ibatis+spring+struts統合アプリケーション



 この3つの統合といえば、ibatis+springの統合です.
Spring iBATIS統合例ここでは、2つのSpring iBATIS統合の方法を紹介します.この2つの統合方法もspring公式文書で言及されているこの2つの統合方式です.
 
Spring iBATIS統合モード1
 
Springに対する依存性なしに、元のiBATIS APIに基づいてプログラムすることができる.注入されたSqlMapClientを直接使用する.
例: 
 
package net.chinaideal.samples.ibatis.dao;   
import java.sql.SQLException;   
import net.chinaideal.samples.ibatis.model.User;   
import com.ibatis.sqlmap.client.SqlMapClient;   
/**   
* SpringiBatis - UserDAO.java    
*   :   
* UserDAO      
*       Spring  iBatis SqlMapClient,        iBatis API  。   
*             Spring  ,       iBatis API,        。   
**/ 

public class UserDAOImpl implements UserDAO {     
	protected SqlMapClient sqlMapClient;           
	public User getUserByUsername(String username) {          
		try {              
	return (User) this.sqlMapClient.queryForObject("getUserbyUsername", username);          
		} catch (SQLException ex) {              
			ex.printStackTrace();          
		}          
			return null;      
	}       

	public SqlMapClient getSqlMapClient() {          
       		return sqlMapClient;      
	}       
	public void setSqlMapClient(SqlMapClient sqlMapClient){                      
		this.sqlMapClient = sqlMapClient;      
	}       
} 
  
 Spring iBATIS統合モード二 
 
package net.chinaideal.samples.ibatis.dao;  
 
import net.chinaideal.samples.ibatis.model.User;   
import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;  
 
/**  
 * SpringiBatis - UserDAOImpl2.java  

 *   :  
 *   2:UserDAOImpl2  SqlMapClientDaoSupport   
 * SqlMapClientDaoSupport    Spring ibatis     
 * ibatis           ,Spring       ,      。  
 *   :  
 * queryForObject(statename, args)  。  
 *  
 *           Spring SqlMapClientDaoSupport,    Spring           ,     。  
 */ 
 
public class UserDAOImpl2 extends SqlMapClientDaoSupport implements UserDAO {  
/*
*           SqlMapClient   spring      UserDAOImpl2  bean     
* sqlMapClient bean   
*/
	public User getUserByUsername(String username) {  
    return (User)getSqlMapClientTemplate().queryForObject("getUserbyUsername", username);  
	}  
 
} 
 
Spring             :
 <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
    <property name="configLocation" value="WEB-INF/sql-map-config.xml"/>
    <property name="dataSource" ref="dataSource"/>
 </bean>

<bean id="userDao2" class="net.chinaideal.samples.ibatis.dao.UserDAOImpl2 ">
   <property name="sqlMapClient" ref="sqlMapClient"/>
 </bean>
 ------------------------------------
 
オープンソースのOrmオブジェクトマッピングフレームとしては、ibatisはスレッドの安全性と学習が容易ですが、開発はhibernateに対しては、複雑にロックされています.ibatisのすべての配置をサポートするツールがないので、ほとんど手書きで作成します.以下に作成します.
一、スプリングを導入して、ibatis jarバッグです.
二、ロゴ4 j.propertiesログファイルを作成する
      log 4 j.root Loggar=DEBUG、stdout
      log 4 j.apender.stdout=org.apache.log 4 j.sonine solieApender
      log 4 j.appnder.stdout.layout=org.apaache.log 4 j.Pattern Layout
      log 4 j.appnder.stdout.layout.ConversionPattern=%c{1}-%n
      log 4 j.logger.java.sql.PreparedSttement=DEBUG
三、Student.java類の映像属性を建立する
 
package org.terry.ibatis.pojo;

public class Student {

 private Long id;
 private String name;
 private String subject;
 private Long score;

 public Long getId() {  return id; }
 public void setId(Long id) {  this.id = id; }
 public String getName() {  return name; }
 public void setName(String name) {  this.name = name; }
 public Long getScore() {  return score; }
 public void setScore(Long score) {  this.score = score; }
 public String getSubject() {  return subject; }
 public void setSubject(String subject) {  this.subject = subject; }
}
  
