JdbcTemplate 来封装数据库jdbc操作细节
29 } 提供了JdbcTemplate 来封装数据库jdbc操作细节: 包括: 数据库连接[打开/关闭] , 异常转义 , SQL执行 , 查询结果的转换 使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操
29
|
}
|
提供了JdbcTemplate 来封装数据库jdbc操作细节:
包括: 数据库连接[打开/关闭] ,异常转义 ,SQL执行 ,查询结果的转换
使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操作,简化传统的JDBC操作的复杂和繁琐过程。
1) 使用JdbcTemplate 更新(insert /update /delete)
1
|
int k
= jdbcTemplate.update( "UPDATE
tblname SET prop1=?,prop2=?..." , new Object[]{...});
|
1
|
jdbcTemplate.update( "INSERT
INTO tblname VALUES(?,?,..)" , new Object[]{...},
|
2
|
new int []{Types.VARCHAR,Types.NUMERIC});
|
01
|
jdbcTemplate.update( "INSERT
INTO tblname VALUES(?,?,..)" ,
|
02
|
new PreparedStatementSetter(){
|
03
|
public void setValues(PreparedStatement
ps) throws SQLException{
|
04
|
ps.setLong( 1 ,
user.getId( 1 ));
|
05
|
ps.setString( 2 ,
user.getName( 2 ));
|
06
|
ps.setDate( 3 , new java.sql.Date( new Date().getTime());
|
07
|
ps.setTimestamp( 4 , new Timestamp( new Date().getTime());
|
08
|
}
|
09
|
}
|
10
|
);
|
2) 使用JdbcTemplate 查询 (select)
1
|
final User
user = new User();
|
2
|
jdbcTemplate.query( "SELECT
id,name,.. FROM tblname WHERE id=1" ,
|
3
|
new RowCallbackHandler(){
|
4
|
public void processRow(ResultSet
rs) throws SQLException{
|
5
|
user.setId(rs.getLong( 1 ));
|
6
|
user.setName(rs.getString( 2 ));
|
7
|
}
|
8
|
}
|
9
|
);
|
01
|
List
uGroup = jdbcTemplate.query( "SELECT
id,name,.. FROM tblname WHERE igroup=1" ,
|
02
|
new RowMapper(){
|
03
|
public Object
mapRow(ResultSet rs, int no) throws SQLException{
|
04
|
User
user = new User();
|
05
|
user.setId(rs.getLong( 1 ));
|
06
|
user.setName(rs.getString( 2 ));
|
07
|
return user
;
|
08
|
}
|
09
|
}
|
10
|
};
|
3)使用JdbcTemplate 便捷方法
1
|
List
uNames = jdbcTemplate.queryForList( "SELECT
name FROM tblname WHERE id>?" ,
|
2
|
new Integer
[]{ 5 },
String. class );
|
1
|
List<map>
uMapList = (List<map>) jdbcTemplate.queryForList( </map></map> "SELECT
id, name FROM tblname WHERE id>?" ,
|
2
|
new Integer
[]{ 5 });
|
3
|
for (Map<string>
uMap :uMapList){</string>
|
4
|
Integer
id = uMap.get( "id" );
|
5
|
String
name = uMap.get( "name" );
|
6
|
};
|
1
|
String
user = jdbcTemplate.queryForObject( "SELECT
name FROM tblname WHERE id=?" ,
|
2
|
new Integer
[]{ 5 },
String. class );
|
1
|
int uNum
= jdbcTemplate.queryForInt( "SELECT
count(*) FROM tblname WHERE id>?" ,
|
2
|
new Integer
[]{ 5 });
|
4)使用jdbc 操作类
a)扩展 MappingSqlQuery类
01
|
class JdbcQueryObject extends MappingSqlQuery
{ //
extends SqlQuery
|
02
|
public JdbcQueryObject
(DataSource ds,String sql){
|
03
|
this .setDataSource(
ds );
|
04
|
this .setSql(
sql );
|
05
|
this .declareParameter( new Sqlparameter( "propName" ,
|
06
|
Types.VARCHAR); //
propName 提示作用
|
07
|
this .compile();
|
08
|
}
|
09
|
public Object
mapRow(ResultSet rs, int p) throws SQLException{
|
10
|
//
...
|
11
|
}
|
12
|
}
|
13
|
JdbcQueryObject
queryObj = new JdbcQueryObject(
ds,
|
14
|
"SELECT
.. FROM tblName WHERE param=?" );
|
15
|
List
list = queryObj.execute( new Object[]{...});
|
b)使用 SqlFunction 类 查询单条结果
1
|
SqlFunction
queryFun = new SqlFunction(
ds,
|
2
|
"select
count(*) from tblName where ..." , new int []{Types.CHAR,...}
);
|
3
|
queryFun.compile();
|
4
|
queryFun.run( new Object[]{p1,p2,..});
|
c)使用 SqlUpdate 类 更新
1
|
SqlUpdate
updateFunc = new SqlUpdate(ds
, "INSERT
tblName ..." );
|
2
|
updateFunc.declareParameter( new SqlParameter( "prop" ,Types.CHAR)
);
|
3
|
updateFunc.compile();
|
4
|
updateFunc.update( new String[]{s1,s1});
|
5)支持jdbc 事务
spring的事务管理有两种方式:编程式事务、声明式事务
这里谈一下 基于数据库单一资源的编程式事务:
spring用实现TransactionDefinition接口的类定义事务的属性:传播行为;隔离级别;超时值;只读标志
默认实现为:DefaultTransactionDefinition类
01
|
PlatformTransactionManager
tm =
|
02
|
new DataSourceTransactionManager(
|
03
|
jdbcTemplate.getDataSource()
);
|
04
|
TransactionStatus
status = null ;
|
05
|
try {
|
06
|
//null
默认事务属性配置DefaultTransactionDefinition
|
07
|
status
= tm.getTransaction( null );
|
08
|
for ( final String
wd: words){
|
09
|
try {
|
10
|
jdbcTemplate.update(
insertWordSql,
|
11
|
new PreparedStatementSetter(){
|
12
|
13
|
public void setValues(PreparedStatement
pstate)
|
14
|
throws SQLException
{
|
15
|
pstate.setString( 1 ,
wd) ;
|
16
|
pstate.setTimestamp( 2 ,
|
17
|
new Timestamp( new Date().getTime()
));
|
18
|
}
|
19
|
}
|
20
|
);
|
21
|
|
22
|
} catch (DataAccessException
e) {
|
23
|
e.printStackTrace();
|
24
|
//tm.rollback(status);
|
25
|
}
|
26
|
} //
end for
|
27
|
} finally {
|
28
|
tm.commit(status);
|
29
|
}
|

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

