在上一章中,我们已经搭建了 myeclipse,mybatis,mysql 的开发环境,并且实现了 mybatis 的一个简单的查询。要注意的是,这种方式是用 SqlSession
实例来直接执行在User.xml
文件中映射的 SQL 语句:session.selectOne("com.yiibai.mybatis.models.UserMapper.getUserByID", 1)
,但是还有比这更简单的方法,使用合理描述参数和SQL语句返回值的接口(比如:IUser.class
),这样现在就可以不使用类似User.xml
配置文件,至此更简单,代码更安全,不容易发生的字符串文字和转换的错误,下面是项目创建的详细过程:
1、创建一个接口:IUser,并在其中声明对应的操作方法
在 src
源码目录下创建一个包:com.yiibai.mybatis.dao
,并建立接口类 IUser
及一个方法, 在方法上面,我们使用了一个SQL注释,内容如下:
package com.yiibai.mybatis.dao;
import org.apache.ibatis.annotations.Select;
import com.yiibai.mybatis.models.User;
/**
* @author yiibai.com
*/
public interface IUser {
@Select("select * from user where id= #{id}")
public User getUserByID(int id);
}
请注意,这里面代码有一个方法名 getUserByID
必须与 User.xml
里面配置的 select
的 id
对应(<select id="getUserByID">
)同名,虽使用注解映射不需要User.xml
。
2、创建对应映射接口 SQL 语句
首先配置 MyBatis 所需的数据连接文件,这里创建一个文件: conf.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/yiibai" /> <property name="username" value="root" /> <property name="password" value="" /> </dataSource> </environment> </environments> <mappers> <!-- 注册userMapper.xml文件, userMapper.xml位于me.gacl.mapping这个包下,所以resource写成me/gacl/mapping/userMapper.xml--> <!-- 注释 --> <!-- mapper resource="me/gacl/mapping/userMapper.xml"/--> </mappers> </configuration>
3、测试接口映射
package me.gacl.test; import java.io.Reader; 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 me.gacl.dao.IUser; import me.gacl.domain.User; public class Test2 { //sql工厂类 private static SqlSessionFactory sqlSessionFactory; //io读 private static Reader reader; static { try { //mybatis的配置文件 reader = Resources.getResourceAsReader("conf.xml"); sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); sqlSessionFactory.getConfiguration().addMapper(IUser.class); }catch(Exception e) { e.printStackTrace(); } } public static SqlSessionFactory getSession() { return sqlSessionFactory; } public static void main(String[] args) { //创建能执行sql的SqlSession SqlSession sqlSession = sqlSessionFactory.openSession(); try { IUser iuser = sqlSession.getMapper(IUser.class); User user = iuser.getUser(1); System.out.println("姓名:" + user.getName()); System.out.println("行业:" + user.getDept()); System.out.println("电话:" + user.getPhone()); }finally { sqlSession.close(); } } }