ibatis的简单应用

 

ExampleMain.java

package com.si_tech;
    
import java.sql.SQLException;   
import java.util.List;   
  
import com.ibatis.sqlmap.client.SqlMapClientBuilder;   
   
public class ExampleMain {   
  
    public static void update() {   
        //首先初始化iBatis获得一个SqlMapClient对象   
        String resource = "com/si_tech/SqlMapConfig.xml";   
        com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;   
        try {   
            java.io.Reader reader = com.ibatis.common.resources.Resources   
                    .getResourceAsReader(resource);   
            sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }   
        // sqlMap系统初始化完毕,开始执行update操作   
        try {   
            sqlMap.startTransaction();   
            User user = new User();   
            user.setId(new Integer(1));   
            user.setName("zhupan");   
            user.setSex(new Integer(1));   
            sqlMap.update("updateUser", user);   
            sqlMap.commitTransaction();   
        } catch (SQLException e) {   
            System.out.println(e.getMessage());   
        } finally {   
            try {   
                sqlMap.endTransaction();   
            } catch (SQLException e) {   
                e.printStackTrace();   
            }   
        }   
    }   
    public static List getUser() {   
//      首先初始化iBatis获得一个SqlMapClient对象   
        String resource = "com/si_tech/SqlMapConfig.xml";   
        com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;   
        List user=null;   
        try {   
            java.io.Reader reader = com.ibatis.common.resources.Resources   
                    .getResourceAsReader(resource);   
            sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }   
        // sqlMap系统初始化完毕,开始执行getAllUser操作   
        try {   
            sqlMap.startTransaction();                 
            user=sqlMap.queryForList("getAllUser", "zhupan");   
            sqlMap.commitTransaction();   
        } catch (SQLException e) {   
            System.out.println(e.getMessage());   
        } finally {   
            try {   
                sqlMap.endTransaction();   
            } catch (SQLException e) {   
                e.printStackTrace();   
            }   
        }   
        return user;  
    }  
    public static List getUsers(){
     String resource = "com/si_tech/SqlMapConfig.xml";   
        com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;   
        List list=null;
        try {   
            java.io.Reader reader = com.ibatis.common.resources.Resources   
                    .getResourceAsReader(resource);   
            sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);   
        } catch (Exception e) {   
            e.printStackTrace();   
        }   
        try {   
            sqlMap.startTransaction();                 
            list=sqlMap.queryForList("getAllUsers", null);   
            sqlMap.commitTransaction();   
        } catch (SQLException e) {   
            System.out.println(e.getMessage());   
        } finally {   
            try {   
                sqlMap.endTransaction();   
            } catch (SQLException e) {   
                e.printStackTrace();   
            }   
        }   
        return list;
    }
    public static void main(String[] args) {   
        update();   
        List user=getUsers();
        for(int i=0;i<user.size();i++)
        {   
            System.out.println(((User)user.get(i)).getName());   
        }   
  
    }   
}  

User.java

package com.si_tech;
import java.io.Serializable;

public class User implements Serializable {
 private static final long serialVersionUID = 1L;

 private Integer id;

 private String name;

 private Integer sex;

 public User() {

 }

 public Integer getId() {
  return id;
 }

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

 public String getName() {
  return name;
 }

 public void setName(String name) {
  this.name = name;
 }

 public Integer getSex() {
  return sex;
 }

 public void setSex(Integer sex) {
  this.sex = sex;
 }

}

SqlMapConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMapConfig PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
    "http://www.ibatis.com/dtd/sql-map-config-2.dtd">
<sqlMapConfig>

 <settings cacheModelsEnabled="true" enhancementEnabled="true"
  lazyLoadingEnabled="true" errorTracingEnabled="true" maxRequests="32"
  maxSessions="10" maxTransactions="5" useStatementNamespaces="false" />

 <transactionManager type="JDBC">
  <dataSource type="SIMPLE">
   <property name="JDBC.Driver" value="com.mysql.jdbc.Driver" />
   <property name="JDBC.ConnectionURL"
    value="jdbc:mysql://localhost/sample" />
   <property name="JDBC.Username" value="root" />
   <property name="JDBC.Password" value="root" />
   <property name="Pool.MaximumActiveConnections" value="10" />
   <property name="Pool.MaximumIdleConnections" value="5" />
   <property name="Pool.MaximumCheckoutTime" value="120000" />
   <property name="Pool.TimeToWait" value="500" />
   <property name="Pool.PingQuery"
    value="select 1 from sample" />
   <property name="Pool.PingEnabled" value="false" />
   <property name="Pool.PingConnectionsOlderThan" value="1" />
   <property name="Pool.PingConnectionsNotUsedFor" value="1" />
  </dataSource>
 </transactionManager>

 <sqlMap resource="com/si_tech/User.xml" />
</sqlMapConfig>

 

User.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap     
    PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"     
    "http://ibatis.apache.org/dtd/sql-map-2.dtd">
<sqlMap namespace="User">

 <typeAlias alias="user" type="com.si_tech.User" />
 <select id="getUser" parameterClass="java.lang.String"
  resultClass="com.si_tech.User">

  select name, sex from t_user where name = #name#
 </select>

 <select id="getAllUser" resultClass="user">

  select name, sex from t_user where name = #name#
 </select>
 
 <select id="getAllUsers" resultClass="user">

  select * from t_user
 </select>
 <update id="updateUser" parameterClass="user">

  UPDATE t_user SET name=#name#, sex=#sex# WHERE id = #id#
 </update>

 <insert id="insertUser" parameterClass="user">
  INSERT INTO t_user ( name, sex) VALUES ( #name#, #sex# )
 </insert>

 <delete id="deleteUser" parameterClass="java.lang.String">
  delete from t_user where id=#value#
 </delete>

</sqlMap>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值