自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

分步詳解 如何在iBatis中調(diào)用存儲過程

開發(fā) 后端
本文通過實例講解如何在iBatis中調(diào)用存儲過程,讓你在iBatis中調(diào)用存儲過程更輕松。

通過iBatis我們可以在數(shù)據(jù)庫表中執(zhí)行內(nèi)嵌的insert , delete, update SQL命令。本文中你將看到如何在iBatis中調(diào)用存儲過程.

我們使用MySQL數(shù)據(jù)庫,并且使用和上一個例子中一樣的Contact表.

我們在數(shù)據(jù)庫"vin"中創(chuàng)建了一個叫showData()的存儲過程,它將顯示Contract表中的所有的contact信息.為了創(chuàng)建存儲過程,我們打開MySQL并創(chuàng)建如下定義的過程 :

  1. DELIMITER $$  DROP  PROCEDURE  IF EXISTS `vin`.`showData`$$  CREATE  PROCEDURE  `vin`.`showData`()BEGINselect *  from  Contact; END$$ DELIMITER ; 

 

"Contact.java"和"SqlMapConfig.xml"與上一個例子中的是一樣的 :

 

  1. public class Contact {  private String firstName;  
  2.  private String lastName;     private String email;   
  3.  private int id;   public Contact() {}   
  4.  public Contact(    String firstName,    String lastName,    String email) {    this.firstName = firstName;  
  5.   this.lastName = lastName;    this.email = email;    }   
  6.  public String getEmail() {    return email;  } 
  7.  public void setEmail(String email) {    this.email = email;  }
  8.   public String getFirstName() {    return firstName;  } 
  9.  public void setFirstName(String firstName) {    this.firstName = firstName;  } 
  10.  public int getId() {    return id;  }  public void setId(int id) {    this.id = id;  }  
  11. public String getLastName() {    return lastName;  }  public void setLastName(String lastName) {    this.lastName = lastName;  } } 

 

SqlMapConfig.xml

  1. <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE sqlMapConfigPUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"
  2. "http://ibatis.apache.org/dtd/sql-map-config-2.dtd"> <sqlMapConfig>   <settings useStatementNamespaces="true"/>  
  3.    <transactionManager type="JDBC">       
  4.  <dataSource type="SIMPLE">       
  5.    <property name="JDBC.Driver" value="com.mysql.jdbc.Driver"/>      
  6.     <property name="JDBC.ConnectionURL"               value="jdbc:mysql://192.168.10.112:3306/vin"/>     
  7.      <property name="JDBC.Username" value="root"/>     
  8.      <property name="JDBC.Password" value="root"/>      
  9.   </dataSource>  
  10.     </transactionManager>    
  11.  <sqlMap resource="Contact.xml"/> </sqlMapConfig> 

 

我們只需修改"Contact.xml"并使用標(biāo)簽來在iBatis中調(diào)用存儲過程

  1. <procedure id="storedInfo" resultClass="Contact">    
  2.    { call showData() } </procedure> 

 

上面幾行代碼調(diào)用了存儲過程并集合了contract表.下面是Contact.xml的代碼 :

  1. <?xml version="1.0" encoding="UTF-8"?><!DOCTYPE sqlMapPUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"
  2. "http://ibatis.apache.org/dtd/sql-map-2.dtd">
  3.  <sqlMap namespace="Contact"> 
  4.  <!--- Calling stored procedure -->     
  5.   <procedure id="storedInfo" resultClass="Contact">      
  6.       { call showData()}    </procedure></sqlMap> 

 

現(xiàn)在我們可以這樣在iBatis中調(diào)用存儲過程 :

sqlMap.queryForList("Contact.storedInfo",null); "sqlMap"是SqlMapClient類的一個對象. IbatisStoredProcedure.java的代碼如下 :

  1. import com.ibatis.common.resources.Resources;
  2. import com.ibatis.sqlmap.client.SqlMapClient;
  3. import com.ibatis.sqlmap.client.SqlMapClientBuilder;
  4. import java.io.*;import java.sql.SQLException;
  5. import java.util.*; 
  6. public class IbatisStoredProcedure{  public static void main(String[] args)     
  7.   throws IOException,SQLException{        Reader reader =       Resources.getResourceAsReader("SqlMapConfig.xml");      
  8. SqlMapClient sqlMap =       SqlMapClientBuilder.buildSqlMapClient(reader);      System.out.println("All Contacts");    
  9.   List<Contact> contacts = (List<Contact>)   
  10.      sqlMap.queryForList("Contact.storedInfo",null);    
  11.     Contact contact = null;    
  12.   for (Contact c : contacts) {      System.out.print("  " + c.getId());    
  13.   System.out.print("  " + c.getFirstName()); 
  14.      System.out.print("  " + c.getLastName());     
  15.  System.out.print("  " + c.getEmail());   
  16.      contact = c;     
  17.   System.out.println("");      }      }}  

 

請依照如下步驟執(zhí)行在iBatis中調(diào)用存儲過程 :

  創(chuàng)建Contact.xml和SqlMapConfig.xml

  創(chuàng)建Contact.java并將其編譯

  創(chuàng)建IbatisStoredProcedure.java并將其編譯

  執(zhí)行IbatisStoredProcedure類文件,所有的Contract信息將在你的命令提示符下顯示 :

 

【編輯推薦】

  1. iBATIS教程之like語句的寫法淺析
  2. iBATIS應(yīng)用之SQLMap API編程淺析
  3. iBATIS入門程序六大步詳解
  4. iBATIS與Hibernate間的取舍
  5. iBATIS接口應(yīng)用的淺析
責(zé)任編輯:佚名 來源: Javaeye
相關(guān)推薦

2010-04-30 08:47:22

Oracle分頁存儲

2010-05-06 14:01:12

Oracle分頁存儲過

2011-07-19 17:33:53

存儲過程javaibatis

2009-07-21 13:50:00

iBATIS.NET調(diào)

2009-07-21 17:06:35

iBATIS.NET執(zhí)

2009-07-08 17:17:16

JDBC調(diào)用存儲過程

2012-03-08 10:18:33

JavaOracle

2011-08-11 14:35:47

SQL Server插入更新

2012-05-10 11:17:23

JavaSQL Server

2011-11-11 10:31:07

Ubuntu瀏覽器

2015-07-08 09:57:59

Git服務(wù)器分步詳解

2009-07-10 17:54:15

Java中調(diào)用JythJython

2020-11-26 10:33:44

MySQL存儲函數(shù)

2021-10-15 06:43:11

數(shù)據(jù)庫存儲過程

2016-08-24 21:24:27

MySQL存儲數(shù)據(jù)庫

2022-09-20 14:46:17

PostgreSQL存儲工具

2010-04-16 11:03:02

Oracle存儲過程

2009-03-03 11:51:54

微軟數(shù)據(jù)庫ACCESS

2010-06-04 13:50:24

MySQL存儲過程

2009-09-15 11:08:01

LinQ調(diào)用存儲過程
點贊
收藏

51CTO技術(shù)棧公眾號