对SpringDAO层支持的总结
- public interface JdbcOperations {
- //接口定义行为集
- public Object execute() throws SQLException ;
- }
- public abstract class AbstractJdbcOperations implements JdbcOperations {
- @Override
- public final Object execute() throws SQLException {
- Connection conn = DataSourceUtils.getConnection();
- try {
- Object retVal = doInConnection(conn);
- conn.commit();
- return retVal;
- }catch (Exception e) { conn.rollback(); throw e;}
- finally { conn.close(); }
- }
- public abstract Object doInConnection(Connection conn) throws SQLException;
- }
- public class DataSourceUtils {
- public static Connection getConnection() {
- //返回数据库连接
- return null;
- }
- }
- JdbcOperations select = new AbstractJdbcOperations() {
- @Override
- public Object doInConnection(Connection conn) throws SQLException {
- PreparedStatement pstmt =
- conn.prepareStatement("select * from tbl_user");
- ResultSet rs = pstmt.executeQuery();
- List result = null;
- //处理结果集
- return result;
- }
- };
- select.execute();
- public interface JdbcOprations2 {
- //接口定义行为集
- public Object execute(ConnectionCallback callback) throws Exception ;
- }
- public interface ConnectionCallback {
- public Object doInConnection(Connection conn) throws SQLException;
- }
- public class JdbcTemplate implements JdbcOprations2 {
- @Override
- public Object execute(ConnectionCallback callback) throws Exception {
- Connection conn = DataSourceUtils.getConnection();
- try {
- Object retVal = callback.doInConnection(conn);
- conn.commit();
- return retVal;
- }
- catch (Exception e) {
- conn.rollback();
- throw e;
- }
- finally {
- conn.close();
- }
- }
- }
- jdbcTemplate.execute(new ConnectionCallback() {
- @Override
- public Object doInConnection(Connection conn) throws SQLException {
- //可变操作
- return null;
- }
- });
- public interface PreparedStatementCallback {
- public Object doInPreparedStatement(PreparedStatement pstmt)
- throws SQLException;
- }
缺点:灵活但不通用

对SpringDAO层支持的总结的更多相关文章
- TensorRT层和每个层支持的精度模式
下表列出了TensorRT层和每个层支持的精确模式.它还列出了该层在深度学习加速器(DLA)上运行的能力.有关附加约束的更多信息,请参见 DLA Supported Layershttps://doc ...
- [Abp vNext 源码分析] - 5. DDD 的领域层支持(仓储、实体、值对象)
一.简要介绍 ABP vNext 框架本身就是围绕着 DDD 理念进行设计的,所以在 DDD 里面我们能够见到的实体.仓储.值对象.领域服务,ABP vNext 框架都为我们进行了实现,这些基础设施都 ...
- Caffe学习系列(4):激活层(Activiation Layers)及参数
在激活层中,对输入数据进行激活操作(实际上就是一种函数变换),是逐元素进行运算的.从bottom得到一个blob数据输入,运算后,从top输入一个blob数据.在运算过程中,没有改变数据的大小,即输入 ...
- 转 Caffe学习系列(4):激活层(Activiation Layers)及参数
在激活层中,对输入数据进行激活操作(实际上就是一种函数变换),是逐元素进行运算的.从bottom得到一个blob数据输入,运算后,从top输入一个blob数据.在运算过程中,没有改变数据的大小,即输入 ...
- caffe中关于(ReLU层,Dropout层,BatchNorm层,Scale层)输入输出层一致的问题
在卷积神经网络中.常见到的激活函数有Relu层 layer { name: "relu1" type: "ReLU" bottom: "pool1&q ...
- caffe 每层结构
如何在Caffe中配置每一个层的结构 最近刚在电脑上装好Caffe,由于神经网络中有不同的层结构,不同类型的层又有不同的参数,所有就根据Caffe官网的说明文档做了一个简单的总结. 1. Vision ...
- [转] caffe激活层及参数
在激活层中,对输入数据进行激活操作(实际上就是一种函数变换),是逐元素进行运算的.从bottom得到一个blob数据输入,运算后,从top输入一个blob数据.在运算过程中,没有改变数据的大小,即输入 ...
- caffe(4) 激活层(Activation Layers)及参数
在激活层中,对输入数据进行激活操作(实际上就是一种函数变换),是逐元素进行运算的.从bottom得到一个blob数据输入,运算后,从top输入一个blob数据.在运算过程中,没有改变数据的大小,即输入 ...
- 『开发技巧』Keras自定义对象(层、评价函数与损失)
1.自定义层 对于简单.无状态的自定义操作,你也许可以通过 layers.core.Lambda 层来实现.但是对于那些包含了可训练权重的自定义层,你应该自己实现这种层. 这是一个 Keras2.0 ...
随机推荐
- topGO
前面我们讲过GO.db这个包,现在接着延伸topGO包,该包是用来协助GO富集分析 1)安装 if("topGO" %in% rownames(installed.packages ...
- Spring工作原理与单例
最近看到spring管理的bean为单例的,当它与web容器整合的时候始终搞不太清除,就网上搜索写资料, Tomcat与多线程, servlet是多线程执行的,多线程是容器提供的能力. servlet ...
- memcache缓存失效
缓存过期 memcached在处理过期的缓存项时,采用懒惰模式处理方法. 缓存项过期,不会立即删除,直到对该缓存项执行了get操作,才会删除过期缓存. > set key 0 10 > t ...
- springmvc与struts2的不同
1.springmv的入口是一个servlet,即前端控制器.而struts2入口是一个fliter过滤器. 2.springmvc是基于开发方法(一个url对应一个方法,通过注解的方式进行访问),请 ...
- Halcon一维码和二维码的解码步骤和技巧——第11讲
针对Halcon中一维码和二维码的解码,我分别写了两篇文章,参见: <Halcon的一维条码解码步骤和解码技巧>:https://www.cnblogs.com/xh6300/p/1048 ...
- [freeCodeCamp] solution to HTTP JSON API SERVER passed!
var http = require('http') var url = require('url') function parsetime (time) { return { hour: time. ...
- OpenGLES.Functions.Missing.in.OpenGLES1.x
转载自: http://maniacdev.com/2009/05/big-list-of-opengl-functions-missing-in-iphone-opengl-es The funct ...
- [转]docker 基本原理及快速入门
版权声明:原创作品, 来自海牛部落-青牛,http://hainiubl.com/topics/13 什么是docker Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud ...
- asp.net core 2.1 增加Nlog日志到sql server数据库
一.增加引用 <PackageReference Include="NLog.Extensions.Logging" Version="1.2.1" /& ...
- 判定map中是否存在某元素
判断某key是否存在可以使用map的count方法来间接判定 count接受一个参数key值,返回map中key值为给定值的元素总数 map<int, string> i_to_s_map ...