Spring JDBC

 

Spring降低了JavaEE API的使用难度,其中就包括JDBC。

Spring JDBC的核心类是JdbcTemplate,JdbcTemplate类   extends  JdbcAccessor抽象类,并implements了JdbcOperations接口。

 

 

 

Spring JDBC的使用步骤

1、添加数据库驱动的jar包

Spring JDBC需要3个jar包的支持:

  • spring-jdbc.jar、spring-tx.jar(事务处理)   这2个是Spring自带的,不用管
  • 数据库驱动的jar包

 

 

2、在xml中配置DataSource、JdbcTemplate

    <!--配置数据源,class打DMDS就出来了-->
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.cj.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://127.0.0.1/my_db?serverTimezone=GMT" />
        <property name="username" value="root" />
        <property name="password" value="abc" />
    </bean>

    <!--配置JdbcTemplate-->
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
        <!--注入数据源依赖-->
        <property name="dataSource" ref="dataSource" />
    </bean>

 

 

3、使用JdbcTemplate

1   ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
2         //获取配置的JdbcTemplate
3         JdbcTemplate jdbcTemplate=applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
4         //之后就可以通过jdbcTemplate操作数据库了
5         //.......

 

 

 

 

JdbcTemplate类的常用方法

1、execute(String  sql)   

可执行任何sql语句,但因为返回值是void,所以一般用于执行DDL语句(对数据库、表进行新建、修改、删除操作)。

 

 

2、查询,有多个查询方法

 

 

3、update()    插入、修改、删除记录

  • int  update(String sql)     //返回受影响的记录数
  • int  update(String sql, Object…args)

 

 

4、batchUpdate()   批量插入、修改、删除记录

  • int[]   batchUpdate(String…sql)    //返回受影响的记录数
  • int[]   batchUpdate(String…sql, List<Object[]>  args)    

 

 

5、set系列方法

  • setMaxRows(int max)    //设置返回的最大记录数
  • setQueryTimeout(int  timeout)    //设置查询超时
  • setDataSource(DataSource  dataSource)    //设置数据源

以上方法都有对应的get方法。

 

 

 

 

 

JdbcTemplate类的查询方法

1、queryForObject()      //返回一条记录 ,select只能选择一列

  • 目标类型   queryForObject(String sql, 目标类型.class)    //返回值就是目标类型的结果
  • 目标类型  queryForObject(String sql, Object[] args, 目标类型.class)    //args是sql语句中?对应的值
  • 目标类型  queryForObject(String sql, 目标类型.class, Object… args)

 

1      String sql="select id from student_tb where name = '张三'";
2         int id=jdbcTemplate.queryForObject(sql,Integer.class);  //如果查询到的id有多个,此句代码会报错。包装类、普通类会自动转换。

 

1     String sql="select id from student_tb where name = ? and score = ?";
2         Object[] arg=new Object[]{"张三",90};
3         int id=jdbcTemplate.queryForObject(sql,arg,int.class);  //参数要是Object[]的形式

 

1     String sql="select id from student_tb where name = ? and score = ?";
2         int id=jdbcTemplate.queryForObject(sql,int.class,"张三",90);

 

说明

  • 因为是ForObject,一个对象,所以select只能选中一列,选择多个列会报错。
  • 必须且只能返回一条记录,如果返回多条记录或没有记录匹配,都会报错

 

 

 

 

2、queryForRowSet()     //返回查询结果集

  • SqlRowSet  queryForRowSet(String sql)     //SqlRowSet即结果集
  • SqlRowSet  queryForRowSet(String sql, Object…args)    //args是sql语句中的?对应得值。
1     String sql="select * from student_tb";
2         SqlRowSet rowSet=jdbcTemplate.queryForRowSet(sql);
3         while (rowSet.next()){
4             System.out.println(rowSet.getInt(1));   //参数可以是int型的列索引(从1开始),也可以是String类型的列名
5         }

 

 

 

 

3、queryForMap()    //返回一条记录,select可选择多列

  • queryForMap(String sql)
  • queryForMap(String sql, Object…args)
1     String sql="select id,name,age,score from student_tb where id = 1";
2         Map<String,Object> map=jdbcTemplate.queryForMap(sql); //此处使用泛型时,key必须是String,value必须是Object
3         System.out.println("学号:"+map.get("id"));
4         System.out.println("姓名:"+map.get("name"));
5         System.out.println("年龄:"+map.get("age"));
6         System.out.println("成绩:"+map.get("score"));

 

