就是自己写实现类的方式来开发 直接finish 把之前写的CRUD的代码复制到过来. 在把之前pom.xml里面的包的依赖也复制过来 复制到当前的pom.xml内 允许自动导入 以上步骤就是复制了一个完整的上一节的CRUD的工程 调整和改造 QueryVo删掉. 映射文件中.resultMap的内容并不需要.也删除掉. 这里也需要把resultMap改成resultType.并且值是完整的包的路径 实际的开发过程中用的都是代理dao的方式.所以这里只作为了解.选学的内容 实体类改成和数据表 内的…
另外一种情况,不写Mybits的dao实现类的情况. 切换工程到CRUD的工程.这里面是不写dao实现类的方式 进入到GetMaper里面.这里是创建代理对象 去找SqlSession的实现类DefaultSqlSession DefaultSqlSession的getMapper方法 进入Configuration的getMapper方法 MapperRegistry的getMapper方法.里面走的是mapperProxyFactory.newInstance的方法 下面的调用上面的方法.…
从测试类入手,断点调试 找到实现类,进入到insert方法里面 这里是SqlSession的接口里面的方法. 我们需要找SqlSession的实现类. DefaultSqlSession 里面有两个insert方法,第一个insert执行的是第二个insert方法,德尔格insert方法又执行的是下面的update方法 delete最终执行的也是update方法 我们的update方法传了两个参数 所以他最终执行的是这里两个参数的 update再往后走就是executor.update方法.也就…
继续运行testFindAll方法.把其他类的断点都删除掉. 只在这里加了断点,所以直接就跳转到这里了.RoutingStatementHandler里面的query方法 继续往下走,断点又回到了这里.delegate变成了一个叫做PrparedStatementHandler 找PrparedStatementHandler PrparedStatementHandler里面找到query方法.然后加断点. preparedStatement就是JDBC里面的对象.ps.execute不仅能执…
delete方法没有并SqlSession的delete方法,而是调用的Upadte方法. 在测试类这里加断点. 实际的方法体内也加断点 运行测试方法,选择debug的方式 走到断点这里.会看到factory是DefaultSqlSessionFactory session是DefaultSqlSession 找借口的实现类 选中SqlSession 选中SqlSession并鼠标右键---show Implementations 显示它的所有实现 然后就显示了两个.通过刚才的断点调试我们知道是…
update和上面的Insert代码基本是一样的,只需要修改这里, 测试Update的方法 删除 findById 测试方法 findByName 测试方法 findTotal…
再完善.saveUser的方法 测试保存的操作 报错了 SqlSession的insert的源码 我们在执行Insert的时候,并没有把user对象传过去 usersex改成sex 再次测试…
之前都是使用我们传统的方式进行引入jar包,现在我们使用maven进行管理依赖,这样,我们的jar就不需要我们进行管理,而且,我们的maven还可以进行项目构建,一个项目从编写源代码到编译,测试,运行,打包,部署的过程,只需要对应的一个命令即可以了,方便了很多 这里,我们直接进入主题,像eclipse中怎么配置maven等这里我们暂时不说,直接从创建项目开始,而且我们采用的是纯配置文件的方式 我们可以看一下我们的目录结构 这咯我们的ssh_parent是父工程,而剩下的都是它的子模块 这里我们的…
controller层负责创建类传递类给service:service层负责逻辑编写调用dao层 将编写后的类传递到dao层,保证事务的正确性:dao层负责数据的持久化…
基于Mybatis的Dao层开发 SqlSessionFactoryBuilder用于创建SqlSessionFacoty,SqlSessionFacoty一旦创建完成就不需要SqlSessionFactoryBuilder了,因为SqlSession是通过SqlSessionFactory生产,所以可以将SqlSessionFactoryBuilder当成一个工具类使用,最佳使用范围是方法范围即方法体内局部变量. SqlSessionFactory是一个接口,接口中定义了openSession…
写在前面:菜鸟拙见,望请纠正 一:为什么需要连接池 普通的JDBC数据库连接使用 DriverManager 来获取,每次向数据库建立连接的时候都要将 Connection 加载到内存中,需要数据库连接的时候,就向数据库要求一个,执行完成后再断开连接..这样的方式将会消耗大量的资源和时间 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去. 其实就是以前的时候每一次执行操作都要获得一…
配置别名 上面制定了好了别名后,映射文件就可以简写了.不区分大小写 皆可以小写也可以大写 大小写混着也可以 测试 package 直接把com.itheima.domain下面所有的类都注册了 可以使用别名,并且类名就是别名. 测试,.依然没有问题 mappers里面也有对应的包 测试,.依然没问题 总结 这两个标签,在实际的开发中节省很多的代码…
properties 可以把数据库链接的配置放在上面的properties里面 #{占位符}的形式去引用上面的.下面的内容就是引用上面的内容的定义. 运行查询的方法测试一下 这样改造可以成功的运行程序. 数据库外部配置文件 可以支持把放到外部的配置文件里面. 给的资料里面有一个文件:jdbcConfig.properties 里面是配置数据库的信息 把此文件复制到我们项目的resources里面.jdbcConfig.properties 和配置文件内的前缀保持一致 运行测试方法 浏览器打开这个…
注解开发是省了IUserDao.xml这个映射文件里面的配置 环境搭建 首先是packaging标签.输入jar 需要准备一个实体类.生成getter和setter还有toString方法 创建dao接口.先写一个查询所有的接口 按照原来的要求需要在resources下创建Directory也就是文件夹 创建了com.itheima.dao这三个文件夹.为了演示用. 配置主配置文件SqlMapConfig.xmls 复制给的资料里面的config的约束 先输入configuration标签.然互…
定义user的实体.然后生成getter和setter 定义一个可以封装Account和User的Map type这里虽然是account类型 这一段只能保证account的数据完成.并不能保证user对象 association标签.column表示外键的字段. 运行findAll的方法 user对象出现null的原因: javaType表示封装那个属性信息里面.正常应该是完成的包名 因为我们用了别名所以这里可以直接简单用user表示:com.itheima.domain.User 再次执行测…
封面:洛小汐 作者:潘潘 一直以来 他们都说为了生活 便追求所谓成功 顶级薪水.名牌包包 还有学区房 · 不过 总有人丢了生活 仍一无所获 · 我比较随遇而安 有些事懒得明白 平日里问心无愧 感兴趣的事能一直做 便很知足 · 难道不是 除了活着 其他都只是锦上添花吗 前言 上节我们介绍了 < Mybatis系列全解(六):Mybatis最硬核的API你知道几个? >一文,详细解读了 Mybatis 框架核心设计和 API ,图文并茂,干货满满,感兴趣的朋友可以往下翻目录找到文章的链接传送门进行…
mybatis可以用xml进行数据操作,也可以在dao层用注解的方式,也可以采取xml和dao层接口组合使用的方法.显然 ,后者更加简单. 实体类Student   package com.zhao.entity; /** * * @author: zhao * @time: 2016年5月31日 * * @description:学生 */ public class Student { private int stuId; private String stuName; private Str…
本文将探讨使用 mapper接口,以及 pojo 包装类进行 dao 层基本开发 mybatis dao 层开发只写 mapper 接口 其中需要 开发的接口实现一些开发规范 1. UserMapper.xml 这个配置文件中的namespace应该是 mapper 接口的地址 2. UserMapper.java 中的方法名与UserMapper.xml 的 statementid 要保持一致 3. 第二点中的方法 输入参数 与 返回值均要 跟 UserMapper.xml 中配置好的 par…
MyBatis 的前生为Apache的开源项目iBatis.其优势在于灵活,几乎可以替代JDBC,同时提供了编程接口.目前MyBatis的数据访问Dao层不需要实现类,也不需要像JDBC那样拼接Hql,它只需要一个接口和XML(或者注解).MyBatis提供自动映射.动态SQL.级联.缓存.注解.代码和SQL分离等特性,使用很方便,还能够对SQL就行优化.因为其具有封装少.映射多样化.支持存储过程.可以进行SQL优化等特点,使得它替代了Hibernate成为Java互联网中首选的持久框架.下面简…
开发规范 Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体同原始Dao接口实现类方法. Mapper接口开发需要遵循以下规范: Mapper.xml文件中的namespace与mapper接口的类路径相同,即namespace必须是接口的全限定名. Mapper接口方法名和Mapper.xml中定义的每个statement的id相同. Mapper接口方法的输入参数类型和mapper.xml中定…
Mybatis(3)dao层开发 以实现类完成CRUD操作 1.持久层dao层接口的书写 src\main\java\dao\IUserDao.java package dao; import domain.QueryVo; import domain.User; import java.util.List; public interface IUserDao { /** * 查询所有数据 * @return */ List<User> findAll(); //List<User>…
传统的dao层编写 以前编写dao层,先新建一个包com.chy.dao,再写接口StudentDao: public interface StudentDao { public void insertStudent(Student student); public void updateStudent(Student student, Integer id); public Student selectStudent(Integer id); } 接着写实现类StudentDaoImpl: p…
1.Mybatis的Dao层实现 1.1 传统开发方式 1.1.1编写UserDao接口 public interface UserDao { List<User> findAll() throws IOException; } 1.1.2.编写UserDaoImpl实现 public class UserDaoImpl implements UserDao { public List<User> findAll() throws IOException { InputStream…
根据慕课网上关于java高并发秒杀API的课程讲解用maven+ssm+redis实现的一个秒杀系统 参考了codingXiaxw's blog,很详细:http://codingxiaxw.cn/2016/11/27/53-maven-ssm-seckill-dao/ 这是第一个部分:业务分析与DAO层 1.相关技术介绍 MySQL:1.这里我们采用手写代码创建相关表,掌握这种能力对我们以后的项目二次上线会有很大的帮助:2.SQL技巧:3.事务和行级锁的理解和一些应用. MyBatis:1.D…
Java秒杀简单设计二:数据库表Dao层设计 上一篇中搭建springboot项目环境和设计数据库表  https://www.cnblogs.com/taiguyiba/p/9791431.html 在此基础上设计数据库表Dao层代码 1.数据库表设计 项目涉及到两张表,seckill:秒杀库存表,success_killed:秒杀成功明细表 seckill:秒杀库存表 CREATE TABLE `seckill` ( `seckill_id` bigint() NOT NULL AUTO_I…
SSM是sping+springMVC+mybatis集成的框架. MVC即model view controller. model层=entity层.存放我们的实体类,与数据库中的属性值基本保持一致. service层.存放业务逻辑处理,也是一些关于数据库处理的操作,但不是直接和数据库打交道,他有接口还有接口的实现方法,在接口的实现方法中需要导入mapper层,mapper层是直接跟数据库打交道的,他也是个接口,只有方法名字,具体实现在mapper.xml文件里,service是供我们使用的方…
1.配置文件添加paginationInterceptor @Configuration @MapperScan("fama.cost.*.mapper") public class SpringConnectionFactory { @Bean public MybatisPlusInterceptor paginationInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor()…
首先这是现在最基本的分层方式,结合了SSH架构.modle层就是对应的数据库表的实体类.Dao层是使用了Hibernate连接数据库.操作数据库(增删改查).Service层:引用对应的Dao数据库操作,在这里可以编写自己需要的代码(比如简单的判断).Action层:引用对应的Service层,在这里结合Struts的配置文件,跳转到指定的页面,当然也能接受页面传递的请求数据,也可以做些计算处理.以上的Hibernate,Struts,都需要注入到Spring的配置文件中,Spring把这些联系…
Dao层是使用了Hibernate连接数据库.操作数据库(增删改查).Service层:引用对应的Dao数据库操作,在这里可以编写自己需要的代码(比如简单的判断).Action层:引用对应的Service层,在这里结合Struts的配置文件,跳转到指定的页面,当然也能接受页面传递的请求数据,也可以做些计算处理.以上的Hibernate,Struts,都需要注入到Spring的配置文件中,Spring把这些联系起来,成为一个整体. 一般java都是三层架构 数据访问层(dao) 业务逻辑层(biz…
1.dao层要有connection 2.dao层进行分页,mysql limit关键字 3.dao层进行结果集转换为java bean 4.dao层queryforlist…