陈科朝:http://blog.csdn.net/u013474104/article/details/44279309

================

1.spring 对数据库訪问的支持

当我们开发持久层的时候。我们面临着多种选择。比方使用JDBC、Hibernate、java持久化API或其他持久化框架。幸好的是spring可以支持全部这些持久化机制。

DAO(data access boject)数据訪问对象,这个名字就非常形象描写叙述了DAO在应用程序中所扮演的角色。

DAO提供了数据的读取、写入到数据库中的一种方式。它们应该以接口的方式公布功能,而应用程序的其他部分就能够通过接口来进行訪问了。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzQ3NDEwNA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" style="font-size:18px">

注:服务对象本身并不会处理数据訪问。而是将数据訪问托付给DAO。DAO接口确保其与服务对象的松耦合。

2.配置数据源

spring提供了在spring上下文中配置数据源Bean的多种方式,包含:

a.通过JDBC驱动程序定义的数据源;

b.通过JNDI查找的数据源;

c.连接池的数据源;

接下我们就专门来讲讲从使用连接池获取连接的数据源!

(即c点)

上下文配置Bean的代码:

  1. <!--配置数据源 -->
  2. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
  3. <property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
  4. <property name="url" value="jdbc:oracle:thin:@localhost:1521:orcl"/>
  5. <property name="username" value="wwo"/>
  6. <property name="password" value="wwo"/>
  7. <!-- 连接池启动时的初始值 -->
  8. <property name="initialSize" value="3" />
  9. <!-- 连接池的最大值 -->
  10. <property name="maxActive" value="300" />
  11. <!-- 最大空暇值.当经过一个高峰时间后,连接池能够慢慢将已经用不到的连接慢慢释放一部分,一直降低到maxIdle为止 -->
  12. <property name="maxIdle" value="2" />
  13. <!-- 最小空暇值.当空暇的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 -->
  14. <property name="minIdle" value="1" />
  15. <!-- end -->
  16. </bean>

注:JDBC驱动数据源并没有池的概念,因此没有存在池属性的配置!

好了,到这一步,我们已经完毕了通过数据源建立了与数据库的连接。接下来就是实际訪问数据库了。

3.在Spring中集成Hibernate

Hibernate一些特性:

a.延迟载入(Lazy loading):比如一个Bean对象由其属性及还有一个Bean对象组成,假设我们仅仅关注的仅仅是这个Bean对象的属性。那么我们能够借助于延迟载入,仅仅抓取须要的数据。

b.预先抓取(Eager fetching):这与延迟载入是相对的,一个Bean所关联的其他Bean都会被查询出来,这就节省了多次查询的成本;

c.级联(Cascading):有时候删除一个Bean对象后,也希望其同一时候能数据库中删除掉与其关联的其他Bean。

Spring对Hibernate ORM框架的支持提供了与这些框架集成点以及一些附加的服务,例如以下所看到的:

a.Spring声明式事务的集成支持。

b.透明的异常处理;

c.线程安全的、轻量级的模板类;

d.DAO支持类。

e.资源管理。

4.声明会话工厂(Session Factory)

使用Hibernate的主要接口是org.hibernate.Session。Session提供了主要的数据訪问功能,如保存、更新、删除以及从数据库载入对象的功能。

能过借助于Hibernate的SessionFactory来获取Session对象,SessionFactory主要负责Hibernate Session的打开、关闭以及管理。

配置在xml上下文的Bean例如以下:

  1. <bean id="sessionFactory"
  2. class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
  3. <property name="dataSource" ref="dataSource"/>
  4. <property name="packagesToScan">
  5. <!--扫描一下实体文件夹 -->
  6. <list>
  7. <value>com.blog.entity</value>
  8. </list>
  9. </property>
  10. <property name="hibernateProperties">
  11. <props>
  12. <prop key="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</prop>
  13. <prop key="hibernate.show_sql">true</prop>
  14. <prop key="hibernate.format_sql"> true</prop>
  15. <prop key="current_session_context_class">thread</prop>
  16. </props>
  17. </property>
  18. </bean>

