iBATIS ParameterMap配置實例淺析


iBATIS ParameterMap是能夠優化訪問數據庫操作而存在的,那么本文就向你介紹iBATIS ParameterMap的基本情況。

AD: 2014WOT全球軟件技術峰會北京站 課程視頻發布

    iBATIS ParameterMap就是針對在用ADO.NET進行數據庫訪問操作中,最麻煩的就是准備DbCommand必須為它添加DbParameter,特別是當要傳的參數特別多的情況下,數據訪問層的很多代碼都是花在那里的問題所提出的一種解決方案,基於XML的配置,把字段名和對象的屬性對應起來,通過運行時的一些工作,自動為DbCommand提供它所需的參數集合。從而避免了我們直接寫很多重復代碼。

    在Employees_ParameterMap.xml配置文件中:

     
     
     
             
    1. ﹤select id="Employees_SelectWithParameterClass" parameterClass="Employee" resultClass="Employee" listClass="ArrayList"﹥ 
    2.  
    3.     SELECT EmployeeID,LastName,FirstName FROM Employees WHERE EmployeeID = #EmployeeID# OR LastName = #LastName# 
    4.  
    5. ﹤/select﹥

    使用的是內聯參數映射的方式,語句的在執行查詢時只需為它提供Employee類型的對象,它就會自動去讀自己需要的EmployeeID,LastName屬性的值,返回查詢結果。在執行時它所執行的語句如下:

     
     
     
             
    1. [SELECT EmployeeID,LastName,FirstName FROM Employees WHERE EmployeeID =  @param0  OR LastName =  @param1]

    所需的參數的提供方式如下:

     
     
     
             
    1. [@param0=[EmployeeID,12], @param1=[LastName,8bbb7bfb-c]]

    並且,在iBATIS中還會指出各個參數的類型:

     
     
     
             
    1. [@param0=[Int32, System.Int32], @param1=[String, System.String]]

    對於下面這個配置:

     
     
     
             
    1. ﹤select id="Employees_SelectWithParameterMap1" parameterMap="Employee_SelectParameterMap" resultClass="Employee" listClass="ArrayList"﹥ 
    2.  
    3.         SELECT EmployeeID,LastName,FirstName FROM Employees WHERE EmployeeID = #EmployeeID# OR LastName = #LastName# OR Country = #Country# 
    4.  
    5.     ﹤/select﹥

    它所使用的ParameterMap配置如下:

     
     
     
             
    1. ﹤parameterMap class="Employee" id="Employee_SelectParameterMap"﹥ 
    2.  
    3.     ﹤parameter column="EmployeeID" property="EmployeeID" dbType="int" type="int" direction="Input"/﹥ 
    4.  
    5.     ﹤parameter column="LastName" property="LastName" dbType="nvarchar" type="string" direction="Input"/﹥ 
    6.  
    7.     ﹤parameter column="Country" property="Country" dbType="nvarchar" type="string" direction="Input"/﹥ 
    8.  
    9. ﹤/parameterMap﹥

    在每一個Parameter映射元素可以指定每個屬性對應的列,它的類型和對應的數據庫的類型,還可以指定當它為空值時的默認值,具體可以參看官方文檔。但是可以看到,我們期待它能和內聯參數一樣的使用方法,如上配置的那樣。可是行不行呢?從程序的執行結果來看,是不可以的。由於之前在配置SQL語句的時候基本都是使用內聯參數沒有特別注意到這點。在使用Parameter Map的時候是不能用#property#的形式顯示地指定要使用的屬性參數,只能通過“?”,順序替代每一個parameter元素,如下:

     
     
     
             
    1. ﹤select id="Employees_SelectWithParameterMap2" parameterMap="Employee_SelectParameterMap" resultClass="Employee" listClass="ArrayList"﹥ 
    2.  
    3.             SELECT EmployeeID,LastName,FirstName FROM Employees WHERE EmployeeID = ? OR LastName = ? OR Country = ? 
    4.  
    5. ﹤/select﹥

    可以看到,由於沒有明顯地指出EmployeeID對應哪個屬性,那如果把上面的parameter元素調換一下,那么EmployeeID所對應的參數值就發生變化了。同時,也是這個原因,通過這種方式的參數映射,就無法重復利用每個參數了。如果仔細觀察會發現,既然都指定了column屬性了,那它為什么不會自動去配置呢?其實在這邊column屬性是不起作用的,它只會作用在執行存儲過程的時候。也就是說上面的Parameter元素中的column屬性不是必須的。下面是一個存儲過程的例子:

     
     
     
             
    1. ﹤procedure id="Employee_InsertWithProcedure" parameterMap="Employee_InsertParameterMap2" resultClass="int"﹥ 
    2.  
    3.     InsertEmployee 
    4.  
    5. ﹤/procedure﹥

    InsertEmployee接受兩個參數@LastName和@FirstName。我給它提供的映射參數如下:

     
     
     
             
    1. ﹤parameterMap class="Employee" id="Employee_InsertParameterMap2"﹥            
    2.  
    3.     ﹤parameter column="LastName" property="LastName" dbType="nvarchar" type="string" direction="Input"/﹥ 
    4.  
    5.     ﹤parameter column="FirstName" property="FirstName" dbType="nvarchar" type="string" direction="Input"/﹥ 
    6.  
    7. ﹤/parameterMap﹥

    上面這樣的配置的結果是(其中逗號后面的是值):

     
     
     
             
    1. [@LastName=[LastName,9a8bc059-3], @FirstName=[FirstName,46887db0-2]]

    但是當我把他們的位置調換了一下。它的結果如下:

     
     
     
             
    1. [@LastName=[ FirstName,9a8bc059-3], @FirstName=[LastName,46887db0-2]]

    也就是對儲存過程也是一樣的,參數映射關系仍然與parameter元素的順序息息相關的。Column屬性仍然沒有顯示出它的作用。所以使用ParameterMap還有是有一定的局限性的。但是對存儲過程來說,就必須使用這樣的方式,因為它只支持ParameterMap為它提供參數,而不支持內聯參數。

    最后總結列出幾點ParameterMap需要特別注意的幾個細節:

    1.在配置ParameterMap的時候,如果傳入的參數對像是元數據類型(int,string etc),那么在配置Parameter元素的時候,property的屬性名使用value。通過這種情況主要使用在為存儲指定參數的情況下。

    2.如果ParameterMap中配置的parameter元素不包含在傳入參數對象中(屬性或IDictionary對象的一個key,value項),將會產生異常,而不管在statement中有沒有用到。

    3.在使用parameterMap的extends屬性時,它將會繼承extends值對應的parameterMap配置,並且會繼承它的所有的參數映射,並且順序是從繼承的那配置為基准開始計算。這個在需要用到extends屬性的時候要特別注意。

    4.在為存儲過程傳參過程要特別注意,參數映射與存儲過程的參數之間的順序對應要正確。而且必須為提供與存儲過程足夠的參數(parameter配置足夠多),即使存儲過程的部分參數已經有默認值了。否則將拋出System.ArgumentOutOfRangeException異常。

    5.正常情況下,應該盡量使用內聯參數。

    iBATIS ParameterMap相關的情況就介紹到這里,希望通過這樣的介紹對你掌握iBATIS ParameterMap的設計有點啟發。

    【編輯推薦】

    1. iBATIS.NET執行存儲過程實例詳解
    2. iBATIS一對多映射解析
    3. iBATIS的多對多映射配置淺析
    4. iBATIS.NET API基礎淺析
    5. iBATIS映射文件基礎淺談


    免責聲明!

    本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



     
    粵ICP備18138465號   © 2018-2025 CODEPRJ.COM