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>