5.创建自己的基础DAO类

Spring可以通过Spring的Hibernate模板来保证每一个事务都使用同一个会话。既然Hibernate可以对其自己进行管理,那就不必要使用模板类了。接下我们直接将Hibernate Session装配到自己的DAO类中。

  1. /**
  2. * 基础dao
  3. *
  4. * @author ckz
  5. *
  6. * @param <T>
  7. */
  8. public abstract class BaseDAO<T> {
  9. private Class<T> baseEntity;
  10.  
  11. protected BaseDao(Class<T> baseEntity) {
  12. this.baseEntity = baseEntity;
  13. }
  14.  
  15. /**
  16. * 注入sessionFactory
  17. */
  18. @Autowired
  19. private SessionFactory sessionFactory;
  20.  
  21. /**
  22. * 获得session
  23. *
  24. * @return
  25. */
  26. protected Session getCurrentSession() {
  27. return sessionFactory.getCurrentSession();
  28. }
  29.  
  30. /**
  31. * 保存
  32. *
  33. * @param entity
  34. * @throws Exception
  35. */
  36. public void add(T entity) throws Exception {
  37. getCurrentSession().save(entity);
  38. }
  39.  
  40. /**
  41. * 调用存储过程
  42. *
  43. * @param proName
  44. * @return
  45. */
  46. public CallableStatement citePro(final String proName){
  47. Session session = getCurrentSession();
  48. CallableStatement proc=session.doReturningWork(
  49. new ReturningWork<CallableStatement>() {
  50. @Override
  51. public CallableStatement execute(Connection connection) throws SQLException{
  52. CallableStatement resultSet = connection.prepareCall(proName);
  53. return resultSet;
  54. }
  55. }
  56. );
  57. return proc;
  58. }
  59.  
  60. /**
  61. * 更新
  62. *
  63. * @param entity
  64. * @throws Exception
  65. */
  66. public void update(T entity) throws Exception {
  67. getCurrentSession().update(entity);
  68. }
  69.  
  70. /**
  71. * 保存或更新
  72. *
  73. * @param entity
  74. * @throws Exception
  75. */
  76. public void saveOrUpdate(T entity) throws Exception {
  77. getCurrentSession().saveOrUpdate(entity);
  78. }
  79.  
  80. /**
  81. * 删除
  82. *
  83. * @param entity
  84. * @throws Exception
  85. */
  86. public void delete(T entity) throws Exception {
  87. getCurrentSession().delete(entity);
  88. }
  89.  
  90. /**
  91. * 依据id获取对象
  92. *
  93. * @param Id
  94. * @return
  95. */
  96. @SuppressWarnings("unchecked")
  97. public T getById(final Serializable Id) {
  98. return (T) getCurrentSession().get(this.baseEntity, Id);
  99. }
  100. }

注:

1.T表示的是泛型的參数类型,java泛型简述--http://blog.csdn.net/u013474104/article/details/44337145;

2.T - 由此
Class 对象建模的类的类型。

比如,String.class 的类型是 Class<String>

假设将被建模的类未知。则使用
Class<?>;

版权声明:本文博主原创文章,博客,未经同意不得转载。

