全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Spring jdbc中数据库操作对象化模型的实例详解

Spring jdbc中数据库操作对象化模型的实例详解

Spring Jdbc数据库操作对象化

 使用面向对象方式表示关系数据库的操作,实现一个线程安全可复用的对象模型,其顶级父类接口RdbmsOperation.

 SqlOperation继承该接口,实现数据库的select, update, call等操作。 

1.查询接口:SqlQuery

1) GenericSqlQuery, UpdatableSqlQuery, MappingSqlQueryWithParameter 

2) SqlUpdate, BatchSqlUpdate

3) SqlCall

 1) 将数据库操作select封装为对象,查询操作的基类是SqlQuery,所有查询都可以使用该类表示,Spring JDBC还提供了一些更容易使用的MappingSqlQueryWithParameters和MappingSqlQuery用于将结果集映射为Java对象,查询对象类还提供了两个扩展UpdatableSqlQuery和SqlFunction;

 2) 即增删改操作,将数据库操作insert 、update、delete封装为对象,增删改基类是SqlUpdate,当然还提供了BatchSqlUpdate用于批处理;

 3) 存储过程及函数调用封装为对象,基类是SqlCall类,提供了StoredProcedure实现。

数据库连接

JDBC:

 spring jdbc通过DataSource控制数据库连接即通过其实现子类获取。

 1) DriverManagerDataSource: 简单封装DriverManager.getConnection()

 2) SingleConnectionDataSource: 内部封装一个链接,不会关闭不能再多线程使用,用于测试

 3) LazyConnectionDataSourceProxy: 封装DataSource,用于延迟获取数据库连接,只有在真正创建Statement等时才获取连接,因此再说实际项目中最后使用该代理包装原始DataSource从而使得只有在真正需要连接时才去获取。 

Vendor:

 提供的DataSource实现主要有C3P0/Proxool/DBCP/ 等,这些实现都具有数据库连接池能力。 

DataSourceUtils: Spring JDBC抽象框架内部都是通过它的getConnection(DataSource dataSource)方法获取数据库连接,releaseConnection(Connection con, DataSource dataSource) 用于释放数据库连接,DataSourceUtils用于支持Spring管理事务,只有使用DataSourceUtils获取的连接才具有Spring管理事务。

Spring JDBC通过DaoSupport抽象类提供一致的数据库访问。

 1) JdbcDaoSupport: 支持一致的JdbcTemplate访问

 2) NamedParameterJdbcDaoSupport: JdbcDaoSupport子类,提供了NamedParameterJdbcTemplate的访问

 3) SimpleJdbcDaoSupport: JdbcDaoSupport子类,提供了SimpleJdbcTemplate访问 

由于JdbcTemplate、NamedParameterJdbcTemplate、SimpleJdbcTemplate类使用DataSourceUtils获取及释放连接,而且连接是与线程绑定的,因此这些JDBC模板类是线程安全的,即JdbcTemplate对象可以在多线程中重用。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# Spring  # jdbc  # 操作对象化模型  # 数据库操作对象  # IntelliJ IDEA安装运行python插件方法  # Intellij IDEA安装lombok插件及使用详解  # IntelliJ IDEA 热部署插件JRebel的使用  # 推荐一款IntelliJ IDEA提示快捷键的Key Promoter X插件  # Java 程序员必备的 Intellij IDEA 插件  # IntelliJ IDEA JRebel 安装使用图文教程(热部署插件)  # Intellij IDEA插件开发入门详解  # Intellij Idea插件开发之创建项目层级的右键菜单  # 使用IntelliJ IDEA 2017.2.5 x64中的Spring Initializr插件快  # 详述IntelliJ IDEA插件的安装及使用方法(图解)  # IntelliJ IDEA 安装vue开发插件的方法  # 详解如何在IntelliJ IDEA中使用.ignore插件忽略不必要提交的文件  # Intellij IDEA 配置Subversion插件实现步骤详解  # Spring Boot实战之数据库操作的示例代码  # springboot数据库操作图文教程  # Spring Boot Mysql 数据库操作示例  # Spring Boot中使用IntelliJ IDEA插件EasyCode一键生成代码详细方法  # 子类  # 时才  # 都是  # 如有  # 批处理  # 希望能  # 可以使用  # 谢谢大家  # 更容易  # 再多  # 绑定  # 多线程  # 面向对象  # 存储过程  # 复用  # 疑问请  # 连接池  # 主要有  # 抽象类  # Java 


相关文章: 潮流网站制作头像软件下载,适合母子的网名有哪些?  网站制作新手教程,新手建设一个网站需要注意些什么?  重庆市网站制作公司,重庆招聘网站哪个好?  如何有效防御Web建站篡改攻击?  网站代码制作软件有哪些,如何生成自己网站的代码?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  如何通过虚拟主机快速完成网站搭建?  网站制作员失业,怎样查看自己网站的注册者?  如何在企业微信快速生成手机电脑官网?  如何通过万网虚拟主机快速搭建网站?  成都响应式网站开发,dw怎么把手机适应页面变成网页?  建站之星安装步骤有哪些常见问题?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  C#如何在一个XML文件中查找并替换文本内容  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  如何通过VPS搭建网站快速盈利?  创业网站制作流程,创业网站可靠吗?  Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递  电影网站制作价格表,那些提供免费电影的网站,他们是怎么盈利的?  详解jQuery中基本的动画方法  如何快速搭建高效可靠的建站解决方案?  javascript中的try catch异常捕获机制用法分析  用v-html解决Vue.js渲染中html标签不被解析的问题  如何高效配置香港服务器实现快速建站?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  专业商城网站制作公司有哪些,pi商城官网是哪个?  家庭建站与云服务器建站,如何选择更优?  C++如何使用std::optional?(处理可选值)  北京建设网站制作公司,北京古代建筑博物馆预约官网?  如何通过网站建站时间优化SEO与用户体验?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  网站设计制作公司地址,网站建设比较好的公司都有哪些?  如何在建站宝盒中设置产品搜索功能?  公司门户网站制作流程,华为官网怎么做?  制作充值网站的软件,做人力招聘为什么要自己交端口钱?  建站之星微信建站一键生成小程序+多端营销系统  ppt制作免费网站有哪些,ppt模板免费下载网站?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  家庭服务器如何搭建个人网站?  建站之星展会模版如何一键下载生成?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  太平洋网站制作公司,网络用语太平洋是什么意思?  如何在云主机快速搭建网站站点?  定制建站流程解析:需求评估与SEO优化功能开发指南  建站主机是什么?如何选择适合的建站主机?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式) 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。