一.spring的数据访问哲学

1. Srping的目标之一就是允许我们在开发应用程序的时候,能够遵循面向对象(Object Oriented,OO)原则中的"针对接口式编程";
  • 讲道理现在市面上的所有项目都离不开接口,针对接口是面向对象的重要特征之一,而spring的最终目标就是简化这一特征的使用方法(比如耦合).
  • 只暴露接口,从而体现出该实现的目标!
 

2. Spring的jdbc

  • Spring为多种框架提供了jdbc支持;
  • Spring本身就具有多个模块,他是模块化的框架,就好像java的虚拟机一样,在什么地方,用什么方法;
 

二.配置数据源

1.不管使用什么模板,以及不管使用什么类型的数据库,数据源是必须的(废话),一般有三种方式;

  • 通过jdbc驱动程序定义的数据源(最基本的jdbc,注册驱动->获取连接->获取操作对象->操作结果集->释放资源);
  • 通过JNDL查找数据源(这个配置在服务器上面的比如TOMCAT),(留待)
  • 通过连接池获取数据源(c3p0,druid..)

三.jdbcTemplate (其实并不难,我指的是里面源码,很好理解,前提是理解回调和递归原则)

1.回调,它最难理解的地方之一
    类A调用类B的方法B_1,然后A继续去执行自己的东西,B_1自己执行完了就告诉A,然后类A得到类B_1的执行结果,去做些不可描述的事情
    小王在打游戏,叫小红去做饭,小红做了一会饭做好了,小王还在打游戏(这个时候小王可以决定吃饭,也可以继续打游戏,也可以边吃饭便打游戏(多线程异步))
  • 这之中的实现步骤,小王要实现一个接口,小红做好了饭就调用这个接口去告诉小王传递饭好了的信息,然而这个故事的主人公是小王,小红只是个配角,

换句话说如果小王没有叫小红去做饭那么小红是什么我们都不知道,小红之所以存在是因为小王他需要,所以要小红属于小王,小红对象依赖于小王对象而活,

   在创建小王的同时就要将小红当做参数送给小王;
 
 
  • 警察叔叔和贼的例子,因为警察想要教育贼,所以才有的贼回答问题(这个逻辑一点毛病都没有的)
  1. //回调接口
  2.  
  3. public interface CB {
  4. public void talk(String word);
  5. }
  1. //警察叔叔类
  2. public class Police implements CB {
  3. private Thief tf ; //因为警察叔叔需要贼(要问问题),所以才有的贼(贼要回答问题),主业务需求,诞生附属子实现!!!!
  4. public Police(Thief tf) {//将贼对象传递给警察叔叔,
  5. this.tf = tf;
  6. }
  7.  
  8. //回调方法,用来向当前类传递信息
  9. @Override
  10. public void talk(String word) {
  11. System.out.println("毛贼说:" + word);
  12. }
  13.  
  14. /**
  15. * 警察发问
  16. */
  17. public void talkcrap() {
  18. System.out.println("你错了吗");
  19. tf.worng(this); //警察进行询问,这个贼是传入进来的,将当前类对象传递个贼,贼和警察是1对1关系(当然也可以实现1对多,使用LIist<贼对象>)
  20. }
  21. }
  1. public class Thief {
  2. public void worng(CB cb) { //回调接口传递信息
  3. cb.talk("警察叔叔我错了"); //这个地方传递的参数,当前行调用了接口的talk方法
  4. }
  5. }
回调很绕,我解释不太清除,这个例子是自己想出来的,网上有很多大佬的解释,多敲几遍,多调试几遍代码,就能看懂里面的逻辑所在了;
  • 附上我修改过1对多例子
  1. //回调接口
  2. public interface CallBack {
  3. //这里才是回调,要调用这个方法,才能够传递信息!!!!!
  4. public void tellAnswer(int answer);
  5. }
  6.  
  7. //学生接口
  8. public interface Student {
  9. //这里放入一个对象,要放入主要对象,就是当前类依赖于的对象:主业务对象
  10. public void resovleQuestion(CallBack callBack);
  11. }
  1. //老师类
  2. public class Teacher implements CallBack {
  3. private List<Student> stus;//tom,lusy,rose
  4.  
  5. public Teacher(List<Student> stus) {
  6. System.out.println("teacher对象创建,学生数量"+stus.size());
  7. this.stus = stus;
  8. }
  9.  
  10. @Override
  11. public void tellAnswer(int answer) {
  12. System.out.println(Thread.currentThread().getName()+"你的答案是" + answer);
  13. }
  14.  
  15. public void askQuestion() {
  16. Thread.currentThread().setName("老师线程");
  17. System.out.println("你们写了多长时间的作业?");
  18. long end = 0;
  19. //启动所有线程,回答所有问题
  20. for (int i = 0; i < stus.size(); i++) {
  21. new Thread((Runnable) stus.get(i)).start();
  22.  
  23. }
  24. try {
  25. System.out.println(Thread.currentThread().getName()+"开始休眠15秒,等待所有人的问题回答完");
  26. Thread.sleep(15000);
  27. } catch (InterruptedException e) {
  28. e.printStackTrace();
  29. }
  30. System.out.println("老师线程休眠结束"+System.currentTimeMillis());
  31. for (int i = 0; i < stus.size(); i++) {
  32. stus.get(i).resovleQuestion(this);
  33. }
  34. //当前类实现了回调接口,所以讲当前类对象传入进去
  35.  
  36. //
  37. // long end = System.currentTimeMillis();
  38. // System.out.println("回答问题的时间:"+(end-start));
  39.  
  40. }
  41. }
 
 
