zoukankan      html  css  js  c++  java
  • MyBatis入门学习(一)

    所需要jar包:mybatis-3.x.x.jar 、如果需要和spring整合,还需要加入相关的包

    1:看项目目录 红颜色不要关心

    2:按照步骤:

    1:加入jar包

    2:创建数据源(configuration.xml)创建数据库(此处省略)

    1. <?xml version="1.0" encoding="UTF-8" ?>     
    2. <!DOCTYPE configuration     
    3.     PUBLIC "-//mybatis.org//DTD Config 3.0//EN"     
    4.     "http://mybatis.org/dtd/mybatis-3-config.dtd">  
    5. <configuration>  
    6.     <typeAliases>  
    7.         <!--给实体类起一个别名 user -->  
    8.         <typeAlias type="com.forum.po.User" alias="User" />  
    9.     </typeAliases>  
    10.     <!--数据源配置  这块用 BD2数据库 -->  
    11.     <environments default="development">  
    12.         <environment id="development">  
    13.             <transactionManager type="jdbc" />  
    14.             <dataSource type="POOLED">  
    15.                 <property name="driver" value="com.ibm.db2.jcc.DB2Driver" />  
    16.                 <property name="url" value="jdbc:db2://localhost:50000/forum" />  
    17.                 <property name="username" value="DB2ADMIN" />  
    18.                 <property name="password" value="admin" />  
    19.             </dataSource>  
    20.         </environment>  
    21.     </environments>  
    22.     <mappers>  
    23.         <!--userMapper.xml装载进来  同等于把“dao”的实现装载进来 -->  
    24.         <mapper resource="myBatis/userMapper.xml" />  
    25.     </mappers>  
    26. </configuration>   
    3:创建实体类USER

    1. package com.forum.po;  
    2.   
    3. /** 
    4.  * 用户类 
    5.  *  
    6.  * @author db2admin 
    7.  *  
    8.  */  
    9. public class User extends Entity {  
    10.     private String name;  
    11.     private Integer age;  
    12.     public String getName() {  
    13.         return name;  
    14.     }  
    15.     public void setName(String name) {  
    16.         this.name = name;  
    17.     }  
    18.     public Integer getAge() {  
    19.         return age;  
    20.     }  
    21.     public void setAge(Integer age) {  
    22.         this.age = age;  
    23.     }  
    24.     public User() {  
    25.     }  
    26.   
    27. }  

    4:创建dao接口、可以说是Mapper接口:UserMapper

    1. package com.forum.dao;  
    2.   
    3. import com.forum.po.User;  
    4.   
    5. public interface UserMapper {  
    6.     public User findById(String Id);  
    7. }  

    5:创建dao的实现,不同于hibernarte的此处的实现为一个xml文件,也就是userMapper.xml

    1. <?xml version="1.0" encoding="UTF-8" ?>  
    2. <!DOCTYPE mapper PUBLIC   
    3.     "-//mybatis.org//DTD Mapper 3.0//EN"  
    4.     "http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
    5.     <!--这块等于dao接口的实现  namespace必须和接口的类路径一样-->  
    6. <mapper namespace="com.forum.dao.UserMapper">  
    7.     <!-- findById必须和接口中的方法名一样  返回一个User  就是刚才的别名  如果不弄别名要连类路径一起写 麻烦-->  
    8.     <select id="findById" parameterType="HashMap" resultType="User">  
    9.         select  
    10.         * from butone.student where id=#{id}  
    11.     </select>  
    12. </mapper>  

    6:测试类,MyBatisTest

    1. package com.forum.test;  
    2.   
    3. import java.io.IOException;  
    4.   
    5. import org.apache.ibatis.io.Resources;  
    6. import org.apache.ibatis.session.SqlSession;  
    7. import org.apache.ibatis.session.SqlSessionFactory;  
    8. import org.apache.ibatis.session.SqlSessionFactoryBuilder;  
    9.   
    10. import com.forum.dao.UserMapper;  
    11. import com.forum.po.User;  
    12.   
    13. /** 
    14.  * myBatis数据库连接测试 
    15.  *  
    16.  * @author db2admin 
    17.  *  
    18.  */  
    19. public class MyBatisTest {  
    20.     /** 
    21.      * 获得MyBatis SqlSessionFactory   
    22.      * SqlSessionFactory负责创建SqlSession,一旦创建成功,就可以用SqlSession实例来执行映射语句,commit,rollback,close等方法。 
    23.      * @return 
    24.      */  
    25.     private static SqlSessionFactory getSessionFactory() {  
    26.         SqlSessionFactory sessionFactory = null;  
    27.         String resource = "configuration.xml";  
    28.         try {  
    29.             sessionFactory = new SqlSessionFactoryBuilder().build(Resources  
    30.                     .getResourceAsReader(resource));  
    31.         } catch (IOException e) {  
    32.             // TODO Auto-generated catch block  
    33.             e.printStackTrace();  
    34.         }  
    35.         return sessionFactory;  
    36.     }  
    37.   
    38.     public static void main(String[] args) {  
    39.         SqlSession sqlSession = getSessionFactory().openSession();  
    40.         UserMapper userMapper = sqlSession.getMapper(UserMapper.class);  
    41.         User user = userMapper.findById("1");  
    42.         System.out.println(user.getName());  
    43.   
    44.     }  
    45.   
    46. }  
  • 相关阅读:
    DP--HDU 1003求数字串中的最大连续序列(含有DP过程详细分析)
    递归+DFS--简单迷宫问题--百练2802
    枚举--百练2812--恼人的青蛙(内含枚举基本思想总结)
    计蒜客:最大子阵
    hdu 4515 小Q系列故事——世界上最遥远的距离
    日期计算
    最大最小公倍数
    hdu 1568 Fibonacci
    矩阵快速幂
    矩阵乘法
  • 原文地址:https://www.cnblogs.com/daichangya/p/12958677.html
Copyright © 2011-2022 走看看