MyBatis入門學習(一)

轉載自http://blog.csdn.net/huzheaccp/article/details/7399124

所需要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. }  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章