Mybatis的簡單樣本,Mybatis簡單樣本

來源:互聯網
上載者:User

Mybatis的簡單樣本,Mybatis簡單樣本

首先建立一個JavaWeb項目並匯入mybatis依賴的jar包,同時Mybatis是對資料庫的操作所以我們需要在資料庫中建立一個表user用來示範。

建立完表之後我們還需要建立相對應的實體類User.java並添加set和get方法:

 1 public class User { 2     private String username; 3     private String password; 4     private int age; 5     public String getUsername() { 6         return username; 7     } 8     public void setUsername(String username) { 9         this.username = username;10     }11     public String getPassword() {12         return password;13     }14     public void setPassword(String password) {15         this.password = password;16     }17     public int getAge() {18         return age;19     }20     public void setAge(int age) {21         this.age = age;22     }23 }

在Mybatis中我們需要建立一個與實體類相對應的對應檔userMapper.xml:

 1 <?xml version="1.0" encoding="UTF-8" ?> 2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> 3 <!-- 為這個mapper指定一個唯一的namespace,namespace的值習慣上設定成包名+sql對應檔名) 4  --> 5 <mapper namespace="com.mybatis.mapping.userMapper"> 6     <!-- 在select標籤中編寫查詢的SQL語句,id屬性值必須是唯一的 7     使用parameterType屬性指明查詢時使用的參數類型,resultType屬性指明查詢返回的結果集類型 8     --> 9     <!-- 10         根據username查詢得到一個user對象11      -->12     <select id="getUser" parameterType="java.lang.String" 13         resultType="com.mybatis.po.User">14         select * from user where username=#{username}15     </select>16     17        <delete id="deleteUser" parameterType="java.lang.String">18         delete from user where username=#{username}19     </delete>20 </mapper>

最後我們需要在src下建立一個Mybatis與資料庫連接的設定檔config.xml,並將上面的userMapper.xml匯入,代碼如下:

 1 <?xml version="1.0" encoding="UTF-8"?> 2 <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> 3 <configuration> 4     <environments default="development"> 5         <environment id="development"> 6             <transactionManager type="JDBC" /> 7             <!-- 設定資料庫串連資訊 --> 8             <dataSource type="POOLED"> 9                 <property name="driver" value="com.mysql.jdbc.Driver" />10                 <property name="url" value="jdbc:mysql://localhost:3306/test" />11                 <property name="username" value="root" />12                 <property name="password" value="" />13             </dataSource>14         </environment>15     </environments>16      <mappers>17         <!-- 註冊userMapper.xml檔案,resource為userMapper.xml所在目錄-->18          <mapper resource="com/mybatis/mapping/userMapper.xml"/>19      </mappers>20 </configuration>

這裡的設定資料庫串連資訊和Hibernate差別不是很大,現在我們建立一個Test類來測試一下:

 1 public class Test { 2  3     public static void main(String[] args) throws IOException { 4         //mybatis的設定檔 5         String resource = "config.xml"; 6         //使用類載入器載入mybatis的設定檔(它也載入關聯的對應檔) 7         InputStream is = Test.class.getClassLoader().getResourceAsStream(resource); 8         //構建sqlSession的工廠 9         SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);10         //開啟session11         SqlSession session = sessionFactory.openSession();12         /**13          * 映射sql的標識字串14          *com.mybatis.mapping.userMapper是userMapper.xml檔案中mapper標籤的namespace屬性的值,15          * getUser是select標籤的id屬性值,通過select標籤的id屬性值就可以找到要執行的SQL16          */17         String statement = "com.mybatis.mapping.userMapper.getUser";//映射sql的標識字串18         //執行查詢返回一個唯一user對象的sql19         User user = session.selectOne(statement,"username1");20         System.out.println(user.getUsername());21         String statement2="com.mybatis.mapping.userMapper.deleteUser";22         session.delete(statement2,user);23     }24 }

執行selectOne方法會返回一個user對象(如果想要查詢多條資料可以用selectList,此方法會返回List<User>的對象),我們在控制台輸出user對象的username.執行delete方法可以直接將對象對應的一條資料刪除,可以根據資料庫中的變化來判斷是否執行成功。下面是我的項目的目錄,大家可以參考一下:

以上就是Mybatis的一個簡單樣本,當然在userMapper.xml中我們還可以用OGNL產生動態sql語句,感興趣的可以自己研究一下。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.