SpringAccess数据库(oracle)构造的更多相关文章

  1. Oracle实例和Oracle数据库(Oracle体系结构)

    --========================================== --Oracle实例和Oracle数据库(Oracle体系结构) --==================== ...

  2. 【转载】Oracle实例和Oracle数据库(Oracle体系结构)

    免责声明:     本文转自网络文章,转载此文章仅为个人收藏,分享知识,如有侵权,请联系博主进行删除.     原文作者:Leshami      原文地址:http://blog.csdn.net/ ...

  3. Oracle 数据库(oracle Database)Select 多表关联查询方式

    Oracle数据库中Select语句语法及介绍 SELECT [ ALL | DISTINCT ] <字段表达式1[,<字段表达式2[,…] FROM <表名1>,<表名 ...

  4. spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置

    spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...

  5. 各种数据库(oracle、mysql、sqlserver等)在Spring中数据源的配置和JDBC驱动包----转

    在开发基于数据库的应用系统时,需要在项目中进行数据源的配置来为数据 库的操作取得数据库连接.配置不同数据库的数据源的方法大体上都是相同的,不同的只是不同数据库的JDBC驱动类和连接URL以及相应的数据 ...

  6. JDBC(用Eclipse操作数据库Oracle)的基础操作集合

    JDBC: JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编 ...

  7. [数据库]Oracle和mysql中的分页总结

    Mysql中的分页 物理分页 •在sql查询时,从数据库只检索分页需要的数据 •通常不同的数据库有着不同的物理分页语句 •mysql物理分页,采用limit关键字 •例如:检索11-20条 selec ...

  8. Ubuntu16.04下安装数据库oracle客户端

    在Ubuntu16.04下安装oracle数据库客户端,使Django项目连接到远程Oracle数据库. 1.下载oracle客户端安装包: 进入官网http://www.oracle.com/tec ...

  9. 不同数据库oracle mysql SQL Server DB2 infomix sybase分页查询语句

    在不同数据库中的使用的分页查询语句: 当前页:currentpage 页大小:pagesize 1. Oracle数据库 select * from (select A.*,rownum rn fro ...

随机推荐

  1. vim使用(三):.viminfo和.vimrc

    1. viminfo 在vim中操作的行为,vim会自己主动记录下来,保存在 ~/.viminfo 文件里. 这样为了方便下次处理, 如:vim打开文件时,光标会自己主动在上次离开的位置显示. 原来搜 ...

  2. 采用SharePoint Designer将JavaScript而他们的网站页面集成的定义

    采用SharePoint Designer将JavaScript而他们的网站页面集成的定义 像JavaScript这种动态脚本语言可以给你的页面震撼效果.为了加盟JavaScript要定义自己的网站页 ...

  3. unicode下一个,读取数据库乱码问题

    TCHAR cbContent[512];           dyn.GetFieldValue(0,cbContent,512); // 中文会显示乱码 AfxMessageBox(cbConte ...

  4. GCD code block

    在这里积累一些片段,由于备忘录. + (DRClass *)sharedDR{ //创建小黑.正常ap模式仅仅有一个小黑,so static DRClass *aDR = nil; static di ...

  5. Entity Framework mvc Code First data migration

    1. Code First 可以先在代码里写好数据模型,自动生成DB.下一次启动的时候会根据__MigrationHistory判断 数据库是否和模型一致. 详情参考:http://blogs.msd ...

  6. 客户端上显示csdn上的各类别下的的文章列表 (制作csdn app 三)

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/23597229 今天将在Android 使用Fragment,ViewPagerI ...

  7. Java应用中使用ShutdownHook友好地清理现场(转)

    在线上Java程序中经常遇到进程程挂掉,一些状态没有正确的保存下来,这时候就需要在JVM关掉的时候执行一些清理现场的代码.Java中得ShutdownHook提供了比较好的方案. JDK在1.3之后提 ...

  8. 解决mysqldb查询大量数据导致内存使用过高的问题

    1.源码 connection=MySQLdb.connect( host="thehost",user="theuser", passwd="the ...

  9. iOS 辛格尔顿

    单例模式: 为什么使用单例,单例模式的用途是什么?以下我们举一个样例来诠释一下 举个大家都熟知的样例--Windows任务管理器,如图,我们能够做一个这种尝试,在Windows的"任务栏&q ...

  10. 站点系统压力測试Jmeter+Badboy

    近期项目须要压力測试,因此搜了几款试用,首选的是LoadRunner这款大名鼎鼎的測试软件: LoadRunner11 下载请猛戳这里 传送门LoadRunner破解文件 下载请猛戳这里 传送门Loa ...