课前准备工作:
编程软件:eclipse 2021版本或者相邻版本
数据库:mysql 5.x.x 5左右的版本即可,太高版本mybatis语句会有所不一样。
jar包下载地址:Maven Repository: Search/Browse/Explore
什么是框架?
一:Mybatis
1、mybatis简介
1.1、 mybatis历史
MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁移到了Google Code。随着开发团队转投Google Code旗下, iBatis3.x正式更名为MyBatis。代码于2013年11月迁移到Github。
iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。 iBatis提供的持久层框架包括SQL Maps和Data Access Objects(DAO)。
1.2、MyBatis特性
1) MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架
2) MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
3) MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java
Objects,普通的Java对象)映射成数据库中的记录
4) MyBatis 是一个 半自动的ORM(Object Relation Mapping)框架
1.3、MyBatis下载
MyBatis下载地址:https://github.com/mybatis/mybatis-3
1.4、 与Java web中的DAO层的对比
1) 需要手动传参数以及使用ResultSet手动获取结果集。
public int addToCart(Cart cart) {
// TODO Auto-generated method stub
//设置参数
String sql = "insert into cart values(?,?,?,?,?,?,?,?)";
//手动传参
Object[] params =new Object[] {cart.getId(),cart.getGood_id(),cart.getUser_name(),cart.getIntro(),cart.getAmount(),cart.getPrice(),cart.getTotal_price(),cart.getCover()};
int result = exceuteUpdate(sql, params);
return result;
}
@Override
public List
Goods goosGoods =null;
//数据库语句
String sql = "select g.*,t.name as typename from goods g LEFT JOIN type t on g.type_id = t.id where 1=1";
//条件拼接 格式太复杂
if (goods.getName()!=null&&!"".equals(goods.getName().trim())) {
sql += " and g.name like'%"+goods.getName()+"%'";
}
if (goods.getId()!=0) {
sql += " and g.id='"+goods.getId()+"'";
}
if (goods.getType_id()!=0) {
sql += " and g.type_id='"+goods.getType_id()+"'";
}
ResultSet rs = querySql(sql);
List
if(rs!=null) {
try {
while (rs.next()) {
//依次手动获取结果集
goosGoods = new Goods(rs.getInt("id"),rs.getString("typename"),rs.getString("name"), rs.getString("cover"), rs.getString("image1"), rs.getString("image2"), rs.getFloat("price"), rs.getString("intro"), rs.getInt("stock"), rs.getInt ("type_id"));
list.add(goosGoods);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
return list;
}
2、搭建mybatis
2.1 开发环境
1、 mysql 5
2、 Mybatis 3.5.2
注意:
MySQL不同版本的注意事项
1、驱动类driver-class-name
MySQL 5版本使用jdbc5驱动,驱动类使用:com.mysql.jdbc.Driver
MySQL 8版本使用jdbc8驱动,驱动类使用:com.mysql.cj.jdbc.Driver
2、连接地址url
MySQL 5版本的url:
jdbc:mysql://localhost:3306/ssm
MySQL 8版本的url:
jdbc:mysql://localhost:3306/ssm?serverTimezone=UTC
否则运行测试用例报告如下错误:
java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or
represents more
2.2 创建web项目导入jar包
mysql-connector-java-5.1.13.jar
mybatis-3.5.2.jar
2.3、创建MyBatis的核心配置文件
习惯上命名为mybatis-config.xml,这个文件名仅仅只是建议,并非强制要求。将来整合Spring
之后,这个配置文件可以省略,所以大家操作时可以直接复制、粘贴。
核心配置文件主要用于配置连接数据库的环境以及MyBatis的全局配置信息
核心配置文件存放的位置是Java resources/src目录下
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-config.dtd">
2.4、创建mapper接口
MyBatis中的mapper接口相当于以前的dao。但是区别在于,mapper仅仅是接口,我们不需要
提供实现类。
public interface UserMapper {
/**
* 添加用户信息
*/
int insertUser();
}
2.5、创建MyBatis的映射文件
1、映射文件的命名规则:
表所对应的实体类的类名+Mapper.xml
例如:表t_user,映射的实体类为User,所对应的映射文件为UserMapper.xml
因此一个映射文件对应一个实体类,对应一张表的操作
MyBatis映射文件用于编写SQL,访问以及操作表中的数据
MyBatis映射文件存放的位置与mapper接口同一个包里
2、 MyBatis中可以面向接口操作数据,要保证两个一致:
a>mapper接口的全类名和映射文件的命名空间(namespace)保持一致
b>mapper接口中方法的方法名和映射文件中编写SQL的标签的id属性保持一致
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
insert into t_user values(null,'admin','123456',23,'男','12345@qq.com')
2.6、测试
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
//读取MyBatis的核心配置文件
InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
//创建SqlSessionFactoryBuilder对象
SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
//通过核心配置文件所对应的字节输入流创建工厂类SqlSessionFactory,生产SqlSession对象
SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
//创建SqlSession对象,此时通过SqlSession对象所操作的sql都必须手动提交或回滚事务
//SqlSession sqlSession = sqlSessionFactory.openSession();
//创建SqlSession对象,此时通过SqlSession对象所操作的sql都会自动提交
SqlSession sqlSession = sqlSessionFactory.openSession(true);
//通过代理模式创建UserMapper接口的代理实现类对象
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
//调用UserMapper接口中的方法,就可以根据UserMapper的全类名匹配元素文件,通过调用的方法名匹配
//映射文件中的SQL标签,并执行标签中的SQL语句
int result = userMapper.insertUser();
//sqlSession.commit();
System.out.println("结果:"+result);
}
2.7、加入log4j日志功能
加入jar包: log4j-1.2.17.jar log4j-api-2.11.2.jar log4j-core-2.11.2.jar slf4j-api-1.7.26.jar slf4j-log4j12-1.7.26.jar
加入log4j的配置文件:log4j.properties
log4j.rootLogger=DEBUG, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n
3、优化核心配置文件
3.1优化核心配置文件mybatis-config.xml
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-config.dtd">
jdbc.properties文件,与mybatis-config.xml同一目录下
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/buyerapp?characterEncoding=utf-8
jdbc.username=root
jdbc.password=123456
jdbc.initialPoolSize=5
jdbc.minPoolSize=1
jdbc.maxPoolSize=10
3.2、优化读取配置文件
分装工厂类 SqlSessionUtil
public static SqlSession getSession() {
SqlSession sqlSession = null;
try {
InputStream is= Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactoryBuilder sessionFactoryBuilder = new SqlSessionFactoryBuilder();
SqlSessionFactory sqlSessionFactory = sessionFactoryBuilder.build(is);
sqlSession=sqlSessionFactory.openSession(true);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return sqlSession;
}
读取
//调用SqlSessionUtil类静态方法
SqlSession session = SqlSessionUtil.getSession();
//通过session获取接口实例话对象
UserMapper userMapper = session.getMapper(UserMapper.class);
int result = userMapper.insertUser();
4、MyBatis的增删改查
4.1 新增
insert into t_user values(null,'liming','123456','男',25)
4.2 删除
delete from t_user where id=1
4.3修改
update t_user set userName='czh',userPassword='654321' where id=2
4.4查询
查询一条数据
select * from t_user where id=2
查询多条数据
select * from t_user
注意:
1、查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射
关系。
resultType:自动映射,用于属性名和表中字段名一致的情况
resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况
parameterType和 parameterMap与上面情况一致。用于表示参数类型。方法有参数时需要加上。
5、MyBatis获取参数值的两种方式
MyBatis获取参数值的两种方式:${}和#{}
${}的本质就是字符串拼接,#{}的本质就是占位符赋值
${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引
号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,
可以自动添加单引号
5.1 多种查询情况
通过一个参数查询一个实体类对象 Admin getAdminByyym(String username);
select * from admin where yhm = '${usename}'
只有一个参数的时候{}里的参数名字随便写,他都能一一对应。
通过两个及以上的参数查询一个实体类对象
使用param1、param2.....进行赋值
//多个参数变量获取值时
Admin checklogin(String yhm,String mm);
select * from admin where yhm = #{param1} and mm = #{param2}
使用 #{param1}指定对应的参数为第一个
使用 @Param给参数命名 Admin checkLoginByParam(@Param("yhm")
相关链接
发表评论