咱們開發DAO層時用的最多的就是ORM框架(Mybatis,hibernate)了。在有些特殊的狀況下,ORM框架的搭建略顯笨重,這時最好的選擇就是Spring中的jdbcTemplate了。本文對jdbcTemplate進行詳解,而且會對具名參數namedParameterJdbcTemplate進行講解。html
1 在spring配置文件中加上jdbcTemplate的bean:java
<!--注入jdbcTemplate--> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource"/> </bean>
注意:在這以前咱們須要先配置好數據庫數據源dateSource。
2.在使用jdbcTemplate類中使用@Autowired進行注入spring
@Autowired private JdbcTemplate jdbcTemplate;
咱們準備一個數據庫
準備數據庫對應的實體pojo,實體的名稱都要對應數據庫的字段名稱:sql
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:app
@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.增刪改方法測試:
新增:ide
@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。
在經典的 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); }
輸出結果就是新增的主鍵。
本文做者: catalinaLi
本文連接: http://catalinali.top/2017/us...版權聲明: 原創文章,有問題請評論中留言。非商業轉載請註明做者及出處。