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小时内与您取得联系。