课前准备工作:

编程软件: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 findGoodList(Goods goods){

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 list = new ArrayList<>();

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查询

查询一条数据

查询多条数据

注意:

1、查询的标签select必须设置属性resultType或resultMap,用于设置实体类和数据库表的映射

关系。

resultType:自动映射,用于属性名和表中字段名一致的情况

resultMap:自定义映射,用于一对多或多对一或字段名和属性名不一致的情况

parameterType和 parameterMap与上面情况一致。用于表示参数类型。方法有参数时需要加上。

5、MyBatis获取参数值的两种方式

MyBatis获取参数值的两种方式:${}和#{}

${}的本质就是字符串拼接,#{}的本质就是占位符赋值

${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引

号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,

可以自动添加单引号

5.1 多种查询情况

通过一个参数查询一个实体类对象 Admin getAdminByyym(String username);

     

     

只有一个参数的时候{}里的参数名字随便写,他都能一一对应。

通过两个及以上的参数查询一个实体类对象

使用param1、param2.....进行赋值

//多个参数变量获取值时

Admin checklogin(String yhm,String mm);

使用 #{param1}指定对应的参数为第一个

使用 @Param给参数命名 Admin checkLoginByParam(@Param("yhm")

相关链接

评论可见,请评论后查看内容,谢谢!!!评论后请刷新页面。