四、student.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="student">

 <typeAlias alias="student" type="org.terry.ibatis.pojo.Student"/>

 <resultMap class="student" id="studentResult">

  <result property="id" column="id" jdbcType="number" javaType="java.lang.Long"/>
  <result property="name" column="name"/>
  <result property="subject" column="subject"/>
  <result property="score" column="score"/>

 </resultMap> 

 <select id="selectAll" resultMap="studentResult">
  select * from student
 </select> 

 <select id="findbyId" parameterClass="java.lang.Long" resultClass="student">
  select * from student where id=#id#
 </select>

 <insert id="insert" parameterClass="student">
  insert into student(id,name,subject,score) values(#id#,#name#,#subject#,#score#)
 </insert>

 <update id="update" parameterClass="student">
  update student set name=#name#,subject=#subject#,score=#score# where id=#id#
 </update>

 <delete id="delete" parameterClass="java.lang.Long">
  delete from student where id=#id#
 </delete>

</sqlMap>
 
五、Sql MapConfig.xmlファイルを作成する【ibatisの配置ファイルにsql Mapだけが残っています.他はいらないです.】
<?xml version="1.0" encoding="utf-8" ?>

<!DOCTYPE sqlMapConfig       
    PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"        "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
  
<sqlMapConfig>
    <sqlMap resource="org/terry/ibatis/pojo/student.xml"/>
</sqlMapConfig>

 
 
六、StudentDao.javaを作成する(実現クラス)
 
package org.terry.ibatis.dao;

import java.io.IOException;
import java.sql.SQLException;
import java.util.List;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
import org.springframework.orm.ibatis.SqlMapClientCallback;
import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;
import org.terry.ibatis.pojo.Student;
import com.ibatis.sqlmap.client.SqlMapExecutor;

public class StudentDao extends SqlMapClientDaoSupport implements Idao{

 public void delete(Long id) {
  this.getSqlMapClientTemplate().delete("delete", id);
 }

 public Object findbyId(Long id) {
  return this.getSqlMapClientTemplate().queryForObject("findbyId", id);
 }

 public List getAll() {
  return (List)this.getSqlMapClientTemplate().execute(new SqlMapClientCallback(){
   public Object doInSqlMapClient(SqlMapExecutor sqlMapper) throws SQLException {
    return sqlMapper.queryForList("selectAll");
   }
  });
 }

 public void save(Object o) {
  this.getSqlMapClientTemplate().insert("insert", o);
 }

 public void update(Object o) {
  this.getSqlMapClientTemplate().update("update", o);
 }

 public static void main(String[] args) throws IOException {
   Resource re=new ClassPathResource("Ibatis-Context.xml");
   XmlBeanFactory xml=new XmlBeanFactory(re);
   StudentDao student=(StudentDao)xml.getBean("studentDao");

   Student stu=new Student();
   stu.setId(Long.valueOf(16));
   stu.setName("terry");
   stu.setScore(Long.valueOf(99));
   stu.setSubject("  ");

   student.delete(Long.valueOf(16));
 }
}

 
 
七、Application Contact.xmlファイルの設定
<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans>

 <bean id="dataSource"  class="org.apache.commons.dbcp.BasicDataSource">

     <property name="driverClassName">
           <value>oracle.jdbc.driver.OracleDriver</value>
   </property>

  <property name="url">
          <value>jdbc:oracle:thin:@localhost:1521:orcl</value>
  </property>

  <property name="username">
         <value>terry</value>
  </property>

  <property name="password">
         <value>terry</value>
  </property>

 </bean>

 <bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
      <property name="configLocation" value="SqlMapConfig.xml"/>
      <property name="dataSource" ref="dataSource"></property>
 </bean>

    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
      <property name="dataSource" ref="dataSource"></property>
 </bean>

  <!--         -->
   <bean id="transactionIterceptor" class="org.springframework.transaction.interceptor.TransactionInterceptor">

    <!--                  -->
        <property name="transactionManager" ref="transactionManager"></property>
        <property name="transactionAttributes">
        <props>
              <prop key="insert*">PROPAGATION_REQUIRED</prop>
              <prop key="find*,get*">PROPAGATION_REQUIRED,readOnly</prop>
              <prop key="*">PROPAGATION_REQUIRED</prop>
     </props>
    </property>
   </bean>
   <bean class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator">

        <property name="beanNames">
             <list>
                  <value>*Dao</value>
             </list>
        </property>

        <property name="interceptorNames">
             <list>
                  <value>transactionIterceptor</value>
             </list>
        </property>
   </bean>

 <bean id="studentDao" class="org.terry.ibatis.dao.StudentDao">
      <property name="sqlMapClient" ref="sqlMapClient"></property>
 </bean>

</beans>