Mybatis(二)

来源:http://www.cnblogs.com/xuweiweiailixing/archive/2017/05/21/6885546.html
-Advertisement-
Play Games

1 Mybatis映射文件--增刪改查 POJO類 EmployeeMapper.xml IEmployeeDAO 配置文件--log4j.properties 配置文件--db.properties 配置文件--mybatis-config.xml 測試類 ...


1 Mybatis映射文件--增刪改查

  • POJO類
package cn.demo1;

import org.apache.ibatis.type.Alias;

/**
 * 描述:POJO
 */
@Alias("emp")
public class Employee {
    private Integer id;
    private String lastName;
    private String gender;
    private String email;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public String getGender() {
        return gender;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    @Override
    public String toString() {
        return "Employee{" +
                "id=" + id +
                ", lastName='" + lastName + '\'' +
                ", gender='" + gender + '\'' +
                ", email='" + email + '\'' +
                '}';
    }
}
  • EmployeeMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
        <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.demo1.IEmployeeDAO">
<!--
    namespace:命名空間  指定為介面的全類名
    id:唯一標識 和介面中的方法名相同
    resultType:返回值類型
-->
<select id="findById" parameterType="int" resultType="emp" databaseId="mysql">
    select id,last_name,email,gender from employee where id = #{id}
</select>

<insert id="addEmployee" parameterType="cn.demo1.Employee">
    insert into employee(last_name,email,gender) values (#{lastName},#{email},#{gender})
</insert>

<update id="updateEmployee" parameterType="cn.demo1.Employee">
    update employee set last_name = #{lastName} ,email = #{email},gender = #{gender} where id = #{id}
</update>

<delete id="deleteEmployeeById" parameterType="java.lang.Integer">
    delete from employee where id = #{id}
</delete>

</mapper>
  • IEmployeeDAO
package cn.demo1;



public interface IEmployeeDAO {
    public Employee findById(Integer id);

    public void addEmployee(Employee employee);

    public void updateEmployee(Employee employee);

    public void deleteEmployeeById(Integer id);
}
  • 配置文件--log4j.properties
### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.err
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### direct messages to file mylog.log ###
log4j.appender.file=org.apache.log4j.FileAppender
log4j.appender.file.File=c\:mylog.log
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n

### set log levels - for more verbose logging change 'info' to 'debug' ###

log4j.rootLogger=debug, stdout
  • 配置文件--db.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis
jdbc.user=root
jdbc.password=root
  • 配置文件--mybatis-config.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>

    <!--
        Mybatis可以使用properties屬性來引入外部properties配置文件內容
            resource:引入類路徑下的資源
            url:引入網路路徑或磁碟路徑下的資源
    -->
    <properties resource="db.properties"></properties>
    
    <settings>
        <!--
            是否開啟自動駝峰規則映射,即如果數據表中的欄位是last_name到Java中的lastName等類似的映射
         -->
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>

    <!--
        typeAliases:別名處理器,可以為Java類型起別名
    -->
    <typeAliases>
        <!--
            類很多情況下,可以批量設置別名這個包下的每一個類創建一個預設的別名,就是簡單類名小寫。
        -->
       <package name="cn.demo1"/>
    </typeAliases>

    <!--
        environments ,Mybatis可以配置多種環境
            environment,配置一個具體的環境信息,必須有兩個標簽,ID表示當前環境的唯一標識
                transactionManager s事務管理器
                    type 事務管理器的類型
                        JDBC   this.typeAliasRegistry.registerAlias("JDBC", JdbcTransactionFactory.class);
                        MANAGER  this.typeAliasRegistry.registerAlias("MANAGED", ManagedTransactionFactory.class);
                dataSource
                        JNDI    this.typeAliasRegistry.registerAlias("JNDI", JndiDataSourceFactory.class);
                        POOLED  this.typeAliasRegistry.registerAlias("POOLED", PooledDataSourceFactory.class);
                        UNPOOLED  this.typeAliasRegistry.registerAlias("UNPOOLED", UnpooledDataSourceFactory.class);
    -->
    <environments default="mysql_development">
        <environment id="mysql_development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.user}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
        <environment id="oracle_development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${oracle.driver}"/>
                <property name="url" value="${oracle.url}"/>
                <property name="username" value="${oracle.user}"/>
                <property name="password" value="${oracle.password}"/>
            </dataSource>
        </environment>
    </environments>

    <databaseIdProvider type="DB_VENDOR">
        <property name="MySQL" value="mysql"/>
        <property name="Oracle" value="oracle"/>
        <property name="SQL Server" value="sqlserver"/>
    </databaseIdProvider>

    <mappers>
        <mapper resource="cn/demo1/EmployeeMapper.xml"/>
    </mappers>
</configuration>
  • 測試類
package cn.test;

import cn.demo1.Employee;
import cn.demo1.IEmployeeDAO;
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 org.junit.Test;

import java.io.IOException;
import java.io.InputStream;

/**
 *
 * 描述:
 */

public class MybatisTest {
    /**
     * 測試查詢
     * @throws IOException
     */
    @Test
    public  void demo1() throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();

        IEmployeeDAO dao = session.getMapper(IEmployeeDAO.class);
        Employee employee = dao.findById(1);
        System.out.print(employee);

        session.close();
    }

    /**
     * 測試增加
     * @throws IOException
     */
    @Test
    public  void demo2() throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();

        IEmployeeDAO dao = session.getMapper(IEmployeeDAO.class);
        Employee employee = new Employee();
        employee.setLastName("呵呵");
        employee.setGender("女");
        employee.setEmail("[email protected]");
        dao.addEmployee(employee);

        session.commit();
        session.close();
    }

