分步详解 如何在iBatis中调用存储过程

开发 后端
本文通过实例讲解如何在iBatis中调用存储过程,让你在iBatis中调用存储过程更轻松。

通过iBatis我们可以在数据库表中执行内嵌的insert , delete, update SQL命令。本文中你将看到如何在iBatis中调用存储过程.

我们使用MySQL数据库,并且使用和上一个例子中一样的Contact表.

我们在数据库"vin"中创建了一个叫showData()的存储过程,它将显示Contract表中的所有的contact信息.为了创建存储过程,我们打开MySQL并创建如下定义的过程 :

  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"并使用标签来在iBatis中调用存储过程

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

 

上面几行代码调用了存储过程并集合了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> 

 

现在我们可以这样在iBatis中调用存储过程 :

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("");      }      }}  

 

请依照如下步骤执行在iBatis中调用存储过程 :

  创建Contact.xml和SqlMapConfig.xml

  创建Contact.java并将其编译

  创建IbatisStoredProcedure.java并将其编译

  执行IbatisStoredProcedure类文件,所有的Contract信息将在你的命令提示符下显示 :

 

【编辑推荐】

  1. iBATIS教程之like语句的写法浅析
  2. iBATIS应用之SQLMap API编程浅析
  3. iBATIS入门程序六大步详解
  4. iBATIS与Hibernate间的取舍
  5. iBATIS接口应用的浅析
责任编辑:佚名 来源: Javaeye
相关推荐

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调

2009-07-21 17:06:35

iBATIS.NET执

2009-07-08 17:17:16

JDBC调用存储过程

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浏览器

2009-07-10 17:54:15

Java中调用JythJython

2015-07-08 09:57:59

Git服务器分步详解

2016-08-24 21:24:27

MySQL存储数据库

2022-09-20 14:46:17

PostgreSQL存储工具

2009-03-03 11:51:54

微软数据库ACCESS

2010-06-04 13:50:24

MySQL存储过程

2010-04-16 11:03:02

Oracle存储过程

2020-11-26 10:33:44

MySQL存储函数

2021-10-15 06:43:11

数据库存储过程

2009-06-17 13:19:50

Java调用DLL
点赞
收藏

51CTO技术栈公众号