詳解jdbcTemplate和namedParameterJdbcTemplate
我們開發DAO層時用的最多的就是ORM框架(Mybatis,hibernate)了。在有些特殊的情況下,ORM框架的搭建略顯笨重,這時最好的選擇就是Spring中的jdbcTemplate了。本文對jdbcTemplate進行詳解,並且會對具名引數namedParameterJdbcTemplate進行講解。
jdbcTemplate講解
jdbcTemplate提供的主要方法:
- execute方法:可以用於執行任何SQL語句,一般用於執行DDL語句;
- update方法及batchUpdate方法:update方法用於執行新增、修改、刪除等語句;batchUpdate方法用於執行批處理相關語句;
- query方法及queryForXXX方法:用於執行查詢相關語句;
- call方法:用於執行儲存過程、函式相關語句。
jdbcTemplate環境搭建:
1 在spring配置檔案中加上jdbcTemplate的bean:
<!--注入jdbcTemplate-->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>
注意:在這之前我們需要先配置好資料庫資料來源dateSource。
2.在使用jdbcTemplate類中使用@Autowired進行注入
@Autowired
private JdbcTemplate jdbcTemplate;
jdbcTemplate方法測試:
我們準備一個資料庫
準備資料庫對應的實體pojo,實體的名稱都要對應資料庫的欄位名稱:
public class User {
private Long id;
private String username;
private String password;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
'}';
}
}
1.查詢單個物件queryForObject:
@Test
public void testQuery(){
String sql = "select id,username,password from user where id=?";
BeanPropertyRowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);
User user = jdbcTemplate.queryForObject(sql, rowMapper,1);
System.out.println(user);
}
輸出結果: User{id=1, username='123', password='123'}
2.查詢多個物件query:
@Test
public void testMutiQuery(){
String sql = "select id,username,password from user";
BeanPropertyRowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);
List<User> users = jdbcTemplate.query(sql, rowMapper);
for (User user : users) {
System.out.println(user);
}
}
輸出結果:
User{id=1, username='123', password='123'}
User{id=2, username='1234', password='1234'}
3.查詢count、avg、sum等函式返回唯一值:
@Test
public void testCountQuery(){
String sql = "select count(*) from user";
BeanPropertyRowMapper<User> rowMapper = new BeanPropertyRowMapper<User>(User.class);
Integer result = jdbcTemplate.queryForObject(sql, Integer.class);
System.out.println(result);
}
輸出結果:2
4.增刪改方法測試:
新增:
@Test
public void testCreate(){
String sql = "insert into user (username,password) values (?,?)";
int create = jdbcTemplate.update(sql, new Object[]{255, 255});
System.out.println(create);
}
輸出結果為1,去資料庫檢視也確實插入這條。
修改:
@Test
public void testUpdate(){
String sql = "update user set username=? , password=? where id=?";
int update = jdbcTemplate.update(sql, new Object[]{256, 256,3});
System.out.println(update);
}
輸出結果為1,並且確實資料已經修改
刪除:
@Test
public void testDelete(){
String sql = "delete from user where id=?";
int delete = jdbcTemplate.update(sql, new Object[]{3});
System.out.println(delete);
}
5.批量操作:
@Test
public void testBatch(){
List<Object[]> batchArgs=new ArrayList<Object[]>();
batchArgs.add(new Object[]{777,888});
batchArgs.add(new Object[]{666,888});
batchArgs.add(new Object[]{555,888});
String sql = "insert into user (username,password) values (?,?)";
jdbcTemplate.batchUpdate(sql, batchArgs);
}
以上方法基本滿足了日常我們多DAO層進行的操作,不過當你進行CRUD操作時如果傳入的引數不確定,這時候你可能會想起ORM框架的便利。沒關係!Spring也為我們提供了這樣的操作NamedParameterJdbcTemplate。
NamedParameterJdbcTemplate講解
在經典的 JDBC 用法中, SQL 引數是用佔位符 ? 表示,並且受到位置的限制. 定位引數的問題在於, 一旦引數的順序發生變化, 就必須改變引數繫結.
在 Spring JDBC 框架中, 繫結 SQL 引數的另一種選擇是使用具名引數(named parameter).
那麼什麼是具名引數?
具名引數: SQL 按名稱(以冒號開頭)而不是按位置進行指定. 具名引數更易於維護, 也提升了可讀性. 具名引數由框架類在執行時用佔位符取代
具名引數只在 NamedParameterJdbcTemplate 中得到支援。NamedParameterJdbcTemplate可以使用全部jdbcTemplate方法,除此之外,我們來看看使用它的具名引數案例:
具名新增:
@Test
public void testNamedParameter(){
String sql = "insert into user (username,password) values (:username,:password)";
User u = new User();
u.setUsername("555");
SqlParameterSource sqlParameterSource=new BeanPropertySqlParameterSource(u);
namedParameterJdbcTemplate.update(sql,sqlParameterSource);
}
我們來看看結果
這樣我們就可以根據pojo類的屬性值使用JDBC來運算元據庫了。
獲取新增的主鍵:
NamedParameterJdbcTemplate還新增了KeyHolder類,使用它我們可以獲得主鍵,類似Mybatis中的useGeneratedKeys。
@Test
public void testKeyHolder(){
String sql = "insert into user (username,password) values (:username,:password)";
User u = new User();
u.setUsername("555");
SqlParameterSource sqlParameterSource=new BeanPropertySqlParameterSource(u);
KeyHolder keyHolder = new GeneratedKeyHolder();
namedParameterJdbcTemplate.update(sql, sqlParameterSource, keyHolder);
int k = keyHolder.getKey().intValue();
System.out.println(k);
}
輸出結果就是新增的主鍵。
參考資料
- Spring JdbcTemplate詳解
- Spring框架筆記(二十五)——NamedParameterJdbcTemplate與具名引數
- 使用Spring的NamedParameterJdbcTemplate完成DAO操作
本文作者: catalinaLi
本文連結: http://catalinali.top/2017/useJDBC/
版權宣告: 原創文章,有問題請評論中留言。非商業轉載請註明作者及出處。
相關文章
- Spring JdbcTemplate之使用詳解SpringJDBC
- 擁抱 NamedParameterJdbcTemplateJDBC
- 設計模式 - 命令模式詳解及其在JdbcTemplate中的應用設計模式JDBC
- Spring 的 JdbcTemplate 和 JdbcDaoSupportSpringJDBC
- JdbcUtil和JdbcTemplate的封裝JDBC封裝
- JdbcTemplateJDBC
- 抽取JDBCTemplateJDBC
- Spring JdbcTemplate詳解,這都看不懂就安心去當個鹹魚吧!SpringJDBC
- JdbcTemplate基礎JDBC
- JdbcTemplate的callbackJDBC
- JdbcTemplate的使用JDBC
- String.format VS. StrSubstitutor VS. NamedParameterJdbcTemplateORMJDBC
- JDBCTemplate--介紹JDBC
- jdbctemplate事務管理JDBC
- DR和BDR詳解
- 詳解 let 和 var
- require 和 import 詳解UIImport
- exp和imp詳解
- xargs 和 exec詳解
- jni和ndk詳解
- ckeckpoint和SCN詳解
- startActivityForResult和setResult詳解
- Spring框架|整合JdbcTemplateSpring框架JDBC
- SpringBoot使用JdbcTemplateSpring BootJDBC
- Spring boot 五 jdbcTemplateSpring BootJDBC
- JdbcTemplate學習筆記JDBC筆記
- jdbctemplate與事務管理JDBC
- jdbcTemplate使用總結1JDBC
- ROP漏洞詳解和利用
- WebRTC SDP 詳解和剖析Web
- pandas qcut 和cut 詳解
- [譯]KVC 和 KVO詳解
- cookie和session的詳解CookieSession
- HTTP和HTTPS詳解HTTP
- iOS KVC和KVO詳解iOS
- rowspan和colspan用法詳解
- HTTP和HTTPS詳解。HTTP
- IP校驗和詳解