Mybatis学习
Mybatis定义:Mybatis是一款优秀的持久层框架,用于简化JDBC的开发;
持久层的定义:负责将数据保存到数据库的那一层代码;
JDBC的缺点:1.硬编码 (~注册驱动,获取连接 ~SQL语句 ) 2.操作繁琐(~手动设置参数 ~手动封装结果集)
这次使用的是mapper代理的方式完成(1.定义一个pojo,里面放实体类例如User,对应数据库表里的属性。2.配置pom.xml 还有核心配置文件 3.配置sqlu映射文件在resource下,4.写Mapper接口,其中sql映射文件与mapper接口的路径要一致,才能方便使用mapper代理,最后编写测试)

首先需要导入maven模块,在pom.xml文件下导入坐标(mybatis、junit、mysql连接等)
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.0</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.49</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.20</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.3.0-alpha14</version>
</dependency>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-core</artifactId>
<version>1.2.3</version>
</dependency>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>RELEASE</version>
<scope>compile</scope>
</dependency>
</dependencies>
第二步:在resource文件下添加mybatis的核心配置文件mybatis-config.xml
<?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/mybatis?useSSL=false&useUnicode=true&characterEncoding=UTF-8"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments>
第三步:配置sql映射文件:统一管理sql语句
<?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"> <!-- namespace:名称空间 --> <mapper namespace="com.matao.mapper.UserMapper"> <select id="selectAll" resultType="com.matao.pojo.User"> select * from tb_user; </select> <!--<select id="selectAll1" resultType="com.matao.pojo.Brand"> select * from tb_brand; </select>--> </mapper>
第四步,在mybatis-config.xml配置加载sql映射文件
<!--加载SQL映射文件-->
<mappers>
<!--<mapper resource="com/matao/mapper/UserMapper.xml"/>-->
<!--mapper代理-->
<!--如果Mapper接口名称和SQL映射文件名称相同,并在同一目录下,则可以使用包扫描的方式简化sql映射文件的加载-->
<package name="com.matao.mapper"/>
</mappers>
第五步:定义与sql映射文件名相同的Mapper接口,并且将mapper接口和sql映射文件放置在同一目录下。

在UserMapper接口里定义方法,方法名就是sql映射文件中sql语句的id,并保持参数类型和返回值类型一致
package com.matao.mapper; import com.matao.pojo.Brand; import com.matao.pojo.User; import java.util.List; public interface UserMapper { List<User> selectAll(); //List<Brand> selectAll1(); }
最后写测试
package com.matao.pojo; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.IOException; import java.io.InputStream; import java.util.List; public class MybatisDemo { public static void main(String[] args) throws IOException { //1.加载mybatis核心配置文件,获取SqlSessionFactory String resource = "org/mybatis/example/mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml"); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); //2.获取Sqlsession对象,用它来执行sql SqlSession sqlSession = sqlSessionFactory.openSession(); //3.执行sql List<User> users = sqlSession.selectList("test.selectAll"); System.out.println(users); sqlSession.close(); } }
其中还有许多小问题,小知识巩固

浙公网安备 33010602011771号