一. Mybatis基础
mybatis 是一个优秀的基于java的, 并且实现了ORM映射的持久层框架,它内部封装了jdbc
mybatis通过xml或注解的方式实现对数据库的持久化操作
MyBatis官网地址:http://www.mybatis.org/mybatis-3/
①添加MyBatis的jar包
mysql-connector-java-5.1.37-bin.jar
mybatis-3.5.3.jar
og4j-1.2.17.jar
②编写实体类(对应数据库中的表)
//学生类
//该类要和数据库表进行一一对应
public class Student {
private Integer id;
private String name;
private Integer age;
//省略get个set方法
}
③编写核心配置文件SqlMapConfig.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!--MyBatis的DTD约束-->
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<!--configuration 核心根标签-->
<configuration>
<!--environments配置数据库环境,环境可以有多个。default属性指定使用的是哪个-->
<environments default="mysql">
<!--environment配置数据库环境 id属性唯一标识-->
<environment id="mysql">
<!-- transactionManager事务管理。 type属性,采用JDBC默认的事务-->
<transactionManager type="JDBC"></transactionManager>
<!-- dataSource数据源信息 type属性 连接池-->
<dataSource type="POOLED">
<!-- property获取数据库连接的配置信息 -->
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://192.168.59.143:3306/数据库表名" />
<property name="username" value="数据库账户" />
<property name="password" value="数据库密码" />
</dataSource>
</environment>
</environments>
<!-- mappers引入映射配置文件 -->
<mappers>
<!-- resource属性指定映射配置文件的位置 -->
<mapper resource="StudentMapper.xml"/>
</mappers>
</configuration>
④编写映射配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!--MyBatis的DTD约束 直接复制-->
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- mapper:核心根标签 namespace属性:名称空间 -->
<mapper namespace="StudentMapper">
<!--
select:查询功能的标签. insert:添加 update:修改 delete:删除
id属性:唯一标识
resultType属性:指定结果映射对象类型
parameterType属性:指定参数映射对象类型
-->
<select id="selectAll" resultType="com.itheima.bean.Student">
SELECT * FROM student
</select>
</mapper>
⑤编写测试类
@Test
public void selectAll() throws Exception{
//1.加载核心配置文件
InputStream is = Resources.getResourceAsStream("MyBatisConfig.xml");
//2.获取SqlSession工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
//3.通过SqlSession工厂对象获取SqlSession对象
SqlSession sqlSession = sqlSessionFactory.openSession();
//4.执行映射配置文件中的sql语句,并接收结果(参数是StudentMapper.xml中的selectAll)
List<Student> list = sqlSession.selectList("StudentMapper.selectAll");
//5.处理结果
for (Student stu : list) {
System.out.println(stu);
}
//6.释放资源
sqlSession.close();
is.close();
}
<?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="StudentMapper">
<insert id="insert" parameterType="student">
INSERT INTO student VALUES (#{
id},#{
name},#{
age})
</insert>
<update id="update" parameterType="student">
UPDATE student SET name = #{
name},age = #{
age} WHERE id = #{
id}
</update>
<delete id="delete" parameterType="int">
DELETE FROM student WHERE id = #{
id}
</delete>
<select id="selectAll" resultType="student">
SELECT * FROM student
</select>
<select id="selectById" resultType="student" parameterType="int">
SELECT * FROM student WHERE id = #{
id}
</select>
</mapper
//简单类型:基本数据类型+String 复杂类型:除了基本数据类型和String
1.参数是简单类型,则parameterType可以省略
2.参数如果只有一个,且是简单类型时,#{
id}可以随便写,都可以获取参数的值
3.如果参数是复杂类型,则#{
id}就相当于调用参数的getId方法,获取对应的参数值
4.返回值是简单类型,则resultType可以省略
5.返回值是集合类型,则resultType只写集合中元素的数据类型
① jdbc.properties
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://192.168.59.143:3306/db1
username=rooot
password=itheima
② 引入配置文件
<!--在MyBatis的核心配置文件中,引入数据库连接的配置文件-->
<properties resource="jdbc.properties"/>
③ 获取配置信息
<!-- 在MyBatis的核心配置文件中, 获取引入的properties文件中的配置信息 -->
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${username}" />
<property name="password" value="${password}" />
<!--起别名-->
<typeAliases>
<!-- 给Student类起别名为"student" -->
<typeAlias type="com.itheima.bean.Student" alias="student"/>
<!-- 给com.itheima.bean包下所有的类起别名,别名为类名的小写名字 -->
<!--<package name="com.itheima.bean"/>-->
</typeAliase>
</typeAliases>
当给实体类起别名后, 在MyBatis映射配置文件中的参数或返回值中, 可以直接使用别名, 并且别名不区分大小写
selectKey标签只能用在增删改语句中, 它可以在"增删改"语句执行前后, 增加对应操作.
<insert id="insert" parameterType="student">
<selectKey keyProperty="id" order="AFTER" >
SELECT LAST_INSERT_ID()
</selectKey>
INSERT INTO student VALUES (#{
id},#{
name},#{
age})
</insert>