学生的实现类只需继承Student接口即可,其中使用了线程暂停来模拟思考题目的过程;sleep();
 
 
2.org.springframework.jdbc.core.RowMapper 
  将ResultSet封装成javaBeen类型,他是一个函数式接口
  1. //将ResultSet封装成User类型
  2. public class RowMapperDemo implements RowMapper<User>{
  3. @Override
  4. public User mapRow(ResultSet resultSet, int i) throws SQLException {
  5. User user = new User();
  6. user.setName(resultSet.getString("name"));
  7. user.setPassword(resultSet.getString("password"));
  8. return user;
  9. }
  10. }
 
 
3.方法总结

  • execute方法:可以用于执行任何SQL语句,一般用于执行update,delete,insert
  • update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;
  • call方法:用于执行存储过程、函数相关语句。
 
 
 
4. 最重要的还是回调

 

  1. //RowMapper接口将ResultSet里面的数据映射到JavaBeen中->封装数据
  2. //queryforList(),执行SQL,将数据返回为List<Map<String(列名),Object(行数据))>>
  3. List<User> list = jt.query(sql, (rs ,i)-> new User(rs.getString("name"),rs.getString("password")));
  4.  
  5. new RowMapper<User>() {
  6. @Override
  7. public User mapRow(ResultSet resultSet, int i) throws SQLException {
  8. User user = new User();
  9. user.setPassword(resultSet.getString("password"));
  10. user.setName(resultSet.getString("name"));
  11. return user;
  12. }
  13. };
 
 
 
5. public <T> List<T> query(String sql, RowMapper<T> rowMapper):将执行的结果通过rowMapper接口映射为实体类对象
  1. public List<Student> getStudents() {
  2. return jt.query("select * from student", (rs, i) -> new Student(rs.getString("stuno"),
  3. rs.getString("name"), rs.getInt("age"), rs.getString("address")));
  4.  
  5. //该lambda表达式相当于
  6. new RowMapper<Student>() {
  7. @Override
  8. public Student mapRow(ResultSet resultSet, int i) throws SQLException {
  9. return new Student(rs.getString("stuno"),rs.getString("name"), rs.getInt("age"), rs.getString("address"));
  10. }
  11. };
  12. }
6.public <T> T queryForObject(String sql, Class<T> requiredType)
  一般用于单列查询,主要用来执行返回聚合函数的查询
  1. jt.queryForObject("select count(*) from student where stuno ='"+stuno+"'", Integer.class);
  2. //返回Integer类型
 
 
 
 
 
7.int update(String sql, @Nullable Object... args)
   一般用来执行 更新,删除,增加操作,通配符使用方式如下
  1. return jt.update("insert into student values(?,?,?,?)", new Object[]{stu.getStuno(), stu.getName(), stu.getAge(), stu.getAddress()});
  2.  
  3. //这两种方式是一样的效果,简略了代码
  4. return jt.update("insert into student values(?,?,?,?)",stu.getStuno(), stu.getName(), stu.getAge(), stu.getAddress());
 
8. execute语句,这种语句一般用来创建数据库,创建表那些,用于那种不复杂(不使用通配符"?")的语句
  1. jt.execute("DELETE FROM student WHERE stuno = '" + stuno + "'");
  2. 不好使用通配符,这条sql半写死的,主要还是用来执行创建数据库,创建表的语句
  3.  
  4. jt.update("DELETE FROM student WHERE stuno = ?",stuno);
  5. 这两条语句的作用是一样的
 
 

9.我uml图画的不是很好,是在网上边学边画的,有问题请不吝赐教QAQ

