环境的配置见我上一篇博客

首先,在上一篇博客中,我们知道,SqlSession中封装了对数据库的curd操作,通过sqlSessionFactory可以创建SqlSession,而SqlSessionFactory是通过SqlSessionFactoryBuilder来进行创建的。

通过ss实例,来实现对数据库的curd操作。

例如: ss.delete("test.deleteUserById", 3);

然后,关于SqlSessionFactoryBuilder

SqlSessionFactoryBuilder用于创建SqlSessionFactory,并且SqlSessionFactory一旦创建完成就不需要SqlSessionFactoryBuilder了,所以可以把它当做一个工具类使用。

最佳的使用方法是放到方法体内当局部变量。

关于SqlSessionFactory

SqlSessionFactory是一个接口,接口中定义了openSession的不同重载方法。最佳使用范围是整个应用运行期间,一旦创建后可以重复使用。所以创建一个实例就够了

所以通常以单例模式管理它。

关于SqlSession

SqlSession是一个面向用户的接口,其中定义了数据库的操作方法。

每个线程都应该有它自己的SqlSession实例,该实例不能被共享使用,它也是线程不安全的。所以使用的最佳范围是请求或方法内。绝对不能把它实例的引用放到一个类的静态字段或实例字段中。

打开一个SqlSession,使用完毕要记得关闭它。所以通常放到finally代码块中以确保每次都能关闭。

这里直接进入正题~~

配置文件依旧用的上一篇博客定义的User.xml

首先,编写Dao接口和Dao实现类

在这里,用查询操作来举例子。

要实现Insert,update,delete操作,都是同样的道理,这里不再赘述。

由于SqlSessionFactory一旦创建后可以重复使用。所以创建一个实例就够了,并且可以通过构造方法把它传入进去。

public class UserDaoImpl implements UserDao {

    private SqlSessionFactory sqlSessionFactory;

    //通过构造方法注入
public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {
super();
this.sqlSessionFactory = sqlSessionFactory;
} @Override
public User findUserById(Integer id) {
//sqlSession是线程不安全的,所以它最佳的使用范围在方法体内,用完就能销毁
SqlSession ss = sqlSessionFactory.openSession();
User user = ss.selectOne("test.findUserById", id);
return user;
} @Override
public List<User> findUserByUserName(String username) {
SqlSession ss = sqlSessionFactory.openSession();
List<User> list = ss.selectList("test.findUserByUserName",username);
return list;
} }

测试代码:

public class UserDaoTest {

    private SqlSessionFactory factory;

    //在测试方法前执行这个方法
@Before
public void setUp() throws Exception{
String resource = "SqlMapConfig.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
factory = new SqlSessionFactoryBuilder().build(inputStream); }
@Test
public void testFindUserById() throws Exception{
UserDao userdao = new UserDaoImpl(factory);
User user = userdao.findUserById(1);
System.out.println(user);
} @Test
public List<User> testFindUserByUsername() throws Exception{
UserDao ud = new UserDaoImpl(factory);
List<User> list = ud.findUserByUserName("王");
return list; }
}

这是第一个方法的运行结果:

原始Dao开发存在的问题:

Dao方法体依旧存在重复代码,即:通过SqlSessionFactory创建SqlSession,调用SqlSession的数据库操作方法。

在本例中,调用sqlSession的数据库操作方法需要指定id,这里存在硬编码,不利于开发维护。

