spring調用存儲過程
1. 請問java高手,spring的jdbcTemplate是怎樣調用oracle的存儲過程的呢
這個包應該是
筆者自己創建獲取bean的包
實際datasource
來自
applicationcontext裡面的datasource
所以你也可以自定義獲取datasource
方法
通過applicationcontext獲取datasource
2. 求spring MVC + EXTJS + MSsql 增刪改不用自帶的方法,直接帶參數調用後台存儲過程,請大俠提供例子
一、SpringMVC註解入門
1. 創建web項目
2. 在springmvc的配置文件中指定註解驅動,配置掃描器
Xml代碼
<!-- mvc的註解驅動 -->
<mvc:annotation-driven />
<!--只要定義了掃描器,註解驅動就不需要,掃描器已經有了註解驅動的功能 -->
<context:component-scan base-package="org.study1.mvc.controller" />
<!-- 前綴+ viewName +後綴 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- WebContent(WebRoot)到某一指定的文件夾的路徑 ,如下表示/WEB-INF/view/*.jsp -->
<property name="prefix" value="/WEB-INF/view/"></property>
<!-- 視圖名稱的後綴 -->
<property name="suffix" value=".jsp"></property>
</bean>
<context:component-scan/> 掃描指定的包中的類上的註解,常用的註解有:
@Controller 聲明Action組件
@Service 聲明Service組件 @Service("myMovieLister")
@Repository 聲明Dao組件
@Component 泛指組件, 當不好歸類時.
@RequestMapping("/menu") 請求映射
@Resource 用於注入,( j2ee提供的 ) 默認按名稱裝配,@Resource(name="beanName")
@Autowired 用於注入,(srping提供的) 默認按類型裝配
@Transactional( rollbackFor={Exception.class}) 事務管理
@ResponseBody
@Scope("prototype") 設定bean的作用
3. @controller:標識當前類是控制層的一個具體的實現
4. @requestMapping:放在方法上面用來指定某個方法的路徑,當它放在類上的時候相當於命名空間需要組合方法上的requestmapping來訪問。
Java代碼
@Controller // 用來標注當前類是springmvc的控制層的類
@RequestMapping("/test") // RequestMapping表示 該控制器的唯一標識或者命名空間
public class TestController {
/**
* 方法的返回值是ModelAndView中的
*/
@RequestMapping("/hello.do") // 用來訪問控制層的方法的註解
public String hello() {
System.out.println("springmvc annotation... ");
return "jsp1/index";
}
//*****
}
在本例中,項目部署名為mvc,tomcat url為 http://localhost,所以實際為:http://localhos/mvc
在本例中,因為有命名空間 /test,所以請求hello方法地址為:http://localhost/mvc/test/hello.do
輸出:springmvc annotation...
二、註解形式的參數接收
1. HttpServletRequest可以直接定義在參數的列表,通過該請求可以傳遞參數
url:http://localhost/mvc/test/toPerson.do?name=zhangsan
Java代碼
/**
* HttpServletRequest可以直接定義在參數的列表,
*
*/
@RequestMapping("/toPerson.do")
public String toPerson(HttpServletRequest request) {
String result = request.getParameter("name");
System.out.println(result);
return "jsp1/index";
}
可以從HttpServletRequest 取出「name」屬性,然後進行操作!如上,可以取出 「name=zhangsan」
輸出:zhangsan
2. 在參數列表上直接定義要接收的參數名稱,只要參數名稱能匹配的上就能接收所傳過來的數據, 可以自動轉換成參數列表裡面的類型,注意的是值與類型之間是可以轉換的
2.1傳遞多種不同類型的參數:
url:http://localhost/mvc/test/toPerson1.do?name=zhangsan&age=14&address=china&birthday=2000-2-11
Java代碼
/**
* 傳遞的參數的名字必須要與實體類的屬性set方法後面的字元串匹配的上才能接收到參數,首字元的大小寫不區分
* 請求中傳的參數只要是能和參數列表裡面的變數名或者實體裡面的set後面的字元串匹配的上就能接收到 a
*
*/
@RequestMapping("/toPerson1.do")
public String toPerson1(String name, Integer age, String address,
Date birthday) {
System.out.println(name + " " + age + " " + address + " " + birthday);
return "jsp1/index";
}
/**
* 注冊時間類型的屬性編輯器,將String轉化為Date
*/
@InitBinder
public void initBinder(ServletRequestDataBinder binder) {
binder.registerCustomEditor(Date.class, new CustomDateEditor(
new SimpleDateFormat("yyyy-MM-dd"), true));
}
輸出:zhangsan 14 china Fri Feb 11 00:00:00 CST 2000
2.2傳遞數組:
url:http://localhost/mvc/test/toPerson2.do?name=tom&name=jack
Java代碼
/**
* 對數組的接收,定義為同名即可
*/
@RequestMapping("/toPerson2.do")
public String toPerson2(String[] name) {
for (String result : name) {
System.out.println(result);
}
return "jsp1/index";
}
輸出:tom jack
2.3傳遞自定義對象(可多個):
url:http://localhost/mvc/test/toPerson3.do?name=zhangsan&age=14&address=china&birthday=2000-2-11
User 定義的屬性有:name,age,並且有各自屬性的對應的set方法以及toString方法
Person定義的屬性有:name,age.address,birthday,並且有各自屬性的對應的set方法以及toString方法
Java代碼
/**
*
* 傳遞的參數的名字必須要與實體類的屬性set方法後面的字元串匹配的上才能接收到參數,首字元的大小寫不區分
* 請求中傳的參數只要是能和參數列表裡面的變數名或者實體裡面的set後面的字元串匹配的上就能接收到
*
*/
@RequestMapping("/toPerson3.do")
public String toPerson3(Person person, User user) {
System.out.println(person);
System.out.println(user);
return "jsp1/index";
}
輸出:
Person [name=zhangsan, age=14, address=china, birthday=Fri Feb 11 00:00:00 CST 2000]
User [name=zhangsan, age=14]
自動封裝了對象,並且被分別注入進來!
3. spring+ibatis 調用Oracle存儲過程出錯
jdbcType應該採用標準的數據類型,varchar2是oracle自定義的,非標準的。
改成 jdbcType="VARCHAR" 再試試
4. springmvc + mybatis 怎麼調用存儲過程
不知道怎麼調用,但是可不可以在代碼里實現存儲過程所完成的功能啊,為什麼要在資料庫端進行操作
5. spring怎麼調用sql server帶參的存儲過程
利用SQL的語言可以編寫對於資料庫訪問的存儲過程,其語法如下:
CREATE PROC[EDURE] procere_name [;number]
[
{@parameter data_type} ][VARYING] [= default] [OUTPUT]
]
[,...n]
[WITH
{
RECOMPILE
| ENCRYPTION
| RECOMPILE, ENCRYPTION
}
]
[FOR REPLICATION]
AS
sql_statement [...n]
[ ]內的內容是可選項,而()內的內容是必選項,
例: 若用戶想建立一個刪除表tmp中的記錄的存儲過程Select_delete可寫為:
Create Proc select_del As
Delete tmp
例:用戶想查詢tmp表中某年的數據的存儲過程
create proc select_query @year int as
select * from tmp where year=@year
在這里@year是存儲過程的參數
例:該存儲過程是從某結點n開始找到最上層的父親結點,這種經常用到的過程可以由存儲過程來擔當,在網頁中重復使用達到共享。
空:表示該結點為頂層結點
fjdid(父結點編號)
結點n 非空:表示該結點的父親結點號
dwmc(單位名稱)
CREATE proc search_dwmc @dwidold int,@dwmcresult varchar(100) output
as
declare @stop int
declare @result varchar(80)
declare @dwmc varchar(80)
declare @dwid int
set nocount on
set @stop=1
set @dwmc=""
select @dwmc=dwmc,@dwid=convert(int,fjdid) from jtdw where id=@dwidold
set @result=rtrim(@dwmc)
if @dwid=0
set @stop=0
while (@stop=1) and (@dwid<>0)
begin
set @dwidold=@dwid
select @dwmc=dwmc,@dwid=convert(int,fjdid) from jtdw where id=@dwidold
if @@rowcount=0
set @dwmc=""
else
set @result=@dwmc+@result
if (@dwid=0) or (@@rowcount=0)
set @stop=0
else
continue
end
set @dwmcresult=rtrim(@result)
使用exec pro-name [pram1 pram2.....]
6. springmvc mybatis 存儲過程怎麼調用
mybatis 配置 裡面 寫好存儲過程,然後直接調用。
編輯userMapper.xml
編輯userMapper.xml文件,添加如下的配置項
1 <!--
2 查詢得到男性或女性的數量, 如果傳入的是0就女性否則是男性
3 -->
4 <select id="getUserCount" parameterMap="getUserCountMap" statementType="CALLABLE">
5 CALL mybatis.ges_user_count(?,?)
6 </select>
7
8 <!--
9 parameterMap.put("sexid", 0);
10 parameterMap.put("usercount", -1);
11 -->
12 <parameterMap type="java.util.Map" id="getUserCountMap">
13 <parameter property="sexid" mode="IN" jdbcType="INTEGER"/>
14 <parameter property="usercount" mode="OUT" jdbcType="INTEGER"/>
15 </parameterMap>
四、編寫單元測試代碼
1 package me.gacl.test;
2
3 import java.util.HashMap;
4 import java.util.List;
5 import java.util.Map;
6
7 import me.gacl.custom.model.ConditionUser;
8 import me.gacl.domain.User;
9 import me.gacl.util.MyBatisUtil;
10 import org.apache.ibatis.session.SqlSession;
11 import org.junit.Test;
12
13 /**
14 * @author gacl
15 * 測試調用存儲過程
16 */
17 public class Test6 {
18
19 @Test
20 public void testGetUserCount(){
21 SqlSession sqlSession = MyBatisUtil.getSqlSession();
22 /**
23 * 映射sql的標識字元串,
24 * me.gacl.mapping.userMapper是userMapper.xml文件中mapper標簽的namespace屬性的值,
25 * getUserCount是select標簽的id屬性值,通過select標簽的id屬性值就可以找到要執行的SQL
26 */
27 String statement = "me.gacl.mapping.userMapper.getUserCount";//映射sql的標識字元串
28 Map<String, Integer> parameterMap = new HashMap<String, Integer>();
29 parameterMap.put("sexid", 1);
30 parameterMap.put("usercount", -1);
31 sqlSession.selectOne(statement, parameterMap);
32 Integer result = parameterMap.get("usercount");
33 System.out.println(result);
34 sqlSession.close();
35 }
36 }
7. spring 事務對存儲過程管用嗎
spring 只能對java層進行控制.
如果需要對存儲過程也添加事物,那麼必須自己編寫存儲過程,需要對存儲過程十分熟練.
在每個存儲過程中添加一個入參,這個入參就是控制事物的.
我見過一家期貨公司就是這么用存儲過程的.