Spring征服数据库的更多相关文章

  1. Spring : 征服数据库(一)

    严格的说.这里征服的是关系型数据库.之后笔者会以MongoDB为例,给出非关系型数据库的解决方式,敬请期待. 获取连接,操作,关闭,不知所云的异常...是的,你受够了.在使用纯JDBC时你訪问数据库时 ...

  2. Spring : 征服数据库 (两)

    本节介绍Spring和ORM集成框架.尽管Hibernate在开源ORM 社区很受欢迎.但是,本文将MyBatis案例解说.也MyBatis和Hibernate好坏是没有意义的,主要看实际需求,有兴趣 ...

  3. 第五章 征服数据库(Spring对DB的使用)——开发持久层

    本章内容: 定义Spring对数据库访问的支持 配置数据库资源 使用Spring的JDBC模板 在几乎所有的企业级应用中,都需要构建数据持久层.现在意义上的数据持久层是指把对象或者数据保存到数据库中, ...

  4. Spring 链接数据库

    一.前言 Spring 现在是我们在做 JavaWeb 开发中,用的最主流的框架.以后是不是我们暂时不知道,但现在是.废话不多我就介绍 Spring 中.链接数据库的三种方式: git源码地址 需要的 ...

  5. 黑马-Spring与数据库

    Spring与数据库 Spring与jdbc 引入dataSource 在客户端 模板编程 类的结构图, 真正干活的是JdbcTemplate(底层实现,操作 excute方法) JdbcTempla ...

  6. 8.spring:事务管理(上):Spring的数据库编程、编程式事务管理

    Spring的数据库编程 Spring框架提供了JDBC模板模式------>JdbcTemplate 简化了开发,在开发中并不经常是使用 实际开发更多使用的是Hibernate和MyBatis ...

  7. Spring的数据库编程浅入浅出——不吹牛逼不装逼

    Spring的数据库编程浅入浅出——不吹牛逼不装逼 前言 上文书我写了Spring的核心部分控制反转和依赖注入,后来又衔接了注解,在这后面本来是应该写Spring AOP的,但我觉得对于初学者来说,这 ...

  8. Spring(四)Spring与数据库编程

    Spring最重要的功能毫无疑问就是操作数据.数据库的百年城是互联网编程的基础,Spring为开发者提供了JDBC模板模式,那就是它自身的JdbcTemplate.Spring还提供了Transact ...

  9. 【Spring】Spring的数据库开发 - 2、Spring JdbcTemplate的常用方法(execute、update、query)

    Spring JdbcTemplate的常用方法 文章目录 Spring JdbcTemplate的常用方法 execute() update() query() 简单记录-Java EE企业级应用开 ...

随机推荐

  1. 3D 图片播放焦点图插件Adaptor

    在线演示 本地下载

  2. 多线程与Java的JMM内存模型

    共享内存模型指的就是Java内存模型(简称JMM),JMM决定一个线程对共享变量的写入时,能对另一个线程可见.从抽象的角度来看,JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存( ...

  3. android使用mina需要注意的问题

    1.第三方jar包的使用       如果在Java Build Path中使用Add External JARs这种方式,运行时会有找不到类的错误(我的上面有,如果你没出现,恭喜你),上网查了几种方 ...

  4. BZOJ(begin) 1328 [Usaco2003 Open]Jumping Cows:贪心【波峰波谷模型】

    题目链接:http://begin.lydsy.com/JudgeOnline/problem.php?id=1328 题意: 给你一个长度为n的正整数序列. 可以选任意个数字,只能从左往右选. 偶数 ...

  5. 【Codeforces】Gym 101156G Non-Attacking Queens 打表

    题意 求$n\times n$的棋盘上放$3$个皇后使得互相不攻击的方案数 拓展是$m\times n$棋盘上放$k$皇后,暴力打表找到了公式 OEIS 代码 import java.math.Big ...

  6. 使用top命令查看系统状态

    Linux系统可以通过top命令查看系统的CPU.内存.运行时间.交换分区.执行的线程等信息.通过top命令可以有效的发现系统的缺陷出在哪里.是内存不够.CPU处理能力不够.IO读写过高? 使用SSH ...

  7. 华为机试 可怕的N阶乘

    题目标题: 计算阶乘n!是一件可怕的事情,因为当n并不是很大时,n!将是一个很大的值.例如13! = 6227020800,已经超过了我们常用的unsigned int类型的取值范围.请设计一个程序, ...

  8. 1123 Is It a Complete AVL Tree(30 分)

    An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child sub ...

  9. MySQL日期处理函数_20160922

    除了对文本字符串进行处理外,对日期处理是最常用的了,年.月.周.日等等,同时在日常工作报表中月报.周报.日报这样的报表也是最常见了. #二.mysql对日期的处理 SELECT #具体某一天 DATE ...

  10. 「LOJ#6121」「网络流 24 题」孤岛营救问题(BFS

    题目描述 1944 年,特种兵麦克接到国防部的命令,要求立即赶赴太平洋上的一个孤岛,营救被敌军俘虏的大兵瑞恩.瑞恩被关押在一个迷宫里,迷宫地形复杂,但幸好麦克得到了迷宫的地形图.迷宫的外形是一个长方形 ...