    /**
     * 測試修改
     * @throws IOException
     */
    @Test
    public  void demo3() throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();

        IEmployeeDAO dao = session.getMapper(IEmployeeDAO.class);
        Employee employee = new Employee();
        employee.setId(1);
        employee.setLastName("呵呵");
        employee.setGender("女");
        employee.setEmail("[email protected]");
        dao.updateEmployee(employee);

        session.commit();
        session.close();
    }

    /**
     * 測試修改
     * @throws IOException
     */
    @Test
    public  void demo4() throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();

        IEmployeeDAO dao = session.getMapper(IEmployeeDAO.class);
        dao.deleteEmployeeById(1);

        session.commit();
        session.close();
    }



}

 

2. 主鍵生成方式

2.1 若資料庫支持自動生成主鍵的欄位(比如MySQL和SQLServer),則可以設置unGeneratedKeys="true",然後再把keyProperty設置到目標屬性上。

<insert id="addEmployee" parameterType="cn.demo1.Employee" useGeneratedKeys="true" keyProperty="id">
    insert into employee(last_name,email,gender) values (#{lastName},#{email},#{gender})
</insert>

 

package cn.demo1;

import org.apache.ibatis.type.Alias;

/**
 * 描述:POJO
 */
@Alias("emp")
public class Employee {
    private Integer id;
    private String lastName;
    private String gender;
    private String email;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getLastName() {
        return lastName;
    }

    public void setLastName(String lastName) {
        this.lastName = lastName;
    }

    public String getGender() {
        return gender;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    @Override
    public String toString() {
        return "Employee{" +
                "id=" + id +
                ", lastName='" + lastName + '\'' +
                ", gender='" + gender + '\'' +
                ", email='" + email + '\'' +
                '}';
    }
}
package cn.demo1;



public interface IEmployeeDAO {
    public Employee findById(Integer id);

    public void addEmployee(Employee employee);

    public void updateEmployee(Employee employee);

    public void deleteEmployeeById(Integer id);
}
<?xml version="1.0" encoding="UTF-8" ?>
        <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.demo1.IEmployeeDAO">
<!--
    namespace:命名空間  指定為介面的全類名
    id:唯一標識 和介面中的方法名相同
    resultType:返回值類型
-->
<select id="findById" parameterType="int" resultType="emp" databaseId="mysql">
    select id,last_name,email,gender from employee where id = #{id}
</select>

<insert id="addEmployee" parameterType="cn.demo1.Employee"  useGeneratedKeys="true" keyProperty="id">
    insert into employee(last_name,email,gender) values (#{lastName},#{email},#{gender})
</insert>

<update id="updateEmployee" parameterType="cn.demo1.Employee">
    update employee set last_name = #{lastName} ,email = #{email},gender = #{gender} where id = #{id}
</update>

<delete id="deleteEmployeeById" parameterType="java.lang.Integer">
    delete from employee where id = #{id}
</delete>

</mapper>
<?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>

    <!--
        Mybatis可以使用properties屬性來引入外部properties配置文件內容
            resource:引入類路徑下的資源
            url:引入網路路徑或磁碟路徑下的資源
    -->
    <properties resource="db.properties"></properties>
    
    <settings>
        <!--
            是否開啟自動駝峰規則映射,即如果數據表中的欄位是last_name到Java中的lastName等類似的映射
         -->
        <setting name="mapUnderscoreToCamelCase" value="true"/>
    </settings>

    <!--
        typeAliases:別名處理器,可以為Java類型起別名
    -->
    <typeAliases>
        <!--
            類很多情況下,可以批量設置別名這個包下的每一個類創建一個預設的別名,就是簡單類名小寫。
        -->
       <package name="cn.demo1"/>
    </typeAliases>

    <!--
        environments ,Mybatis可以配置多種環境
            environment,配置一個具體的環境信息,必須有兩個標簽,ID表示當前環境的唯一標識
                transactionManager s事務管理器
                    type 事務管理器的類型
                        JDBC   this.typeAliasRegistry.registerAlias("JDBC", JdbcTransactionFactory.class);
                        MANAGER  this.typeAliasRegistry.registerAlias("MANAGED", ManagedTransactionFactory.class);
                dataSource
                        JNDI    this.typeAliasRegistry.registerAlias("JNDI", JndiDataSourceFactory.class);
                        POOLED  this.typeAliasRegistry.registerAlias("POOLED", PooledDataSourceFactory.class);
                        UNPOOLED  this.typeAliasRegistry.registerAlias("UNPOOLED", UnpooledDataSourceFactory.class);
    -->
    <environments default="mysql_development">
        <environment id="mysql_development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${jdbc.driver}"/>
                <property name="url" value="${jdbc.url}"/>
                <property name="username" value="${jdbc.user}"/>
                <property name="password" value="${jdbc.password}"/>
            </dataSource>
        </environment>
        <environment id="oracle_development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${oracle.driver}"/>
                <property name="url" value="${oracle.url}"/>
                <property name="username" value="${oracle.user}"/>
                <property name="password" value="${oracle.password}"/>
            </dataSource>
        </environment>
    </environments>

    <databaseIdProvider type="DB_VENDOR">
        <property name="MySQL" value="mysql"/>
        <property name="Oracle" value="oracle"/>
        <property name="SQL Server" value="sqlserver"/>
    </databaseIdProvider>

    <mappers>
        <mapper resource="cn/demo1/EmployeeMapper.xml"/>
    </mappers>
</configuration>
 /**
     * 測試增加
     * @throws IOException
     */
    @Test
    public  void demo2() throws IOException {
        String resource = "mybatis-config.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session = sqlSessionFactory.openSession();

        IEmployeeDAO dao = session.getMapper(IEmployeeDAO.class);
        Employee employee = new Employee();
        employee.setLastName("呵呵");
        employee.setGender("女");
        employee.setEmail("[email protected]");
        dao.addEmployee(employee);

        System.out.print(employee.getId());
        session.commit();
        session.close();
    }

 

2.2 對於不支持自增主鍵的資料庫,則可以使用selectKey子元素;selectKey元素將會首先運行,id會被設置,後插入語句會被調用

<insert id="addEmployee" parameterType="cn.demo1.Employee"   databaseId="oracle">
    <selectKey order="BEFORE" keyProperty="id" resultType="java.lang.Integer">
        select employee_seq.nextval from dual;
    </selectKey>
    insert into employee(id,last_name,email,gender) values (#{id},#{lastName},#{email},#{gender})
</insert>

 

3 參數傳遞

  • 單個參數
    • 可以接受基本類型,對象類型,集合類型的值。這種情況可直接使用這個參數,不需要經過任何處理。
  • 多個參數
    • 任意多個參數,都會被Mybatis重新包裝成一個Map傳入。Map的key是param1,param2,0,1...值就是參數的值。
  • 命名參數
    • 為參數使用@param起一個名字,Mybatis就會將這些參數封裝到map中,key就是我們自己指定的名字。  
  • POJO
    • 當這些參數屬於業務的POJO的時候,我們直接傳遞POJO。#{屬性值}中的屬性值為POJO的屬性值。
  • Map:
    • 我們也可以封裝多個參數為map,直接傳遞。  
  • 註意:
    • 如果是Collection類型的話,那麼key是collection。
    • 如果是List類型的話,那麼key是list。
    • 如果是數組的話,那麼key是array。

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Newtonsoft.Json.Net20.dll 下載請訪問http://files.cnblogs.com/hualei/Newtonsoft.Json.Net20.rar 在.net 2.0中提取這樣的json {"name":"lily","age":23,"addr":{"city":gu ...
  • 什麼是AOP?引用百度百科:AOP為Aspect Oriented Programming的縮寫,意為:面向切麵編程,通過預編譯方式和運行期動態代理實現程式功能的統一維護的一種技術。實現AOP主要由兩種方式,一種是編譯時靜態植入,優點是效率高,缺點是缺乏靈活性,.net下postsharp為代表者( ...
  • public class BulletMove : MonoBehaviour { public float Speed = 5f; public Transform Fx; // Use this for initialization void Start () { //5秒後,刪除自己 Dest ...
  • NancyFx框架中使用綁定模型 新建一個空的Web程式 然後安裝Nuget庫裡面的包 Nancy Nancy.Hosting.Aspnet Nancy.ViewEnglines.Spark 併在Web應用程式裡面添加Models,Module,Views三個文件夾 繼續往Models文件夾裡面添加 ...
  • public class PlaneMove : MonoBehaviour { //h:水平方向的控制,v:前後方向的控制 float h,v; //Speed:飛機的飛行速度 public float Speed; // Use this for initialization void Star ...
  • "Stylet" 是我最近發現的一個WPF MVVM框架, 在博客園上搜了一下, 相關的文章基本沒有, 所以寫了這個入門的文章推薦給大家. Stylet是受 "Caliburn Micro" 項目的啟發, 所以借鑒了其中的很多概念, 同時精簡了一些部分, 如只支持MVVM, WPF和.NET 4.5 ...
  • 一、Servlet 1、瞭解Servlet Servlet(Server Applet),全稱Java Servlet,未有中文譯文。是用Java編寫的伺服器端程式。其主要功能在於互動式地瀏覽和修改數據,生成動態Web內容。狹義的Servlet是指Java語言實現的一個介面,廣義的Servlet是指 ...
  • 結果: ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...