Mybatis
他是一个支持普通Sql查询,存储过程和高级映射的一个优秀的持久层框架,他是一个用来操作数据库的一个框架
环境搭建:
- 导入两个jar包 一个是mybatis的核心jar,一个是mysql的数据库连接驱动
- 书写主配置文件(mybatis.xml):在主配置文件中配置数据库的连接信息(数据库驱动、url、usenrame、password等)
- 书写局部配置文件(xxx.xml):局部配置文件的名字与dao层的类名保持一致,局部配置文件用来保存sql语句
- 将主配置文件(mybatis.xml)与局部配置文件(xxx.xml)关联起来
- 写一个实体类,实体类里面的属性及数据类型要与数据库中相同
- 写一个实现类跟局部配置文件在同一个包下
xml中的注释快捷键:
mybatis.xml 主配置环境
局部配置
id,name,age,birth
insert into man set id=#{id},name=#{name},age=#{age},birth=#{birth};
update man set name=#{name},age=#{age} where id = #{id};
delete from man where id = #{0};
实现类模板
//1、需要执行sql语句(SqlSession---->SqlSessionFactory----->SqlSessionFactoryBuilder)
SqlSessionFactoryBuilder sfb = new SqlSessionFactoryBuilder();
//将mybatis.xml主配置文件变成字节输入流
InputStream ins = Resources.getResourceAsStream( "mybatis.xml");
SqlSessionFactory ssf = sfb.build(ins);
SqlSession session= ssf.openSession();
List lists = session.selectList("com.mao.dao.impl.StudentDaoImpl.selectAll");
for (Student student : lists) {
System.out.println(student);
}
可以将获得Session放到一个init()方法中,每次执行只需要调用一次init()
private static SqlSession session = null;
public void init(){
//1、需要执行sql语句(SqlSession---->SqlSessionFactory----->SqlSessionFactoryBuilder)
//将mybatis.xml主配置文件变成字节输入流
try {
SqlSessionFactoryBuilder sfb = new SqlSessionFactoryBuilder();
InputStream ins = Resources.getResourceAsStream("mybatis.xml");
SqlSessionFactory ssf = sfb.build(ins);
session= ssf.openSession();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
实现类是如何使用查询的
//前面定义了一个公共的一个session
public void selectAll(){
//可以用对象来接收
List lists = session.selectList("com.mao.dao.impl.ManDaoImpl.selectAll");
for (Man man : lists) {
System.out.println(man);
}
}
public void selectAll2(){
//也可以用Map接收
List
增删改查 注意事项!!!需要注意
-
查询数据:在Mybatis.框架中,查询对应的sql语句需要书写在select标签中。
- 查询时必须指定返回的数据类型
- 如果是带条件的查询语句,则需通过select标签中的parameterType指定条件的类型
-
增删改:在Mybatis.框架中,添加对应的sql语句需要书写在insert、delete、update标签中
- 添加千万不要指定返回的数据类型(增、删、改这三个操作返回类型默认均为in类型,代表影响的行数)
- 添加和修改时的参数信息类型需要指定parameterType
- 在企业的实际开发中大多数情况是通过id(主键)来删除数据的
- 增删改数据时需要提交事务(删除、修改也需要提交事务,查询不需要) SqlSession.commit();
-
回滚就是SqlSession.rollback(); 使用完记得将其关闭,SqlSession.close();
其他标签:
别名标签(typeAliases):
typeAliases,标签是写实体类的别名,写了之后可以在写Sql配置文件时,例如标签中的属性就可以不用写实体类的具体路径直接用别名就可以了 typeAliases.的别名配置需要书写在主配置文件中的中的第一行(mybaits.xml), 否则会报错 sql: 在mybatis.中有一个标签叫做sql,但这个标签不是用来书写sql语句的,而是用来存放公共的字段。在局部配置文件中的mapper标签中定义,推荐写到第一行 nclude: 在mybatis,框架中include标签代表引用的含义,它和sql标签是一对组合标签。include标签可以将sql_标签中的公共代码引用到其它的标签之中。 where: 当where标签中有内容时,会自动生成where关键字,并且将内容前多余的and或or去掉 当where标签中没有内容时,此时where标签没有任何效果 trim : 若标签中有内容时: prefix |suffix:将trim标签中内容前面或后面添加指定内容 suffixoverrides |prefixoverrides :将trim标签中内容前面或后面去掉指定内容 若标签中没有内容时,trim标签也没有任何效果 choose、when、otherwise when和otherwise写在choose标签里面。相当if...else if...elsewhen至少要有一个,otherwise最多只能有一个 foreach: