Spring访问数据的方式

访问数据的方式,传统的JDBC,Spring封装的数据库连接池(Datasource,DBCP,Tomcat的JIDN),Spring中的JdbcTemplte(org.springframework.jdbc.core)

现在介绍一下,Spring还可以结合其他工具操作数据库。

使用ORM工具访问数据库:


(一)了解ORM

Object——Relational——Mapping

对象 关系型数据库 映射



ORM包括一下4个部分:

1、一个对持久类对象进行增删改查的API

2、一个语言或API用来规定与类和类属性相关的查询

3、一个规定mapping metadata的工具(metadata元数据,记录一些数据本身的信息)

4、一种技术可以让ORM的实现同事务对象一起进行dirty cheking(脏数据检查),lazy association fetching(懒加载)以及其他的优化操作。


(二)使用Hibernate

Spring+Hibernate

四个步骤:

配置Spring的xml

配置***.hbm.xml

新建一个bean类

新建一个DAO

Spring的xml:

<!-- 配置DataSOurce -->
	<bean id="dataSOurce" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
		<property name="driverClassName">
			<value>oracle.jdbc.driver.OracleDriver</value>
		</property>
		<property name="url">
			<value>jdbc:oracle:thin:@127.0.0.1:1521:orcl</value>
		</property>
		<property name="username">
			<value>hr</value>
		</property>
		<property name="password">
			<value>hr12345</value>
		</property>
	</bean>
	<!-- 配置hibernate发=的SessionFactory -->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
		<property name="dataSource">
			<ref bean="dataSource"/>
		</property>
		<property name="mappingResources">
			<list>com/gc/acion/Student.hbm.xml</list>
		</property>
		<property name="hibernateProperties">
			<props>
				<prop key="hibernate.dialect">
					org.hibernate.dialect.Oracle9Dialect
				</prop>
				<prop key="hibernate.showsql">
					true
				</prop>
			</props>
		</property>
	</bean>
	<!-- 配置transactionManager -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="sessionFactory">
			<ref bean="sessionFactory"/>
		</property>
	</bean>
	<!-- 配置DAO -->
	<bean id="com.gc.acion.StudentDAO">
		<property name="sessionFactory">
			<ref bean="sessionFactory"/>
		</property>
		<property name="transactionManager">
			<ref bean="transactionManager"/>
		</property>
	</bean>

Hibernate通过SessionFactory创建和维护Session,Spring对SessionFactory的配置进行了整合。


Student.hbm.xml配置:

<?xml version="1.0" encoding="UTF-8"?>
<?xml version="1.0"?>    
<!DOCTYPE hibernate-mapping PUBLIC     
    "-//Hibernate/Hibernate Mapping DTD 3.0//EN"    
    "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">    
        
<!--     
    <hibernate-mapping>一般不去配置,采用默认即可。    
    default-cascade="none":默认的级联风格,表与表联动。    
    default-lazy="true":默认延迟加载    
 -->    
<hibernate-mapping>    
    
    <class name="com.gc.acion.Student" table="tbstudent" dynamic-insert="true" dynamic-update="true" optimistic-lock="version">
            
        <id name="id">    
            <!-- <generator>:指定主键由什么生成,推荐使用uuid(随机生成唯一通用的表示符,实体类的ID必须是String),  
                               native(让数据库自动选择用什么生成(根据底层数据库的能力选择identity,sequence或hilo中的一种)),  
                               assigned(指用户手工填入,默认)。 -->    
            <generator class="uuid"/>    
        </id>    
            
        <!--     
            <version/>:使用版本控制来处理并发,要开启optimistic-lock="version"和dynamic-update="true"。    
            name="version":持久化类的属性名,column="version":指定持有版本号的字段名;    
         -->    
        <version name="version" column="version"/>    
            
        <!--     
            <property>:为类定义一个持久化的javaBean风格的属性。    
            name="name":标识属性的名字,以小写字母开头;    
            column="name":表主键字段的名字,如果不填写与name一样;    
            update="true"/insert="true":默认为true,表示可以被更新或插入;    
         -->    
        <property name="name" column="name" />    
        <property name="msg" column="msg"/>    
            
        <!--     
            组件映射:把多个属性打包在一起当一个属性使用,用来把类的粒度变小。    
            <component name="属性,这里指对象">    
                <property name="name1"></property>    
                <property name="name2"></property>    
            </component>    
         -->    
             
         <!--     
            <join>:一个对象映射多个表,该元素必须放在所有<property>之后。    
            <join table="tbl_test:子表名">    
                <key column="uuid:子表主键"></key>    
            <property name="name1:对象属性" column="name:子表字段"></property>    
         </join>    
          -->    
             
    </class>    
        
</hibernate-mapping> 

bean:

package com.gc.acion;

/**
 * 表结构tbstudent (id,name, msg)
 * @author wangyj13357
 *
 */
public class Student {
	public Integer id;
	public String name;
	public String msg;
	
	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 String getMsg() {
		return msg;
	}
	public void setMsg(String msg) {
		this.msg = msg;
	}
	
}

StudentDAO:

//使用HibernateTemplate代替JdbcTemplate
	public void creat(String msg){
		DefaultTransactionDefinition def = new DefaultTransactionDefinition();
		TransactionStatus status = transactionManager.getTransaction(def);
		
		try {
			HibernateTemplate hibernateTemplate = new HibernateTemplate(sessionFactory);
			Student student = new Student();
			student.setId(001);
			student.setName("wangyj");
			student.setMsg("好孩子");
			hibernateTemplate.saveOrUpdate(student);
		} catch (Exception e) {
			transactionManager.rollback(status);
			throw e;
		} finally{
			transactionManager.commit(status);
		}
	}


(三)使用IBatis
IBatis+Spring
5个步骤:
配置Spring的xml
IBatis的配置文件,sqlMapConfig.xml,放在WEB-INF下
配置文件,****.xml
bean类
DAO类


Spring的xml配置文件:

<!-- 配置DataSOurce -->
	<bean id="dataSOurce" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
		<property name="driverClassName">
			<value>oracle.jdbc.driver.OracleDriver</value>
		</property>
		<property name="url">
			<value>jdbc:oracle:thin:@127.0.0.1:1521:orcl</value>
		</property>
		<property name="username">
			<value>hr</value>
		</property>
		<property name="password">
			<value>hr12345</value>
		</property>
	</bean>
	<!-- 配置IBatis -->
	<bean id="sqlMap" class="org.springframework.org.ibatis.SqlMapClientFactoryBean">  
	     <property name="dataSource" ref="dataSource" />  
	     <property name="configLocation" value="WEB-INF/sqlMapConfig.xml" />  
 	</bean>  
 	<!-- 配置transactionManager -->
 	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource">
			<ref bean="dataSource"/>
		</property>
	</bean>
	<!-- 配置DAO -->
	<bean id="com.gc.acion.StudentDAO">
		<property name="dataSource">
			<ref bean="dataSource"/>
		</property>
		<property name="transactionManager">
			<ref bean="transactionManager"/>
		</property>
		<property name="sqlMap">
			<ref bean="sqlMap"/>
		</property>
	</bean>

sqlMapConfig.xml:

<sqlMapConfig>
	<sqlMap resource="com/gc/acion/Student.xml"/>
</sqlMapConfig>

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 type="com.gc.acion.Student" alias="student" />	
	<resultMap class="student" id="teacherResult">		
		<result column="id" property="id" jdbcType="INT" />		
		<result column="name" property="name" jdbcType="VARCHAR2" />		
		<result column="msg" property="msg" jdbcType="VARCHAR2" />	
	</resultMap>	
	<select id="teacher_getTeacherList" resultMap="teacherResult">
		select * from tbstudent
	</select>
</sqlMap>

Student类:

package com.gc.acion;

/**
 * 表结构tbstudent (id,name, msg)
 * @author wangyj13357
 *
 */
public class Student {
	public Integer id;
	public String name;
	public String msg;
	
	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 String getMsg() {
		return msg;
	}
	public void setMsg(String msg) {
		this.msg = msg;
	}
	
}

DAO类


Spring对持久层的封装,并且jdbcTemplete与事务处理结合在一起。及Spring+Hibernate;Spring+IBatis





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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值