当前位置:  编程技术>java/j2ee

spring的jdbctemplate的crud的基类dao

    来源: 互联网  发布时间:2014-11-02

    本文导语:  代码如下:import java.util.List; /*** * 基本接口 *  * @author xyq * @param  *  */public interface BaseDaoInf {  /***  * 查询接口  *   * @return  */ public List find(String sql, Object[] parameters, Class cl); /***  *  添加,更新,删除接口  * @param sql  * @p...

代码如下:

import java.util.List;

/***
 * 基本接口
 *
 * @author xyq
 * @param
 *
 */
public interface BaseDaoInf {

 /***
  * 查询接口
  *
  * @return
  */
 public List find(String sql, Object[] parameters, Class cl);

 /***
  *  添加,更新,删除接口
  * @param sql
  * @param id
  * @param cl
  * @return
  */
 public int addOrUpdateOrDelete(String sql,Object[] parameters, Class cl);
}

代码如下:

import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.List;

import javax.annotation.Resource;

import org.springframework.jdbc.core.BeanPropertyRowMapper;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.PreparedStatementSetter;

import com.xyq.all.dao.inf.BaseDaoInf;

public class BaseDaoImpl implements BaseDaoInf {

 /**
  *
  */
 private static final long serialVersionUID = 1L;
 /***
  * 数据库连接对象
  */
 @Resource(name = "jdbcTemplate")
 private JdbcTemplate jt;

 /***
  * 查询接口
  */

 @Override
 public List find(String sql, Object[] parameters, Class cl) {

  List resultList = null;
  try {
   if (parameters != null && parameters.length > 0)
    resultList = jt.query(sql, parameters,
      new BeanPropertyRowMapper(cl));
   else
    // BeanPropertyRowMapper是自动映射实体类的
    resultList = jt.query(sql, new BeanPropertyRowMapper(cl));
  } catch (Exception e) {
   e.printStackTrace();
  }
  return resultList;
 }

 /***
  * 添加,更新,删除的实现,返回1,0,-1
  */
 @Override
 public int addOrUpdateOrDelete(String sql, final Object[] parameters,
   Class cl) {

  int num = 0;
  try {
   if (parameters == null || parameters.length == 0)
    num = jt.update(sql);
   else
    num = jt.update(sql, new PreparedStatementSetter() {

     @Override
     public void setValues(PreparedStatement ps)
       throws SQLException {

      for (int i = 0; i < parameters.length; i++)
       ps.setObject(i + 1, parameters[i]);
     }
    });
  } catch (Exception e) {
   e.printStackTrace();
   num = -1;
  }
  return num;
 }
}

代码如下:

/**
 * 用户操作接口
 * @author xyq
 *
 */
public interface UserInfoDaoInf {

 /***
  * 查询是否有用户
  * @param user
  * @return
  */
 public UserInfo findUser(UserInfo user);

 /***
  * 删除用户
  * @param user
  * @return
  */
 public int deleteUserById(UserInfo user);

 /***
  * 添加用户
  * @param user
  * @return
  */
 public int addUser(UserInfo user);

 /***
  * 更新用户
  * @param user
  * @return
  */
 public int updateUser(UserInfo user);
}

代码如下:

import java.util.List;

import org.springframework.stereotype.Repository;

import com.xyq.all.dao.inf.UserInfoDaoInf;
import com.xyq.all.entity.UserInfo;

@Repository("userDao")
public class UserInfoDaoImpl extends BaseDaoImpl implements
  UserInfoDaoInf {


 /***
  * 查找用户信息
  */
 @Override
 public UserInfo findUser(UserInfo user) {

  List list = null;
  String sql = "select * from userInfo where username=? and password =? ";
  list = super.find(sql,
    new String[] { user.getUserName(), user.getPassword() },
    UserInfo.class);
  if (list != null && list.size() > 0)
   return list.get(0);
  return null;
 }

 /***
  * 删除用户
  */
 @Override
 public int deleteUserById(UserInfo user) {

  String sql = "delete from userInfo where userid = ?";
  return super.addOrUpdateOrDelete(sql, new Integer[] { user.getUserId() },
    UserInfo.class);
 }

 /***
  * 添加用户
  */
 @Override
 public int addUser(UserInfo user) {

  String sql = "insert into userInfo values(null,?,?,?)";

  return super.addOrUpdateOrDelete(
    sql,
    new Object[] { user.getUserName(), user.getPassword(),
      user.getSecondPassword() }, UserInfo.class);
 }

 /***
  * 更新用户
  */
 @Override
 public int updateUser(UserInfo user) {

  String sql = "update userInfo set userName=?,password = ?,secondPassword = ? where userid=?";
  return super.addOrUpdateOrDelete(
    sql,
    new Object[] { user.getUserName(), user.getPassword(),
      user.getSecondPassword(), user.getUserId() },
    UserInfo.class);
 }


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • java命名空间javax.swing类spring的类成员方法: minus定义及介绍
  • 论坛 iis7站长之家
  • java命名空间javax.swing类spring的类成员方法: max定义及介绍
  • Spring社交扩展框架 Spring Social
  • java命名空间javax.swing类spring的类成员方法: unset定义及介绍
  • Spring 同步解决方案 Spring Sync
  • java命名空间javax.swing类spring的类成员方法: constant定义及介绍
  • 可视化Spring开发插件 Spring IDE
  • java命名空间javax.swing类spring的类成员方法: scale定义及介绍
  • Spring远程服务编程框架 Spring Remoting
  • java命名空间javax.swing类spring的类成员方法: getpreferredvalue定义及介绍
  • Spring安全框架 Spring Security
  • java命名空间javax.swing类spring的类成员方法: getmaximumvalue定义及介绍
  • 读取spring配置文件的方法(spring读取资源文件)
  • java命名空间javax.swing类spring的类成员方法: sum定义及介绍
  • Spring Tool Suite
  • java命名空间javax.swing类spring的类成员方法: getvalue定义及介绍
  • Spring4Me
  • java命名空间javax.swing类spring的类成员方法: width定义及介绍
  • spring-all
  • java命名空间javax.swing类spring的类成员方法: height定义及介绍
  • Spring Workflow


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3