1.引入
上一次课,我们和大家说了一下MyBatis的优点以及MyBatis需要下载的内容。下面我们就和大家一起进入MyBatis的学习。
2.HelloWord创建过程
(1).创建一个数据库表admin
DROP TABLE IF EXISTS `admin`;
CREATE TABLE `admin` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`username` varchar(255) NOT NULL,
`password` varchar(255) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
(2).添加数据并查询内容
(3).创建一个java工程在开发工具上(Eclipse/MyEclipse)
(4)编写数据库表admin所对应的实体对象
创建数据库表所对应的实体对象Admin.java
(5).添加需要的jar文件
(6).编写需要的连接数据库的相关信息以及实体对象映射的配置:mybatis-config.xml(这点类似于HIbernate)
<?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>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/test" />
<property name="username" value="root" />
<property name="password" value="123456" />
</dataSource>
</environment>
</environments>
<!-- 将我们写好的sql映射文件(Admin.xml)一定要注册到全局配置文件(mybatis-config.xml)中 -->
<mappers>
<mapper resource="AdminMapper.xml" />
</mappers>
</configuration>
(7)编写相关的测试类MyBatisTest.java,缺失内容部分填补
public SqlSessionFactory getSqlSessionFactory() throws IOException {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
return new SqlSessionFactoryBuilder().build(inputStream);
}
public void test() throws IOException {
// 2、获取sqlSession实例,能直接执行已经映射的sql语句
// sql的唯一标识:statement Unique identifier matching the statement to use.
// 执行sql要用的参数:parameter A parameter object to pass to the statement.
SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
SqlSession openSession = sqlSessionFactory.openSession();
try {
Admin Admin = openSession.selectOne(
"com.atguigu.mybatis.AdminMapper.selectEmp", 1);
System.out.println(Admin);
} finally {
openSession.close();
}
}
(8).编写SQL所需的xml文件:AdminMapper.xml
<?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 namespace="com.cn.entity.AdminMapper">
<!--
namespace:名称空间;指定为接口的全类名
id:唯一标识
resultType:返回值类型
#{id}:从传递过来的参数中取出id值
public Admin getAdmById(Integer id);
-->
<select id="getAdmById" resultType="com.cn.entity.Admin">
select id,username,password from test_admin where id = #{id}
</select>
</mapper>
注意:namespace + getAdmById这一个确定了唯一的执行SQL编号。那么我们java代码中需要调用这一个sql,那么我们就直接使用:openSession.selectOne("com.cn.entity.AdminMapper.getAdmById", 1);来调用即可。
(9).测试
(10).总结:
1、根据xml配置文件(全局配置文件)创建一个SqlSessionFactory对象 有数据源一些运行环境信息
2、sql映射文件;配置了每一个sql,以及sql的封装规则等。
3、将sql映射文件注册在全局配置文件中
4、写代码:
1)、根据全局配置文件得到SqlSessionFactory;
2)、使用sqlSession工厂,获取到sqlSession对象使用他来执行增删改查
一个sqlSession就是代表和数据库的一次会话,用完关闭
3)、使用sql的唯一标志来告诉MyBatis执行哪个sql。sql都是保存在sql映射文件中的。
3.HelloWord工程相关代码