说明

  • queryForMap()是查询一条记录,只能返回一条记录,若返回多条记录或没有记录匹配,都会报错。
  • Map<String,Object>是固定的,不能修改。
  • Map<String,Object>存储的是一条记录。String指的是select选中的字段名,Object指的是该字段的值。因为一个key(字段)只能对应一个value(字段值),所以返回的必须且只能是一条记录。

 

 

 

 

4、queryForList()    //返回列表,可以返回多条记录

  • List<T>  queryForList(String sql, 目标类型.class)
  • List<T>  queryForList(String sql, Object[]  args, 目标类型.class)    //args是sql语句中?的对应值
  • List<T>  queryForList(String sql, 目标类型.class, Object…args)
1     String sql="select name from student_tb";
2         List<String> list=jdbcTemplate.queryForList(sql,String.class);
3         Iterator<String> iterator=list.iterator();
4         while (iterator.hasNext()){
5             System.out.println(iterator.next());
6         }

说明:因为返回值是List<T>,所以可以返回多条记录。List元素类型必须相同,所以select只能选中一列,选中多列会报错。

 

 

  • List<Map<String,Object>>   queryForList(String sql)
  • List<Map<String,Object>>   queryForList(String sql, Object…args)
 1     String sql="select id,name,age,score from student_tb";
 2         List<Map<String,Object>> list=jdbcTemplate.queryForList(sql);  //select选择多个字段,数据类型不同,value只能是Object
 3         Iterator<Map<String,Object>> iterator=list.iterator();  //如果此处泛型指定迭代的元素类型,则迭代元素需要强制类型转换为Map<String,Obejct>
 4         Map<String,Object> map;
 5         while (iterator.hasNext()){
 6             map= iterator.next();
 7             String out="学号:"+map.get("id")+"        姓名:"+map.get("name")+"      年龄:"+map.get("age")+"       成绩:"+map.get("score");
 8             System.out.println(out);
 9 
10         }

说明:List的元素类型是Map<String,Obejct>,一个Map<String,Obejct>表示一条记录(可以是多列),即返回值可以是多条记录,select可以选择多列。

 

queryForList()的返回值是List,会把返回的记录放入List中,所以可以返回0条或多条记录。返回0条时,List是空的,这是可以的,不会报错。

 

 

 

 

5、query()   

  • List<T>   query(String sql, RowMapper<T>  rowMapper)
  • List<T>   query(String sql, Object[]  args, RowMapper<T>  rowMapper)
  • List<T>   query(String sql, RowMapper<T>  rowMapper, Object…args)
 1 class Student{
 2     private int id;
 3     private String name;
 4     private int age;
 5     private int score;
 6 
 7     public void setId(int id) {
 8         this.id = id;
 9     }
10 
11     public void setName(String name) {
12         this.name = name;
13     }
14 
15     public void setAge(int age) {
16         this.age = age;
17     }
18 
19     public void setScore(int score) {
20         this.score = score;
21     }
22 
23 
24     public int getId() {
25         return id;
26     }
27 
28     public String getName() {
29         return name;
30     }
31 
32     public int getAge() {
33         return age;
34     }
35 
36     public int getScore() {
37         return score;
38     }
39 }
40 
41 
42 public class Test {
43     public static void main(String[] args) {
44         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
45         JdbcTemplate jdbcTemplate=applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
46 
47 RowMapper<Student> rowMapper=new BeanPropertyRowMapper<>(Student.class); 48 String sql="select id,name from student_tb"; 49 List<Student> list=jdbcTemplate.query(sql,rowMapper); 50 for (Student student:list){ 51 System.out.println(student.getName()); 52 } 53 
54     }
55 }

 

说明

  • 可返回多条记录,select可选择多列,但select选择的列名必须和目标类的属性名一致,且目标类中必须有该列(属性)的setter方法,因为返回的记录是通过目标类的setter方法初始化对象的,如果目标类中没有对应属性的setter方法,不会报错,属性会初始化为默认值。select未选中的属性会初始化为默认值。
  • RowMapper是接口,BeanPropertyRowMapper是其实现类

 

点赞