1、Spring框架是一站式框架

(1)针对 JavaEE 三层,每一层都有解决技术

(2)在 dao 层,使用 jdbcTemplate

2、Spring对不同的持久化层的技术都进行了封装

  

  (1)jdcbTemplate 对 jdbc 进行了封装

3、jdbcTemplate 使用和 dbutils (Apache公司)使用很相似,都是对数据库进行 crud 的操作

1、增加

  (1)导入 jdbcTemplate 使用的 jar 包(Maven项目)————别忘了数据库驱动!!!

  1. <dependency>
  2. <groupId>org.springframework</groupId>
  3. <artifactId>spring-jdbc</artifactId>
  4. <version>4.0.2.RELEASE</version>
  5. </dependency>
  6.  
  7. <dependency>
  8. <groupId>org.springframework</groupId>
  9. <artifactId>spring-tx</artifactId>
  10. <version>4.0.2.RELEASE</version>
  11. </dependency>
  12.  
  13. <dependency>
  14. <groupId>mysql</groupId>
  15. <artifactId>mysql-connector-java</artifactId>
  16. <version>5.0.4</version>
  17. </dependency>

  (2)创建对象,设置数据库的信息

  (3)创建 jdbcTemplate 对象,设置数据源

  (4)调用 jdbcTemplate 对象里面的方法实现操作

  

2、修改

  

3、删除

  

