MyBatis接口注解
1,SqlSession
实例来直接执行在User.xml
文件中映射的 SQL 语句
2,但是还有比这更简单的方法,使用合理描述参数和SQL语句返回值的接口(比如:IUser.class
),这样现在就可以不使用类似User.xml
配置文件,至此更简单,代码更安全,不容易发生的字符串文字和转换的错误,下面是项目创建的详细过程:
1、创建一个接口:IUser,并在其中声明对应的操作方法
在 src
源码目录下创建一个包:com.yiibai.mybatis.dao
,并建立接口类 IUser
及一个方法, 在方法上面,我们使用了一个SQL注释,内容如下:
package com.tanlei.newer.dao;
import com.tanlei.newer.pojo.User;
import org.apache.ibatis.annotations.Select;
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 所需的数据连接文件,这里创建一个文件: src/config/Configure.xml
,其内容如下:
typeAliases标签 是写实体类的别名
<?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> <!--typeAliases标签 是写实体类的别名--> <typeAliases > <typeAlias alias="user" type="com.tanlei.newer.pojo.User"></typeAlias> </typeAliases> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"></transactionManager> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"></property> <property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8"></property> <property name="username" value="root"></property> <property name="password" value="password"></property> </dataSource> </environment> </environments> <mappers> <!-- 注释掉咯... <mapper resource="mybatis/user.xml"></mapper>--> </mappers> </configuration>
在包:com.tanlei.newer.pojo
下创建一个User.java
类文件
package com.tanlei.newer.pojo; import java.util.Date; /** * @author:Mr.Tan * @Create:2018-10-28-07-28 **/ public class User { private int id; private String username;// 用户姓名 private String sex;// 性别 private Date birthday;// 生日 private String address;// 地址 public User() { } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } public Date getBirthday() { return birthday; } public void setBirthday(Date birthday) { this.birthday = birthday; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } @Override public String toString() { return "User{" + "id=" + id + ", username='" + username + '\'' + ", sex='" + sex + '\'' + ", birthday=" + birthday + ", address='" + address + '\'' + '}'; } }
与 User.java
对应的 XML 配置文件:User.xml
可以少省略,不用创建,本节讲解的就是如何消灭类似于User.xml
的配置文件。
3、测试接口映射
我们在 src
这个目录下创建一个类:Main.java
,用来测试整个配置和程序运行结果,有关 Main.java
的代码详细内容如下:
package com.tanlei.newer.test; import com.tanlei.newer.dao.IUser; import com.tanlei.newer.pojo.User; 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.Reader; /** * @author:Mr.Tan * @Create:2018-10-31-15-24 **/ public class main { private static Reader reader; private static SqlSessionFactory sqlSessionFactory; static { try { reader=Resources.getResourceAsReader("config/Configure.xml"); sqlSessionFactory=new SqlSessionFactoryBuilder().build(reader); sqlSessionFactory.getConfiguration().addMapper(IUser.class); } catch (IOException e) { e.printStackTrace(); } } public static SqlSessionFactory getSession(){ return sqlSessionFactory; } public static void main(String[] args) { SqlSession sqlsession=sqlSessionFactory.openSession(); IUser iuser=sqlsession.getMapper(IUser.class); User user=iuser.getUserById(27); System.out.println(user.getSex()); System.out.println(user.getUsername()); System.out.println(user.getBirthday()); sqlsession.close(); } }