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 里面配置的 selectid 对应(<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();
    }
}

  

 

  

posted @ 2018-10-31 15:45  言西早石头侠  阅读(237)  评论(0编辑  收藏  举报