一、Mybatis
1、半自动化ORM框架
(1)编写SQL语句 手写
(2)参数动态映射 自动
2、Mybatis配置
(1)依赖jar包
① mysql driver
<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.6</version>
</dependency>
② mybatis
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.38</version>
</dependency>
(2)核心配置
关闭工程后点击configuration–>settings–>live–>live Templates–>user配置下面两个方法(首次配置可能找不到user,可以在点击完settings后直接点击右方加号,此时会出现user,然后在user下进行如图所示配置)
上图代码:(mbcnf)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
</configuration>
上图代码:(mdmapper)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper>
</mapper>
3.项目配置
建包格式如下:仅供参考:
① mybities.xml配置如代码所示(包括以下四项properties,typeAliases,environment,mappers)
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="datasource.properties"/>
<typeAliases>
<package name="cn.kgc.kb08.entity"/>
</typeAliases>
<environments default="mysql">
<environment id="mysql">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${mysql.driver}"/>
<property name="url" value="${mysql.url}"/>
<property name="username" value="${mysql.username}"/>
<property name="password" value="${mysql.password}"/>
</dataSource>
</environment>
</environments>
<mappers>
<package name="cn.kgc.kb08.mapper"/>
</mappers>
</configuration>
②在mapper下的接口中写需要实现的方法
③在mapper下的vStuScoreMapper.xml,实现方法(以查询方法为例)
④在test中调用方法
方法讲解如下:
1)配置文件解析
InputStream config = Resources.getResourceAsStream(String path);
2)SQL会话工厂
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(config);
3)SQL会话 open(true:自动提交/false:不自动提交(启动事务))
SqlSession session = factory.openSession(true);
4)创建会话对象
VStuScoreMapper mapper = session.getMapper(VStuScoreMapper.class);
5)对象调用方法
List list = mapper.findAll();
其余方法可仿照查询格式书写!