通过Mybatis原始Dao来实现curd操作的更多相关文章

  1. Spring + Mybatis - 原始dao开发整合 与 Mapper代理整合

    Spring + Mybatis - 原始dao开发整合 与 Mapper代理整合 标签: mybatisSpringbeanApplicationContextMapper 2015-12-31 1 ...

  2. MyBatis原始dao开发及问题总结(五)

    一.MyBatis原始Dao开发方式 1.原始dao开发需要程序员编写dao接口和dao接口实现类 编写UserDao接口:UserDao.java package codeRose.dao; pub ...

  3. Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6869133.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(一)——My ...

  4. Mybatis 原始dao CRUD方法

    用到的相关jar包及所用版本如下: 其中的Mybatis可以到github.com的网站下载 <project xmlns="http://maven.apache.org/POM/4 ...

  5. MyBatis 原始Dao开发方式

    原始Dao开发方法需要程序员编写Dao接口和Dao实现类. 映射文件 <?xml version="1.0" encoding="UTF-8" ?> ...

  6. Mybatis使用Dao代码方式CURD

    Mybatis 使用Dao代码方式进行增.删.改.查. 1.Maven的pom.xml <project xmlns="http://maven.apache.org/POM/4.0. ...

  7. mybatis入门基础(二)----原始dao的开发和mapper代理开发

    承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...

  8. 【mybatis深度历险系列】深入浅出mybatis中原始dao的开发和mapper代理开发

    使用Mybatis开发Dao,通常有两个方法,即原始Dao开发方法和Mapper接口开发方法.mybatis在进行dao开发的时候,涉及到三姐妹,分别是SqlSessionFactoryBuilder ...

  9. MyBatis开发Dao层的两种方式(原始Dao层开发)

    本文将介绍使用框架mybatis开发原始Dao层来对一个对数据库进行增删改查的案例. Mapper动态代理开发Dao层请阅读我的下一篇博客:MyBatis开发Dao层的两种方式(Mapper动态代理方 ...

随机推荐

  1. WebForm服务器验证控件与前端js自定义验证共同使用

        问题: 前端aspx页面中需要在button中添加OnClientClick事件后,这个OnClientClick所执行的自定义的客户端js验证:这个时候,所有的服务器验证控件都会失效!   ...

  2. Cordova入门系列(一)创建项目

    Cordova是什么? 初学Cordova的人,虽然了解一点点,知道Cordova是用来将html, css, js变成app的,但并不知道到底是怎么用的,原理是什么.经常会有这样的困惑: 它是一个可 ...

  3. String、StringBuilder和StringBuffer的区别

    1         String.StringBuilder和StringBuffer的区别 String.StringBuilder.StringBuffer都可以用来保存字符串.如果是使用次数比较 ...

  4. MySQL存储过程 游标

    MySQL存储过程  游标 如何在存储过程中使用MySQL游标来遍历SELECT语句返回的结果集 MySQL游标简介 要处理存储过程中的结果集,请使用游标.游标允许您迭代查询返回的一组行,并相应地处理 ...

  5. inode满处理

    https://blog.csdn.net/liuxiao723846/article/details/79423581 [root@monitor251 bin]# for i in /boot; ...

  6. linux blast

    建库 减压后,改名为blast,并在blas目录在建立db文件1,建立数据库makeblastdb -in db.fasta -dbtype nucl(prot) -parse_seqids -has ...

  7. scrapy 中crawlspider 爬虫

    爬取目标网站: http://www.chinanews.com/rss/rss_2.html 获取url后进入另一个页面进行数据提取 检查网页: 爬虫该页数据的逻辑: Crawlspider爬虫类: ...

  8. Python连接MySQL数据库的多种方式

    上篇文章分享了windows下载mysql5.7压缩包配置安装mysql 后续可以选择 ①在本地创建一个数据库,使用navicat工具导出远程测试服务器的数据库至本地,用于学习操作,且不影响测试服务器 ...

  9. 【差分约束系统】 note

    [差分约束系统] note >>>>题目 [题目描述] 最近有一款很火的游戏,叫做八分音符酱,它和马里奥很相似,不过它的跳跃距离是由你的声音大小来控制的.不过我们现在对玩法就行 ...

  10. EF6中执行Sql语句

    EF中提供了两个方法,一个是执行查询的Sql语句SqlQuery,另外一个是执行非查询的语句ExecuteSqlCommand.SqlQuery有两种形式的,一种是泛型的,一种是非泛型的.比如我们要在 ...