一個使用ibatis對數據庫增刪改查的例子:
這裏用的開發環境是:Eclipse3.2+mysql5.0.20,ibatis包是ibatis-common-2.jar,
ibatis-dao-2.jar,ibatis-sqlmap-2.jar,mysql包是mysql-connector-java-5.0.3-bin.jar.
步驟:
1.建立數據庫:
create database itcast;
use itcast;
建立表:
create table student
(
id int primary key auto_increment,
firstname varchar(20) not null,
lastname varchar(20) not null
)
2.建立POJO類,Student.java,此程序中用到的全部類都放在cn.itcast包下面,
其餘的配置文件都放在txd.configfile包下面。
package cn.itcast;
public class Student {
private Integer id;
private String firstname;
private String lastname;
public String getFirstname() {
return firstname;
}
public void setFirstname(String firstname) {
this.firstname = firstname;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getLastname() {
return lastname;
}
public void setLastname(String lastname) {
this.lastname = lastname;
}
}
3.跟Student類對應的xml配置文件Student.xml,
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN" "
[url]http://www.ibatis.com/dtd/sql-map-2.dtd[/url]">
<sqlMap namespace="student">
<!--insert元素,id屬性值做爲標識此元素,parameterClass屬性是參數的類型,此
屬性的值是Java類的全限定名(即包括類的包名)。它是可選的,但強烈建議使用。
它的目的是 限制輸入參數的類型爲指定的Java類,並優化框架的性能。##符號中
間的名字來自此類的屬性.-->
<insert id="insert_student" parameterClass="cn.itcast.Student">
insert into student(firstname,lastname) values
(#firstname#,#lastname#)
</insert>
<select id="getStudent" resultClass="cn.itcast.Student">
select id, firstname, lastname from student
</select>
<delete id="delStudent" parameterClass="int">
delete from student where id=#value#
</delete>
<update id="updateStudent" parameterClass="cn.itcast.Student">
update student set firstname=#firstname#,lastname=#lastname#
where id=#id#
</update>
</sqlMap>
4.jdbc.properties文件,存儲數據庫鏈接的driver,url,username,password等信息,
driver=com.mysql.jdbc.Driver
url=jdbc:mysql:///itcast
username=root
password=
5. SqlMap的配置文件SqlMapConfigExample.xml,
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
"
[url]http://www.ibatis.com/dtd/sql-map-config-2.dtd[/url]">
<sqlMapConfig>
<!--<properties>元素,用於在配置文件中使用標準的Java屬性文件(name=value)-->
<properties resource="txd/configfile/jdbc.properties" />
<!--
cacheModelsEnabled:全局性地啓用或禁用SqlMapClient的全部緩存model。
enhancementEnabled:全局性地啓用或禁用運行時字節碼加強,以優化訪問
Java Bean屬性的性能,同時優化延遲加載的性能。
lazyLoadingEnabled:全局性地啓用或禁用SqlMapClient的全部延遲加載。
maxRequests:同時執行SQL語句的最大線程數。
maxSessions:同一時間內活動的最大session數。
maxTransactions:同時進入SqlMapClient.startTransaction()的最大線程數。
useStatementNamespaces:若是啓用本屬性,必須使用全限定名來引用mapped statement。
Mapped statement的全限定名由sql-map的名稱和mapped-statement的名稱合成。
-->
<settings cacheModelsEnabled="true" enhancementEnabled="true"
lazyLoadingEnabled="true" maxRequests="32" maxSessions="10"
maxTransactions="5" useStatementNamespaces="false" />
<!--
<transationManager>元素讓您爲SQL Map配置事務管理服務。屬性type指定所
使用的事務管理器類型。這個屬性值能夠是一個類名,也能夠是一個別名。
包含在框架的三個事務管理器分別是:JDBC,JTA和EXTERNAL。
-->
<transactionManager type="JDBC">
<!--dataSource元素爲SQL Map數據源設置了一系列參數。-->
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="${driver}" />
<property name="JDBC.ConnectionURL" value="${url}" />
<property name="JDBC.Username" value="${username}" />
<property name="JDBC.Password" value="${password}" />
</dataSource>
</transactionManager>
<!--<sqlMap>元素用於包括SQL Map映射文件和其餘的SQL Map配置文件。-->
<sqlMap resource="txd/configfile/Student.xml" />
</sqlMapConfig>
6.MySqlMapClient.java類,用於產生一個SqlMapClient
package cn.itcast;
import java.io.IOException;
import java.io.Reader;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
public class MySqlMapClient {
private static SqlMapClient sqlMapClient;
static {
String resource = "txd/configfile/SqlMapConfigExample.xml";
Reader reader = null;
try {
reader = Resources.getResourceAsReader(resource);
sqlMapClient = SqlMapClientBuilder.buildSqlMapClient(reader);
} catch (IOException e) {
e.printStackTrace();
}
}
public static SqlMapClient getSqlMapInstance() {
return sqlMapClient;
}
}
7.StudentManager 類測試一下上面的代碼, package cn.itcast; import java.sql.SQLException; import java.util.List; import com.ibatis.sqlmap.client.SqlMapClient; public class StudentManager { public static void main(String[] args) { SqlMapClient sqlMap = MySqlMapClient.getSqlMapInstance(); // insert一條記錄 // Student student = new Student(); // student.setFirstname("zhang"); // student.setLastname("san"); // try { // sqlMap.insert("insert_student", student); // System.out.println("插入成功!"); // } catch (SQLException e) { // e.printStackTrace(); // } // delete一條記錄 // try { // int result = sqlMap.delete("delStudent", 5); // System.out.println(result); // } catch (SQLException e) { // e.printStackTrace(); // } // update一條已存在的記錄 Student student = new Student(); student.setId(1); student.setFirstname("jiang"); student.setLastname("zemin"); try { int result = sqlMap.update("updateStudent", student); System.out.println(result); } catch (SQLException e) { e.printStackTrace(); } // query得到多條記錄 // try { // List<Student> list = sqlMap.queryForList("getStudent", null); // for (Student student : list) { // System.out // .println(student.getId() + "\t" // + student.getFirstname() + "\t" // + student.getLastname()); // } // } catch (SQLException e) { // e.printStackTrace(); // } // query單條記錄 // try { // Student student = (Student) sqlMap.queryForObject("getStudent", 1); // System.out.println(student.getId()); // System.out.println(student.getFirstname()); // System.out.println(student.getLastname()); // } catch (SQLException e) { // e.printStackTrace(); // } } }