4、查询

  (1)使用 jdbcTemplate 实现查询操作——对比DButils

    

    (2)查询具体的实现

  查询返回一个值(总条数之类)

      调用的是 queryForObject(String sql, Class<T> requiredType) 方法。

      第一个参数是sql语句,第二个参数是返回值类型的 class 对象

    

  查询返回对象

    原始的JDBC的方式实现

  1. // 2.jdbc实现代码
  2. @Test
  3. public void testJDBC() {
  4. Connection conn = null;
  5. PreparedStatement psmt = null;
  6. ResultSet rs = null;
  7.  
  8. try {
  9. // 加载驱动
  10. Class.forName("com.mysql.jdbc.Driver");
  11. // 创建连接
  12. conn = DriverManager.getConnection("jdbc:mysql:///lianxi", "root", "root");
  13. // 编写sql语句
  14. String sql = "select * from user where username=?";
  15. // 预编译sql
  16. psmt = conn.prepareStatement(sql);
  17. // 设置参数值
  18. psmt.setString(1, "jack");
  19. // 执行sql
  20. rs = psmt.executeQuery();
  21. // 遍历结果集
  22. while(rs.next()) {
  23. // 得到返回结果值
  24. String username = rs.getString("username");
  25. String password = rs.getString("password");
  26. // 放到user对象里
  27. User user = new User();
  28. user.setPassword(password);
  29. user.setUsername(username);
  30. System.out.println(user);
  31. }
  32.  
  33. } catch (Exception e) {
  34. // TODO Auto-generated catch block
  35. e.printStackTrace();
  36. }finally {
  37. try {
  38. rs.close();
  39. psmt.close();
  40. conn.close();
  41. } catch (Exception e2) {
  42. // TODO: handle exception
  43. }
  44. }
  45. }

  jdbcTemplate 中我们使用 queryForObject(String sql, RowMapper<T> rowMapper, Object... args) 方法

  参数:

  (1)SQL语句

  (2) RowMapper 接口,类似于 DBUtils 里面 ResultSetHandler

  (3)可变参数

  

    我们自己实现RowMapper接口,并进行数据封装

  

  查询返回 list 集合

  我们使用 jdbcTemplate 中的  query(String sql, RowMapper<T> rowMapper, Object... args) 方法

  参数:

  (1)sql语句

  (2)RowMapper接口,自己写类实现数据封装(我们还可以用上面自己实现的MyRowMapper

  (3)可变参数(在这里我们sql语句中没有占位符,所以我们可变参数可以不传

   

Spring 的 jdbcTemplate 操作的更多相关文章

  1. spring 学习(四): spring 的 jdbcTemplate 操作

    spring 学习(四): spring 的 jdbcTemplate 操作 spring 针对 javaee 的每一层,都提供了相应的解决技术,jdbcTemplate 的主要操作在 dao 层. ...

  2. Spring的jdbcTemplate操作

    Spring的jdbcTemplate操作 dao层,使用jdbcTemplate Spring对不同的持久化层技术的支持,都进行了封装 JDBC Hibernate5.0 MyBatis JPA 相 ...

  3. Spring的jdbcTemplate操作-未完整

    1 spring框架一站式框架(1)针对javaee三层,每一层都有解决技术(2)在dao层,使用 jdbcTemplate 2 spring对不同的持久化层技术都进行封装

  4. Spring_day03--课程安排_基于aspectj的注解aop_Spring的jdbcTemplate操作

    Spring_day03 上节内容回顾 今天内容介绍 基于aspectj的注解aop Spring的jdbcTemplate操作 增加 修改 删除 查询 Spring配置c3p0连接池和dao使用jd ...

  5. spring学习(四)spring的jdbcTemplate(增删改查封装)

    Spring的jdbcTemplate操作 1.Spring框架一站式框架 (1)针对javaee三层,每一层都有解决技术 (2)到dao 层,使用 jdbcTemplate 2.Spring对不同的 ...

  6. Spring Boot项目中使用jdbctemplate 操作MYSQL数据库

    不废话,先来代码 pom文件: <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http ...

  7. 20. Spring Boot 默认、自定义数据源 、配置多个数据源 jdbcTemplate操作DB

    Spring-Boot-2.0.0-M1版本将默认的数据库连接池从tomcat jdbc pool改为了hikari,这里主要研究下hikari的默认配置 0.  创建Spring Boot项目,选中 ...

  8. Spring JdbcTemplate操作小结

    Spring 提供了JdbcTemplate 来封装数据库jdbc操作细节: 包括: 数据库连接[打开/关闭] ,异常转义 ,SQL执行 ,查询结果的转换 使用模板方式封装 jdbc数据库操作-固定流 ...

  9. Spring Boot教程(二十九)使用JdbcTemplate操作数据库

    使用JdbcTemplate操作数据库 Spring的JdbcTemplate是自动配置的,你可以直接使用@Autowired来注入到你自己的bean中来使用. 举例:我们在创建User表,包含属性n ...

随机推荐

  1. 打印报表工具,web报表工具对比

    ​1.jasperreport报表 有批量报表打印功能,但一般需要通过专门的编程实现批量报表打印:一些较简单的分片式打印能通过主子表实现:不能自动适应纸张大小:不支持分栏打印:不支持一纸多页打印:不支 ...

  2. CLR 详解

    公共语言运行时就是按照CLI标准制作的执行托管代码的环境.CLR 能运行非托管代码. 公共语言运行的功能:代码JIT/AOT编译.  内存管理 .垃圾回收.异常处理.反射服务.安全服务.程序集加载.本 ...

  3. Nullable<T> 结构 |T? 可为空的值类型

    参考链接:https://www.cnblogs.com/tdfblog/p/Nullable-Types-in-Csharp-Net.html https://www.cnblogs.com/min ...

  4. LeetCode-097-交错字符串

    交错字符串 题目描述:给定三个字符串 s1.s2.s3,请你帮忙验证 s3 是否是由 s1 和 s2 交错 组成的. 示例说明请见LeetCode官网. 来源:力扣(LeetCode) 链接:http ...

  5. 微服务从代码到k8s部署应有尽有大结局(k8s部署)

    我们用一个系列来讲解从需求到上线.从代码到k8s部署.从日志到监控等各个方面的微服务完整实践. 整个项目使用了go-zero开发的微服务,基本包含了go-zero以及相关go-zero作者开发的一些中 ...

  6. Mybatis 多对一和一对多 学习总结04

    1.Mybatis 组件的声明周期 ​ 声明周期是组件的重要问题,Mybatis也常用语多线程环境,错误使用会造成多线程并发问题,为正确编写Mybatis应用程序,我们要掌握Mybatis组件的声明周 ...

  7. OSPF协议原理及配置2-理解邻居和邻接关系

    OSPF是一个动态路由协议,运行OSPF的路由器之间需要交换链路状态信息和路由信息,在交换这些信息之前首先需要建立邻接关系.邻接关系用来交换链路状态及路由信息. 注意:并非所有的邻居关系都可以成为邻接 ...

  8. idea Alt+Insert:构造函数

    Alt+Insert:构造函数 包含参数: Constructor:全参构造 Getter:必须的 return 字段名 Setter:this 值 Getter and Setter:选择字段以生成 ...

  9. Linux卸载源码编译安装的软件

    使用auto-apt 和 checkinstall,具体命令如下 #安装auto-apt和checkinstall apt install auto-apt checkinstall #在源码目录中 ...

  10. 线程的sleep()方法和yield()方法有什么区别?

    sleep()方法和yield()方法的区别: sleep()方法给其他线程运行机会时,不考虑线程的优先级,因此会给低优先级的线程运行机会:yield()方法只会给相同优先级或更高优先级的线程运行机会 ...