- 浏览: 1101756 次
- 性别:
- 来自: 成都
文章分类
最新评论
-
skyesx:
这是2PC实现,更常用的是一个柔性事务的实现,可以参考http ...
Spring分布式事务实现 -
ddbird:
这第一句就不严谨“分布式事务是指操作多个数据库之间的事务”,显 ...
Spring分布式事务实现 -
呵呵6666:
基于互联网支付系统的微服务架构分布式事务解决方案http:// ...
Spring分布式事务实现 -
小黄牛:
写得不错,交流群:472213887
Spring分布式事务实现 -
jiaoqf321456:
这明明是用的apache的压缩,给ant.jar有半毛钱关系吗 ...
使用ant.jar进行文件zip压缩
一、使用示例
(1)springJdbcContext.xml
(2)接口:(以第二种方式定义DAO)
(3)接口实现
(4)测试
二、关于操作Blob和Clob问题
spring定义了一个以统一的方式操作各种数据库的Lob类型数据的LobCreator(保存的时候用),同时提供了一个LobHandler为操作二进制字段和大文本字段提供统一接口访问。
(1)配置文件
(2)读写
lxsgoodluck 写道
用GeneratedKeyHolder的地方说“MySQL中不行,Oracle可以”,是不对的,spring中isReturnGeneratedKeys默认是false, 需要setReturnGeneratedKeys(true) 方法怎么写?哪个对象调用的?
SqlUpdate及其扩展类的对象
可以看下我这里的帖子http://www.iteye.com/post/1023484
用GeneratedKeyHolder的地方说“MySQL中不行,Oracle可以”,是不对的,spring中isReturnGeneratedKeys默认是false, 需要setReturnGeneratedKeys(true)
方法怎么写?哪个对象调用的?
(1)springJdbcContext.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd"> <description>springApp</description> <!-- dataSource for MySQL --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/springapp" /> <property name="username" value="root" /> <property name="password" value="****" /> </bean> <bean id = "TransactionManager" class = "org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name = "dataSource" ref="dataSource"/> </bean> <!--1:配置一个JdbcTemplate实例,并将这个“共享的”,“安全的”实例注入到不同的DAO类中去--> <bean id = "jdbcTemplate" class = "org.springframework.jdbc.core.JdbcTemplate"> <property name = "dataSource" ref="dataSource"/> </bean> <bean id = "actorJdbcTemplateDao" class = "com.logcd.bo.dao.impl.ActorJdbcTemplateDaoImpl"> <property name="jdbcTemplate" ref="jdbcTemplate"/> </bean> <!--2:将共享的DataSource实例注入到DAO中,JdbcTemplate实例在DataSource的setter方法中被创建--> <bean id = "actorEventDao" class = "com.logcd.bo.dao.impl.ActorEventDaoImpl"> <property name = "dataSource" ref="dataSource"/> </bean> <!--利用了拦截器的原理。--> <bean id="transactionInterceptor" class="org.springframework.transaction.interceptor.TransactionInterceptor"> <property name="transactionManager"> <ref bean="transactionManager" /> </property> <!-- 配置事务属性 --> <property name="transactionAttributes"> <props> <prop key="delete*">PROPAGATION_REQUIRED</prop> <prop key="operate*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="insert*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="update*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="save*">PROPAGATION_REQUIRED</prop> <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop> </props> </property> </bean> <bean id="txProxy" class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"> <property name="beanNames"> <list> <value>*Dao*</value><!--只是为了测试,一般为service--> </list> </property> <property name="interceptorNames"> <list> <value>transactionInterceptor</value> </list> </property> </bean> </beans>
(2)接口:(以第二种方式定义DAO)
package com.logcd.bo.dao; import java.util.List; import org.springframework.jdbc.support.KeyHolder; import com.logcd.bo.Actor; public interface ActorEventDao { /** * 根据SQL建表 * @param sql */ public void createTableBySQL(String sql); /** * 统计firstName相同的总数 * @param firstName * @return */ public int findCountOfActorsByFirstName(String firstName); /** * 插入记录并返回自动生成的主键Id * @param ps * @return */ public KeyHolder insertActor(final Actor actor); /** * 用SimpleJdbcInsert插入一条记录:mysql测试成功 */ public long inserOneActor(Actor actor); /** * 插入/更新/删除数据 * @param sql 有参数语句 * @param obj 参数值数组 */ public int operateActor(String sql,Object[] obj); /** * 根据SQL查询记录总数 * @param sql * @return */ public int findRowCountBySQL(String sql); /** * 根据Id查找指定对象 * @param id * @return */ public Actor findActorById(long id); /** * 根据Id查找指定对象 * @param id * @return */ public Actor findActorByIdSimple(long id); /** * 返回所有对象 * @return */ public List findAllActors(); /** * 批量更新 * @param actors * @return */ public int[] updateBatchActors(final List actors); /** * 批量更新 * @param actors * @return */ public int[] updateBatchActorsSimple(final List<Actor> actors); }
(3)接口实现
package com.logcd.bo.dao.impl; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.List; import javax.sql.DataSource; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.PreparedStatementCreator; import org.springframework.jdbc.core.RowMapper; import org.springframework.jdbc.support.GeneratedKeyHolder; import org.springframework.jdbc.support.KeyHolder; import com.logcd.bo.Actor; import com.logcd.bo.dao.ActorEventDao; public class ActorEventDaoImpl implements ActorEventDao{ private JdbcTemplate jdbcTemplate; //NamedParameterJdbcTemplate对JdbcTemplate封装,增加了命名参数特性 private NamedParameterJdbcTemplate namedParameterJdbcTemplate; //SimpleJdbcTemplate对JdbcTemplate封装,某些特性要在java5以上才工作 private SimpleJdbcTemplate simpleJdbcTemplate; //简化插入数据操作 private SimpleJdbcInsert inserActor; public void setDataSource(DataSource dataSource){ this.jdbcTemplate = new JdbcTemplate(dataSource); this.namedParameterJdbcTemplate = new NamedParameterJdbcTemplate(dataSource); this.simpleJdbcTemplate = new SimpleJdbcTemplate(dataSource); this.inserActor = new SimpleJdbcInsert(dataSource) .withTableName("actors") .usingColumns("first_name","last_name")//插入这些字段 .usingGeneratedKeyColumns("id");//带回生成的id } /** * 用SimpleJdbcInsert插入一条记录 */ public long inserOneActor(Actor actor){ Map<String,Object> parameters = new HashMap<String,Object>(); parameters.put("first_name",actor.getFirstName()); parameters.put("last_name",actor.getLastName()); return inserActor.executeAndReturnKey(parameters).longValue(); } /** * 统计firstName相同的总数 * @param firstName * @return */ public int findCountOfActorsByFirstName(String firstName){ String sql="select count(0) from actors where first_name = :first_name"; SqlParameterSource namedParameters = new MapSqlParameterSource("first_name",firstName); //Map namedParameter = Collections.singletonMap("first_name",firstName); //还有一种Bean封装的方式 //SqlParameterSource namedParameters = new BeanPropertySqlParameterSource(exampleActor); return this.namedParameterJdbcTemplate.queryForInt(sql, namedParameters); } /** * 根据SQL建表 * @param sql */ public void createTableBySQL(String sql) { this.jdbcTemplate.execute(sql); } /** * 插入记录并返回自动生成的主键Id(MySQL中不行,Oracle可以) * @param ps * @return */ public KeyHolder insertActor(final Actor actor){ final String addSql = "insert into actors(first_name,last_name) values (?,?)"; KeyHolder keyHolder = new GeneratedKeyHolder(); this.jdbcTemplate.update(new PreparedStatementCreator(){ public PreparedStatement createPreparedStatement(Connection conn) throws SQLException { PreparedStatement ps = conn.prepareStatement(addSql, new String[]{"id"});//返回id ps.setString(1, actor.getFirstName()); ps.setString(2, actor.getLastName()); return ps; } }); System.out.println(keyHolder.getKey()); return keyHolder; } /** * 插入/更新/删除数据 * @param sql 有参数语句 * @param obj 参数值数组 */ public int operateActor(String sql,Object[] obj){ return this.jdbcTemplate.update(sql, obj); } /** * 根据SQL查询记录总数 * @param sql * @return */ public int findRowCountBySQL(String sql){ return this.jdbcTemplate.queryForInt(sql); } /** * 根据Id查找指定对象 * @param id * @return */ public Actor findActorById(long id){ Actor actor = (Actor) this.jdbcTemplate.queryForObject( "select id,first_name,last_name from actors where id = ?", new Object[]{new Long(id)}, new RowMapper(){ public Object mapRow(ResultSet rs, int rowNum) throws SQLException { Actor act = new Actor(); act.setId(rs.getLong("id")); act.setFirstName(rs.getString("first_name")); act.setLastName(rs.getString("last_Name")); return act; } }); return actor; } /** * 根据Id查找指定对象 * @param id * @return */ public Actor findActorByIdSimple(long id){ String sql = "select id,first_name,last_name from actors where id = ?"; ParameterizedRowMapper<Actor> mapper = new ParameterizedRowMapper<Actor>(){ //notice the return type with respect to java 5 covariant return types public Actor mapRow(ResultSet rs, int rowNum) throws SQLException { Actor act = new Actor(); act.setId(rs.getLong("id")); act.setFirstName(rs.getString("first_name")); act.setLastName(rs.getString("last_Name")); return act; } }; return this.simpleJdbcTemplate.queryForObject(sql, mapper, id); } /** * 返回所有对象 * @return */ public List findAllActors(){ return this.jdbcTemplate.query( "select id,first_name,last_name from actors", new ActorMapper()); } /** * 定义一个静态内部类,在Dao的方法中被共享 * @author logcd */ private static final class ActorMapper implements RowMapper{ public Object mapRow(ResultSet rs, int rowNum) throws SQLException { Actor act = new Actor(); act.setId(rs.getLong("id")); act.setFirstName(rs.getString("first_name")); act.setLastName(rs.getString("last_Name")); return act; } } } /** * 批量更新 * @param actors * @return */ public int[] updateBatchActors(final List actors){ int[] updateCounts =this.jdbcTemplate.batchUpdate( "update actors set first_name = ?, last_name = ? where id =? ", new BatchPreparedStatementSetter(){ public int getBatchSize() { return actors.size(); } public void setValues(PreparedStatement ps, int i) throws SQLException { ps.setString(1, ((Actor)actors.get(i)).getFirstName()); ps.setString(2, ((Actor)actors.get(i)).getLastName()); ps.setLong(3, ((Actor)actors.get(i)).getId()); } }); return updateCounts; } /** * 批量更新 * @param actors * @return */ public int[] updateBatchActorsSimple(final List<Actor> actors){ //如果对象数组与占位符出现位置一一对应 //SqlParameterSource[] batch = SqlParameterSourceUtils.createBatch(actors.toArray()); List<Object[]> batch = new ArrayList<Object[]>(); for(Actor actor:actors){ Object[] values = new Object[]{//注意顺序 actor.getFirstName(), actor.getLastName(), actor.getId()}; batch.add(values); } int[] updateCounts = this.simpleJdbcTemplate.batchUpdate( "update actors set first_name = ?, last_name = ? where id =? ", batch); return updateCounts; }
(4)测试
/** * */ package com.logcd.test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import org.springframework.jdbc.support.KeyHolder; import com.logcd.bo.Actor; import com.logcd.bo.dao.ActorEventDao; import com.logcd.bo.dao.ActorJdbcTemplateDao; import junit.framework.TestCase; /** * @author logcd */ public class SpringJdbcTest extends TestCase { private ActorEventDao actorEventDao; private ActorJdbcTemplateDao actorJdbcTemplateDao; protected void setUp() throws Exception { super.setUp(); ApplicationContext context = new ClassPathXmlApplicationContext("springJdbcContext.xml"); actorEventDao = (ActorEventDao)context.getBean("actorEventDao"); actorJdbcTemplateDao = (ActorJdbcTemplateDao)context.getBean("actorJdbcTemplateDao"); } protected void tearDown() throws Exception { super.tearDown(); } public void testActorEventDao(){ String creatSql = "create table ACTORS(" + "ID int not null auto_increment," + "FIRST_NAME varchar(15)," + "LAST_NAME varchar(15)," + "primary key (ID)" + ");" ; //建表 actorEventDao.createTableBySQL(creatSql); String addSql = "insert into actors(first_name,last_name) values(?,?);"; Object[] obj = new Object[]{"wang","jinming"}; //新增 System.out.println(actorEventDao.operateActor(addSql, obj)); String countSql = "select count(0) from actors"; System.out.println("Count:"+actorEventDao.findRowCountBySQL(countSql)); System.out.println("Count:"+actorJdbcTemplateDao.findRowCountBySQL(countSql)); //根据id查找 Actor actor = actorEventDao.findActorById(1); System.out.println("id:"+actor.getId()+" first_name:"+actor.getFirstName()+" last_name:"+actor.getLastName()); //输出所有 for(Object o:actorEventDao.findAllActors()){ Actor act = (Actor) o; System.out.println("id:"+act.getId()+" first_name:"+act.getFirstName()+" last_name:"+act.getLastName()); } Actor newAct=new Actor(); newAct.setFirstName("jin"); newAct.setLastName("ming"); KeyHolder keyHold =actorEventDao.insertActor(newAct); System.out.println(keyHold.getKey());//mysql得不到id List<Actor> list = new ArrayList<Actor>(); for(Object o:actorEventDao.findAllActors()){ Actor act = (Actor) o; System.out.println("id:"+act.getId()+" first_name:"+act.getFirstName()+" last_name:"+act.getLastName()); act.setLastName("www"); list.add(act); } actorEventDao.batchUpdateActors(list); for(Object o:actorEventDao.findAllActors()){ Actor act = (Actor) o; System.out.println("id:"+act.getId()+" first_name:"+act.getFirstName()+" last_name:"+act.getLastName()); } } }
二、关于操作Blob和Clob问题
spring定义了一个以统一的方式操作各种数据库的Lob类型数据的LobCreator(保存的时候用),同时提供了一个LobHandler为操作二进制字段和大文本字段提供统一接口访问。
(1)配置文件
<bean id="nativeJdbcExtractor" class="org.springframework.jdbc.support.nativejdbc.CommonsDbcpNativeJdbcExtractor" lazy-init="true"/> <bean id="lobHandler" class="org.springframework.jdbc.support.lob.OracleLobHandler" lazy-init="true" p:nativeJdbcExtractor-ref="nativeJdbcExtractor"/> <bean id="defaultLobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler" lazy-init="true" /> <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" p:dataSource-ref="appDS" p:nativeJdbcExtractor-ref="nativeJdbcExtractor"/> <bean id="txMangager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager" p:dataSource-ref="appDS"/> <tx:annotation-driven transaction-manager="txMangager" proxy-target-class="true"/>
(2)读写
@Resource(name = "lobHandler") private LobHandler lobHandler; @Resource(name = "jdbcTemplate") private JdbcTemplate jdbcTemplate; public void savePost(final Post post) { String sql = " INSERT INTO t_post(post_id,user_id,post_text,post_attach)" + " VALUES(?,?,?,?)"; jdbcTemplate().execute(sql, new AbstractLobCreatingPreparedStatementCallback(this.lobHandler) { protected void setValues(PreparedStatement ps, LobCreator lobCreator) throws SQLException { ps.setInt(1, incre.nextIntValue()); ps.setInt(2, post.getUserId()); lobCreator.setClobAsString(ps, 3, post.getPostText()); lobCreator.setBlobAsBytes(ps, 4, post.getPostAttach()); } }); } public List findAttachs(final int userId){ String sql = "SELECT post_id,post_attach FROM t_post where user_id =? and post_attach is not null"; return jdbcTemplate().query( sql, new Object[] {userId}, new RowMapper() { public Object mapRow(ResultSet rs, int rowNum) throws SQLException { Post post = new Post(); int postId = rs.getInt(1); byte[] attach = lobHandler.getBlobAsBytes(rs, 2); post.setPostId(postId); post.setPostAttach(attach); return post; } }); }
评论
11 楼
ruyi0127
2015-10-08
楼主代码不全,ActorJdbcTemplateDao 和 Actor 类均没有
10 楼
ruyi0127
2015-10-08
楼主没有把类ActorJdbcTemplateDao写出来。。。
9 楼
laodao278838
2013-12-27
,值得收藏!
8 楼
知了ing
2013-04-25
不错
7 楼
fkpj_bit
2011-11-03
楼主好像没有把类ActorJdbcTemplateDao写出来。。。
6 楼
银杏树
2010-10-09
收藏,必须的
5 楼
lxsgoodluck
2009-05-24
wxq594808632 写道
lxsgoodluck 写道
用GeneratedKeyHolder的地方说“MySQL中不行,Oracle可以”,是不对的,spring中isReturnGeneratedKeys默认是false, 需要setReturnGeneratedKeys(true) 方法怎么写?哪个对象调用的?
SqlUpdate及其扩展类的对象
可以看下我这里的帖子http://www.iteye.com/post/1023484
4 楼
wxq594808632
2009-05-15
lxsgoodluck 写道
用GeneratedKeyHolder的地方说“MySQL中不行,Oracle可以”,是不对的,spring中isReturnGeneratedKeys默认是false, 需要setReturnGeneratedKeys(true)
方法怎么写?哪个对象调用的?
3 楼
log_cd
2009-04-02
The basic idea is to use a SqlUpdate object, set the ReturnGeneratedKeys property to true, and then to pass in a KeyHolder object to extract the generated keys. I hope this helps anyone else using MSSQL.
For example, given the schema:
CREATE TABLE [scheduler_jobs] (
[job_id] [int] IDENTITY (1, 1) NOT NULL ,
[job_name] [varchar] (50) COLLATE SQL_Latin1_General_CP1_CI_AS NULL ,
[job_detail] [varchar] (255) COLLATE SQL_Latin1_General_CP1_CI_AS NULL ,
[class_name] [varchar] (255) NULL ,
[start] [datetime] NULL ,
[increment_millis] [bigint] NULL
) ON [PRIMARY]
use:
SqlUpdate su = new SqlUpdate();
su.setDataSource(getDataSource());
su.setSql(sql);
su.declareParameter(new SqlParameter(Types.VARCHAR));
su.declareParameter(new SqlParameter(Types.VARCHAR));
su.declareParameter(new SqlParameter(Types.VARCHAR));
su.declareParameter(new SqlParameter(Types.TIMESTAMP));
su.declareParameter(new SqlParameter(Types.BIGINT));
su.setReturnGeneratedKeys(true);
su.compile();
Object[] params = new Object[]{job.getJobName(), job.getJobDetail(), job.getClassName(), job.getStart(), new Long(job.getIncrementMillis())};
KeyHolder keyHolder = new GeneratedKeyHolder();
su.update(params,keyHolder);
int id = keyHolder.getKey().intValue();
For example, given the schema:
CREATE TABLE [scheduler_jobs] (
[job_id] [int] IDENTITY (1, 1) NOT NULL ,
[job_name] [varchar] (50) COLLATE SQL_Latin1_General_CP1_CI_AS NULL ,
[job_detail] [varchar] (255) COLLATE SQL_Latin1_General_CP1_CI_AS NULL ,
[class_name] [varchar] (255) NULL ,
[start] [datetime] NULL ,
[increment_millis] [bigint] NULL
) ON [PRIMARY]
use:
SqlUpdate su = new SqlUpdate();
su.setDataSource(getDataSource());
su.setSql(sql);
su.declareParameter(new SqlParameter(Types.VARCHAR));
su.declareParameter(new SqlParameter(Types.VARCHAR));
su.declareParameter(new SqlParameter(Types.VARCHAR));
su.declareParameter(new SqlParameter(Types.TIMESTAMP));
su.declareParameter(new SqlParameter(Types.BIGINT));
su.setReturnGeneratedKeys(true);
su.compile();
Object[] params = new Object[]{job.getJobName(), job.getJobDetail(), job.getClassName(), job.getStart(), new Long(job.getIncrementMillis())};
KeyHolder keyHolder = new GeneratedKeyHolder();
su.update(params,keyHolder);
int id = keyHolder.getKey().intValue();
2 楼
log_cd
2009-04-02
谢谢指正!
1 楼
lxsgoodluck
2009-04-02
用GeneratedKeyHolder的地方说“MySQL中不行,Oracle可以”,是不对的,spring中isReturnGeneratedKeys默认是false, 需要setReturnGeneratedKeys(true)
发表评论
-
SpringBoot开发WebService之Axis
2019-07-14 23:56 4983一、服务器端发布WebService服务 1、POM.xml文 ... -
SpringBoot开发WebService之CXF
2019-07-14 23:56 1429一、在服务器端的WebSerivce服务发布 1、POM.xm ... -
SpringBoot项目非web方式启动
2019-07-03 17:02 48391、springboot 1.x中以非web方式启动 @S ... -
SpringBoot使用Druid数据库密码加密
2019-03-06 23:28 15631、生成公钥、私钥和密码加密串 java -cp drui ... -
Spring Annotation
2010-12-02 17:14 0Spring2.x引入了组件自动扫描机制,可以在类路径底 ... -
Spring分布式事务实现
2010-11-10 14:28 83245分布式事务是指操作多个数据库之间的事务,spring的 ... -
Spring3 Annotation + Hibernate3-jpa2.0 + CGLIB + 多数据源
2010-08-19 09:30 10537一、定义一个测试用Entity。 @Entity pub ... -
使用iBatis2.0
2010-05-26 10:20 0一、NULL问题 ibatis操作oracle数据库时, ... -
使用AspectJ LTW(Load Time Weaving)
2010-01-04 14:25 10830在Java 语言中,从 ... -
Spring2.0 AOP AspectJ 注释实现
2010-01-04 14:24 5631一、AOP基本概念 切面(Aspect): 一个关注点的模块 ... -
Spring + JPA + Hibernate配置
2010-01-04 14:24 34777<1>persistence.xml放到类路径下的 ... -
配置spring数据源
2009-11-06 16:47 1272配置一个数据源 Spring在第三方依赖包中包含了两 ... -
hibernate的dialect
2009-07-23 10:04 5484一、hibernate的dialect RDBM ... -
spring ibatis入门
2009-04-20 14:16 3924一、applicationContext.xml <?x ... -
Hibernate缓存配置/批量处理
2009-03-25 21:50 11015Hibernate除了自动对Se ... -
Hibernate的一级与二级缓存
2009-03-25 21:24 1725缓存是介于应用程序和物理数据源之间,其作用是为了降低应用 ... -
Spring2.X以AspectJ 式AOP 配置事务
2008-07-10 13:23 2127(1)配置: Spring的事务管理是通过AOP代理实 ... -
spring 事务管理
2008-07-08 16:35 12041声明式的事务管理(Declarative transactio ... -
Hibernate中one-to-many/many-to-one和many-to-many
2008-06-28 17:03 3988<1>one-to-many/many-to-on ... -
Hibernate中的对象one-to-one关系
2008-06-26 22:55 2503(1) 通过主健参考,限制2个数据表中的主健使用相同的值 c ...
相关推荐
本教程将深入探讨如何使用基于注解的Spring JdbcTemplate进行数据库操作,特别适合初学者入门学习。 ### 1. Spring JdbcTemplate简介 Spring JdbcTemplate提供了一个面向对象的接口,用于执行SQL查询、更新和存储...
在这个实例工程中,我们将深入探讨Spring JdbcTemplate的基本使用、优势以及常见操作。 一、Spring JdbcTemplate简介 Spring JdbcTemplate的出现是为了弥补原生JDBC在编码上的繁琐,它通过模板方法模式,将SQL执行...
SpringJdbcTemplate能够自适应多种数据库,这是因为它的底层使用了JDBC的规范,而不同的数据库厂商都实现了JDBC API。这使得你可以使用相同的代码来连接MySQL、Oracle、PostgreSQL等不同类型的数据库,只需更换相应...
Struts2、Spring和Spring JDBC Template是Java Web开发中常用的三个框架,它们分别负责不同的职责。Struts2作为MVC(Model-View-Controller)框架,主要处理前端请求和业务逻辑;Spring则是一个全面的后端框架,提供...
`JdbcUtils.java`可能是提供了一些数据库连接和JdbcTemplate使用的辅助方法,如数据库连接池的配置,或者封装了JdbcTemplate的执行方法,以提高代码复用性。例如: ```java public class JdbcUtils { private ...
这样,整个应用就可以通过Spring的依赖注入机制来获取并使用JdbcTemplate实例。 例如,一个简单的`applicationContext.xml`配置片段可能如下: ```xml <bean id="dataSource" class="org.springframework.jdbc....
总之,Spring JDBCTemplate结合连接池提供了一个高效且易于使用的数据库访问层,它降低了数据库操作的复杂性,同时也提升了系统的性能。正确配置和使用这些库,可以极大地优化我们的数据库应用程序。
使用 Spring JdbcTemplate 调用 Oracle 存储过程实现 CRUD 在本文中,我们将讨论如何使用 Spring JdbcTemplate 调用 Oracle 存储过程来实现 CRUD(Create、Read、Update、Delete)操作。我们将首先编写 Oracle 存储...
JdbcTemplate使用PreparedStatement来执行SQL,自动防止SQL注入攻击,因为它会正确地转义参数值。 7. 错误处理 如果数据库操作失败,JdbcTemplate会抛出异常,如`DataAccessException`,使得我们可以快速定位并处理...
**Spring JdbcTemplate 使用指南** Spring框架中的JdbcTemplate是数据库操作的核心组件之一,它提供了一种简单、安全的方式来执行SQL查询和更新,而无需手动管理数据库连接。本指南将深入探讨JdbcTemplate的用法,...
使用Spring的JdbcTemplate实现分页功能
Spring JdbcTemplate是Spring框架中用于简化数据库操作的一个重要组件,它是Spring对JDBC的轻量级封装,旨在提供一种结构良好、易于使用的SQL执行机制,同时保持了JDBC的灵活性。在本实例中,我们将深入探讨Spring ...
在本例中,我们将深入探讨Spring JdbcTemplate的工作原理、使用方式以及它的优点。 首先,JdbcTemplate的核心理念是通过预编译的SQL语句和参数绑定来防止SQL注入攻击,同时提供事务管理的支持。它提供了大量方法来...
模仿spring jdbcTemplate的粗略实现,只有很小的参考价值,如果是java初学者可以使用这个封装好的工具进行数据库操作,只需要在db.properties里配置好driver,url等信息
spring JdbcTemplate query方法使用示例,欢迎下载借鉴
在Spring框架中,`JdbcTemplate`是一个用于简化JDBC编程的工具类,它采用了模板模式来分离数据库访问中的不变和可变部分,提供了一种更加健壮且易于使用的数据访问机制。`JdbcTemplate`负责处理资源的获取、关闭以及...
在Spring框架中,`JdbcTemplate`是用于简化Java数据库连接(JDBC)操作的一个核心组件。这个类提供了很多方法来执行SQL查询、更新语句,包括批处理操作。本篇文章将详细探讨`batchUpdate`方法及其在实际开发中的应用...
使用Spring的JdbcTemplate调用Oracle的存储过程
配制Spring事务和JdbcTemplate使用 配制Spring事务和JdbcTemplate使用
本篇将深入探讨Spring JDBCTemplate的使用及其源码解析,帮助你理解其背后的机制。 首先,让我们了解在不使用JDBCTemplate时,传统的JDBC操作通常涉及以下步骤:加载驱动、建立数据库连接、创建Statement或...