zoukankan      html  css  js  c++  java
  • Mybatis接口注解

    在上一章中,我们已经搭建了 myeclipse,mybatis,mysql 的开发环境,并且实现了 mybatis 的一个简单的查询。要注意的是,这种方式是用 SqlSession 实例来直接执行在userMapping.xml文件中映射的 SQL 语句:
    session.selectOne("me.gacl.mapping.UserMapper.getUser", 1),但是还有比这更简单的方法,使用合理描述参数和SQL语句返回值的接口(比如:IUser.class),这样现在就可以不使用类似userMapper.xml配置文件,至此更简单,代码更安全,不容易发生的字符串文字和转换的错误,下面是项目创建的详细过程:

    1、创建一个接口:IUser,并在其中声明对应的操作方法

    在 src 源码目录下创建一个包:me.gacl.dao,并建立接口类 IUser 及一个方法, 在方法上面,我们使用了一个SQL注释,内容如下:

    package me.gacl.dao;
     
    
    import org.apache.ibatis.annotations.Select;
    import me.gacl.domain.User;
    
    
    public interface IUser {
    
    	@Select("select * from user where id=#{id}")
    	public User getUser(int id);	
    	
    }
    

      

    请注意,这里面代码有一个方法名 getUser 必须与 userMapper.xml 里面配置的 select 的 id 对应(<select id="getUser">)同名,虽使用注解映射不需要userMapper.xml

    2、创建对应映射接口 SQL 语句

     
    linuxprobe官方网站

    在上一章中,我们已经搭建了 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);
    }
    
    Java

    请注意,这里面代码有一个方法名 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();
    		}
    	}
    	
    	
    }
    

      

  • 相关阅读:
    html部分
    elementUi 新建和编辑dialog-input无法输入的小坑
    js array methods
    css-渐变背景,爱了爱了。
    css-iview官网布局
    10、TypeScript中的装饰器
    常见的预制注解
    javadoc工具
    元注解
    注解的概念
  • 原文地址:https://www.cnblogs.com/achengmu/p/9162237.html
Copyright © 2011-2022 走看看