本站4月17日消息,集邦咨询(TrendForce)近日发布报告,认为英伟达Blackwell新平台产品需求看涨,预估带动台积电2024年CoWoS封装总产能提升逾150%。英伟达Blackwell新平台产品包括B系列的GPU,以及整合英伟达自家GraceArmCPU的GB200加速卡等。集邦咨询确认为供应链当前非常看好GB200,预估2025年出货量有望超过百万片,在英伟达高端GPU中的占比达到40-50%。在英伟达计划下半年交付GB200以及B100等产品,但上游晶圆封装方面须进一步采用更复

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

Hibernate多态映射可映射继承类到数据库,提供以下映射类型:joined-subclass:为子类创建单独表,包含父类所有列。table-per-class:为子类创建单独表,仅包含子类特有列。union-subclass:类似joined-subclass,但父类表联合所有子类列。

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

本站7月9日消息,AMDZen5架构“Strix”系列处理器会有两种封装方案,其中较小的StrixPoint将采用FP8封装,而StrixHalo将会采用FP11封装。图源:videocardz消息源@Olrak29_最新曝料称StrixHalo的FP11封装尺寸为37.5mm*45mm(1687平方毫米),和英特尔AlderLake、RaptorLakeCPU的LGA-1700封装尺寸相同。AMD最新的PhoenixAPU采用FP8封装方案,尺寸为25*40mm,这意味着StrixHalo的F

目录Astar Dapp 质押原理质押收益 拆解潜在空投项目:AlgemNeurolancheHealthreeAstar Degens DAOVeryLongSwap 质押策略 & 操作“AstarDapp质押”今年初已升级至V3版本,对质押收益规则做了不少调整。目前首个质押周期已结束,第二质押周期的“投票”子周期刚开始。要获取“额外奖励”收益,需把握此关键阶段(预计持续至6月26日,现余不到5天)。我将细致拆解Astar质押收益,

通过封装代码,C++函数可以提高GUI开发效率:代码封装:函数将代码分组到独立单元,使代码易于理解和维护。可重用性:函数可创建通用功能供应用程序中重复使用,减少重复编写和错误。简洁代码:封装代码使主逻辑简洁,便于阅读和调试。
