-
package
hysteria.contact.dao.impl;
-
-
import
java.sql.ResultSet;
-
import
java.sql.SQLException;
-
import
java.sql.Types;
-
import
java.util.List;
-
-
import
org.springframework.jdbc.core.JdbcTemplate;
-
import
org.springframework.jdbc.core.<SPAN
class
=hilite1>RowMapper</SPAN>;
-
-
import
hysteria.contact.dao.ItemDAO;
-
import
hysteria.contact.domain.Item;
-
-
public
class
ItemDAOImpl
implements
ItemDAO {
-
private
JdbcTemplate jdbcTemplate;
-
-
public
void
setJdbcTemplate(JdbcTemplate jdbcTemplate) {
-
this
.jdbcTemplate = jdbcTemplate;
-
}
-
-
public
Item insert(Item item) {
-
String sql =
"INSERT INTO items(user_id,name,phone,email) VALUES(?,?,?,?)"
;
-
Object[] params =
new
Object[]{item.getUserId(),item.getName(),item.getPhone(),item.getEmail()};
-
int
[] types =
new
int
[]{Types.INTEGER,Types.VARCHAR,Types.CHAR,Types.VARCHAR};
-
jdbcTemplate.update(sql,params,types);
-
return
item;
-
}
-
-
public
Item update(Item item) {
-
String sql =
"UPDATE items SET name = ?, phone = ?, email = ? WHERE id = ?"
;
-
Object[] params =
new
Object[] {item.getName(),item.getPhone(),item.getEmail(),item.getId()};
-
int
[] types =
new
int
[] {Types.VARCHAR,Types.CHAR,Types.VARCHAR,Types.VARCHAR,Types.INTEGER};
-
jdbcTemplate.update(sql,params,types);
-
-
return
item;
-
}
-
-
public
void
delete(Item item) {
-
String sql =
"DELETE FROM items WHERE id = ?"
;
-
Object[] params =
new
Object[] {item.getId()};
-
int
[] types =
new
int
[]{Types.INTEGER};
-
jdbcTemplate.update(sql,params,types);
-
}
-
-
public
Item findById(
int
id) {
-
String sql =
"SELECT * FROM items WHERE id = ?"
;
-
Object[] params =
new
Object[] {id};
-
int
[] types =
new
int
[] {Types.INTEGER};
-
List items = jdbcTemplate.query(sql,params,types,
new
ItemMapper());
-
if
(items.isEmpty()){
-
return
null
;
-
}
-
return
(Item)items.get(
0
);
-
}
-
-
public
List<Item> findAll() {
-
String sql =
"SELECT * FROM items"
;
-
return
jdbcTemplate.query(sql,
new
ItemMapper());
-
}
-
-
-
public
List<Item> findAllByUser(
int
user_id) {
-
String sql =
"SELECT * FROM items WHERE user_id = ?"
;
-
Object[] params =
new
Object[]{user_id};
-
int
[] types =
new
int
[]{Types.INTEGER};
-
List items = jdbcTemplate.query(sql,params,types,
new
ItemMapper());
-
return
items;
-
}
-
-
protected
class
ItemMapper
implements
<SPAN
class
=hilite1>RowMapper</SPAN> {
-
-
public
Object mapRow(ResultSet rs,
int
rowNum)
throws
SQLException {
-
Item item =
new
Item();
-
item.setId(rs.getInt(
"id"
));
-
item.setUserId(rs.getInt(
"user_id"
));
-
item.setName(rs.getString(
"name"
));
-
item.setPhone(rs.getString(
"phone"
));
-
item.setEmail(rs.getString(
"email"
));
-
-
return
item;
-
}
-
-
}
-
-
-
}
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
第二个案例
package com.flmusic.cu.dao.jdbc;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import org.springframework.jdbc.core.PreparedStatementCallback;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.support.JdbcDaoSupport;
import com.flmusic.cu.compere.CompereInfoBean;
import com.flmusic.cu.dao.CommendCompereDAO;
public class CommendCompereDAOJdbcImpl extends JdbcDaoSupport implements CommendCompereDAO{
/**
* 新增推荐主持人 状态:0--未审核;1--审核
* @param userId
*/
public void addCommendCompere(final Integer userId){
StringBuffer sql = new StringBuffer(200);
//新增推荐主持人
sql.append("insert into u_commend_compere_info(I64UserID,status) values(?,0)");
this.getJdbcTemplate().execute(sql.toString(),new PreparedStatementCallback(){
public Object doInPreparedStatement(PreparedStatement ps)throws SQLException {
ps.setInt(1, userId);
ps.execute();
return null;
}
});
//更新推荐状态--已推荐(1)
updateCommendFlag(userId,1);
}
/**
* 查询推荐主持人列表
* @return
*/
public List findCommendCompereList(Integer agentId){
StringBuffer sql = new StringBuffer(200);
sql.append("select uc.compereName,uc.ilevel,com.I64UserID,com.status,a.agentName ");
sql.append(" from u_commend_compere_info com ,u_compere_info uc left join webcu.dbo.agent a on uc.agentId=a.agentId ");
sql.append("where com.I64UserID = uc.I64UserID ");
if (agentId != null){
sql.append(" and uc.agentId=").append(agentId);
}
List<CompereInfoBean> list = this.getJdbcTemplate().query(sql.toString(), new RowMapper(){
public Object mapRow(ResultSet rs,int index) throws SQLException{
CompereInfoBean bean = new CompereInfoBean();
bean.setUserId(rs.getInt("I64UserID"));
bean.setCompereName(rs.getString("compereName"));
bean.setLevel(rs.getInt("ilevel"));
bean.setCommendStatus(rs.getInt("status"));
bean.setAgentName(rs.getString("agentName"));
return bean;
}
});
return list;
}
/**
* 更新推荐状态
* @param userId
* @param flag
*/
private void updateCommendFlag(final Integer userId,final int flag){
//更新主持人的是否推荐状态
StringBuffer sql = new StringBuffer(200);
sql.append("update u_compere_info set commendFlag=? where I64UserID=?");
this.getJdbcTemplate().execute(sql.toString(),new PreparedStatementCallback(){
public Object doInPreparedStatement(PreparedStatement ps)throws SQLException {
ps.setInt(1, flag);
ps.setInt(2, userId);
ps.execute();
return null;
}
});
}
/**
* 根据室主Id查询主持人对象列表
*
*
*/
public List findCommendCompereListByHostId(Integer hostId) {
// TODO Auto-generated method stub
StringBuffer sql = new StringBuffer(200);
sql.append("select a.I64UserID,a.compereName,a.iLevel from flMusicUserDB.dbo.u_compere_info a ");
sql.append(" where a.compereNumber in (select compereNumber from RoomDB.dbo.Host_Compere_Mapping where hostNumber="+hostId+") ");
List<CompereInfoBean> list = this.getJdbcTemplate().query(sql.toString(), new RowMapper(){
public Object mapRow(ResultSet rs,int index) throws SQLException{
CompereInfoBean bean = new CompereInfoBean();
bean.setUserId(rs.getInt("I64UserID"));
bean.setCompereName(rs.getString("compereName"));
bean.setLevel(rs.getInt("ilevel"));
return bean;
}
});
return list;
}}
分享到:
相关推荐
本文将深入探讨Spring JdbcTemplate的常用方法,并结合提供的`JsonBean.java`和`JdbcUtils.java`文件,来理解其在实际应用中的使用。 首先,JdbcTemplate的核心功能在于它提供了一系列的方法来执行SQL语句,包括...
在本实例中,我们将深入探讨Spring JdbcTemplate的查询功能及其在实际应用中的使用。 首先,Spring JdbcTemplate通过提供一系列的模板方法,如`queryForList`、`queryForObject`、`execute`等,使得执行SQL查询变得...
在本文中,我们将讨论如何使用 Spring JdbcTemplate 调用 Oracle 存储过程来实现 CRUD(Create、Read、Update、Delete)操作。我们将首先编写 Oracle 存储过程,然后编写 Java 代码使用 Spring JdbcTemplate 调用...
1. **JdbcTemplate对象**:这是Spring JdbcTemplate的核心,它包含了执行SQL语句的所有方法,如update()用于更新,query()用于查询,insert()用于插入等。 2. **参数绑定**:JdbcTemplate支持多种方式的参数绑定,...
SpringJdbcTemplate是Spring框架中用于简化Java数据库访问的工具,它是Spring JDBC模块的核心。这个封装工具类的出现是为了提供一种更简洁、易于使用的接口来执行SQL操作,减轻开发者处理数据库连接、事务管理以及...
Spring JdbcTemplate提供了一个面向对象的接口,用于执行SQL查询、更新和存储过程,避免了直接与JDBC API打交道的繁琐工作。它通过异常处理、事务管理以及结果集的自动处理,简化了数据库访问。基于注解的Spring ...
Spring 框架 JdbcTemplate 类中查询方法介绍 JdbcTemplate 是 Spring 框架中 org.springframework.jdbc.core 包提供的 JDBC 模板类,它是核心类,其他模板类都是基于它封装完成的。JdbcTemplate 类主要提供四类方法...
使用Spring的JdbcTemplate实现分页功能
spring JdbcTemplate query方法使用示例,欢迎下载借鉴
模仿spring jdbcTemplate的粗略实现,只有很小的参考价值,如果是java初学者可以使用这个封装好的工具进行数据库操作,只需要在db.properties里配置好driver,url等信息
**Spring JdbcTemplate**是Spring框架中的一个核心组件,主要用于简化Java数据库访问。它提供了一种模板化的方式来执行SQL语句,使得开发人员可以避免编写大量的重复代码,专注于业务逻辑,而不是底层的数据库交互...
在Spring JDBCTemplate中,连接池扮演着关键角色。连接池管理数据库连接,确保在需要时可以快速提供一个已建立的连接,而不是每次都新建。这在高并发环境下尤其重要,因为它减少了数据库连接创建和关闭的开销。...
Spring JdbcTemplate是Spring框架中的一个核心组件,主要用来简化数据库操作。它提供了一种模板方法设计模式,将SQL语句的执行与结果处理进行了抽象,使得开发者可以更加专注于业务逻辑,而无需关心底层数据访问的...
### Spring中的JdbcTemplate #### JdbcTemplate概述 JdbcTemplate是Spring框架提供的一种用于简化JDBC编程的对象。通过封装原生的JDBC API,JdbcTemplate不仅提高了代码的可读性和可维护性,还帮助开发者避免了...
值得注意的是,虽然有文档提到`JdbcTemplate`提供了`execute(String sql, Object[] params)`方法,但实际上在Spring 2.x版本中并不存在这样的方法签名。 #### 批量更新 当需要进行批量更新操作时,`JdbcTemplate`...
spring 中对大数据的处理,包括clob,blob的数据。比之jdbc下简便很多。
Struts2、Spring和Spring JDBC Template是Java Web开发中常用的三个框架,它们分别负责不同的职责。Struts2作为MVC(Model-View-Controller)框架,主要处理前端请求和业务逻辑;Spring则是一个全面的后端框架,提供...
在Spring框架中,JdbcTemplate是用于简化数据库操作的重要工具,它是Spring JDBC模块的一部分。通过使用JdbcTemplate,开发者可以避免编写大量的重复代码,如手动管理连接、处理结果集等,从而专注于业务逻辑。本文...
在Spring中,JdbcTemplate就是一个典型的模板类,它实现了数据库操作的基本流程,如创建Connection、PreparedStatement、处理结果集等。用户可以通过扩展或自定义模板方法来实现特定的数据库操作逻辑。 **3. 回调...
3. **结果集处理**:对于查询操作,JdbcTemplate可以将结果集映射到Java对象,这通常通过实现RowMapper接口或使用BeanPropertyRowMapper类来完成。RowMapper允许自定义对象映射逻辑,而BeanPropertyRowMapper则会...