本文共 7015 字,大约阅读时间需要 23 分钟。
MyBatis 是一款优秀的持久层框架;
1.2 持久化
数据持久化为什么要持久化?
1.3 持久层
Dao层、Service层、Controller层完成持久化工作的代码块
层界限十分明显
1.4 为什么需要MyBatis
帮助程序员将数据存入到数据库中
方便
传统的JDBC代码太复杂了,简化,框架,自动化
不用MyBatis也可以,技术没有高低之分
优点:
简单易学
灵活 sql和代码的分离,提高了可维护性。 提供映射标签,支持对象与数据库的orm字段关系映射 提供对象关系映射标签,支持对象关系组建维护 提供xml标签,支持编写动态sql思路:搭建环境 --> 导入MyBatis --> 编写代码 --> 测试
步骤: 1.配置pom.xml 2.编写mybatis-config.xml 3.编写mybatisUtils.java工具类 4.编写实体类 User.java 5.编写UserMapper.java接口 6.编写UserMapper.xml配置文件 7.开始测试UserMapperTest.Java2.1 搭建环境
新建项目
mysql mysql-connector-java 8.0.12 org.mybatis mybatis 3.5.4 junit junit 4.12 test
3.编写mybatisUtils.java工具类
//sqlSessionFactory --> sqlSessionpublic class MybatisUtils { static SqlSessionFactory sqlSessionFactory = null; static { try { //使用Mybatis第一步 :获取sqlSessionFactory对象 String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); } catch (IOException e) { e.printStackTrace(); } } //既然有了 SqlSessionFactory,顾名思义,我们可以从中获得 SqlSession 的实例. // SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。 public static SqlSession getSqlSession(){ return sqlSessionFactory.openSession(); }}
4.编写实体类 User.java(自己写)
5.编写UserMapper.java接口public interface UserMapper { public ListgetUserList();}
MapperRegistry是什么?
核心配置文件中注册mappers
@Test public void test(){ //1.获取SqlSession对象 SqlSession sqlSession = MybatisUtils.getSqlSession(); //2.执行SQL // 方式一:getMapper UserMapper userMapper = sqlSession.getMapper(UserMapper.class); ListuserList = userMapper.getUserList(); for (User user : userList) { System.out.println(user); } //关闭sqlSession sqlSession.close(); }
namespace中的包名要和Dao/Mapper接口的包名一致
选择,查询语句;
id:就是对应的namespace中的方法名;
resultType : Sql语句执行的返回值;
parameterType : 参数类型;
1.编写接口
public interface UserMapper { //查询所有用户 public ListgetUserList(); //插入用户 public void addUser(User user);}
2.编写对应的mapper中的sql语句
insert into user (id,name,password) values (#{id}, #{name}, #{password})
3.测试
@Testpublic void test2() { SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); User user = new User(3,"root","666"); mapper.addUser(user); //增删改一定要提交事务 sqlSession.commit(); //关闭sqlSession sqlSession.close();}
注意:增删改查一定要提交事务:
//增删改一定要提交事务sqlSession.commit();
假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们应该考虑使用Map!
1.UserMapper接口
//用万能Map插入用户public void addUser2(Mapmap);
2.UserMapper.xml
insert into user (id,name,password) values (#{userid},#{username},#{userpassword})
3.测试
@Test public void test3(){ SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper mapper = sqlSession.getMapper(UserMapper.class); HashMapmap = new HashMap (); map.put("userid",4); map.put("username","xioayu"); map.put("userpassword",789); mapper.addUser2(map); //提交事务 sqlSession.commit(); //关闭资源 sqlSession.close(); }
Map传递参数,直接在sql中取出key即可! 【parameter=“map”】
对象传递参数,直接在sql中取出对象的属性即可! 【parameter=“Object”】
只有一个基本类型参数的情况下,可以直接在sql中取到
多个参数用Map , 或者注解!
1.Java代码执行的时候,传递通配符% %
ListuserList = mapper.getUserLike("%李%");
2.在sql拼接中使用通配符
select * from user where name like "%"#{ value}"%"
mybatis-config.xml
mybatis的配置文件包含了会深深影响mybatis行为的设置和属性信息。
configuration(配置) properties(属性) settings(设置) typeAliases(类型别名) typeHandlers(类型处理器) objectFactory(对象工厂) plugins(插件) environments(环境配置) environment(环境变量) transactionManager(事务管理器) dataSource(数据源) databaseIdProvider(数据库厂商标识) mappers(映射器)
MyBatis 可以配置成适应多种环境
不过要记住:尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境
学会使用配置多套运行环境!
MyBatis默认的事务管理器就是JDBC ,连接池:POOLED
我们可以通过properties属性来实现引用配置文件
这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties 元素的子元素中设置。【db.poperties】
1.编写一个配置文件
db.properties
driver=com.mysql.cj.jdbc.Driverurl=jdbc:mysql://localhost:3306/mybatis?userSSL=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTCusername=rootpassword=root
2.在核心配置文件中映入
也可以指定一个包,每一个在包 domain.blog
中的 Java Bean,在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。 比如 domain.blog.Author
的别名为 author
,;若有注解,则别名为其注解值。见下面的例子:
在实体类比较少的时候,使用第一种方式。
如果实体类十分多,建议用第二种扫描包的方式。
第一种可以DIY别名,第二种不行,如果非要改,需要在实体上增加注解。
@Alias("author")public class Author { ...}
这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。
MapperRegistry:注册绑定我们的Mapper文件;
方式一:推荐
方式二:使用class文件绑定注册
注意点:
方式三:使用包扫描进行注入
声明周期和作用域是至关重要的,因为错误的使用会导致非常严重的并发问题。
SqlSessionFactoryBuilder:
SqlSessionFactory:
SqlSession:
数据库中的字段
新建一个项目,拷贝之前的,测试实体类字段不一致的情况
测试出现问题
select * from user where id = #{id}==select id,name,pwd from user where id = #{id}
解决方法:
结果集映射
id name pwd
id name password
resultMap 元素是 MyBatis 中最重要最强大的元素。
ResultMap 的设计思想是,对简单的语句做到零配置,对于复杂一点的语句,只需要描述语句之间的关系就行了。
ResultMap 的优秀之处——你完全可以不用显式地配置它们。
如果这个世界总是这么简单就好了。
第一部分到此结束。
第二部分链接:待更新转载地址:http://qyezi.baihongyu.com/