package com.yan.dao;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import com.yan.domain.UserBean;
import com.yan.utils.DBConn;
public class UserDaoImpl implements IUserDao {
private Connection conn = null;
public List<UserBean> getByExample(UserBean userBean, int... params)
throws Exception {
List<UserBean> res = new ArrayList<UserBean>();
conn = DBConn.getConnection();
String sql = this.getUserSql(userBean);
PreparedStatement ps = conn.prepareStatement(sql,
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
ResultSet rs = ps.executeQuery();
if (!rs.next()) {
return res;
}
if (params != null && params.length > 0) {
rs.absolute(params[0]);
}
int k = 0;
do {
if (params != null && params.length > 1) {
if (++k > params[1])
break;
}
UserBean ub = new UserBean();
ub = this.getUserBean(rs);
res.add(ub);
} while (rs.next());
DBConn.closeConnection();
return res;
}
public int getAllRowsNum(UserBean userBean) throws Exception {
String sql = "select count(*)"
+ this.getUserSql(userBean).substring(
this.getUserSql(userBean).indexOf("from"));
conn = DBConn.getConnection();
PreparedStatement ps = conn.prepareStatement(sql);
ResultSet rs = ps.executeQuery();
int a = 0;
if (rs.next()) {
a = rs.getInt(1);
}
DBConn.closeConnection();
return a;
}
public List<UserBean> checkUser(UserBean userBean) throws Exception {
List<UserBean> res = new ArrayList<UserBean>();
conn = DBConn.getConnection();
String sql = "select * from users where username=? and password=?";
if (conn != null) {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, userBean.getUsername());
ps.setString(2, userBean.getPassword());
ResultSet rs = ps.executeQuery();
if (rs.next()) {
UserBean ub = new UserBean();
ub.setId(rs.getInt("id"));
ub.setUsername(rs.getString("username"));
ub.setPassword(rs.getString("password"));
res.add(ub);
}
}
DBConn.getConnection();
return res;
}
public boolean userInsert(UserBean userBean) throws Exception {
boolean bb = false;
String sql = "insert into users(username,password,name,sex) values(?,?,?,?)";
conn = DBConn.getConnection();
if (conn != null) {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, userBean.getUsername());
ps.setString(2, userBean.getPassword());
ps.setString(3, userBean.getName());
ps.setBoolean(4, userBean.getSex());
int row = ps.executeUpdate();
if (row > 0) {
bb = true;
} else {
bb = false;
}
}
DBConn.closeConnection();
return bb;
}
public List<UserBean> LoadById(int id) throws Exception {
conn = DBConn.getConnection();
List<UserBean> res = new ArrayList<UserBean>();
String sql = "select * from users where id=?";
if (conn != null) {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, id);
ResultSet rs = ps.executeQuery();
if (rs.next()) {
UserBean ub = new UserBean();
ub.setId(id);
ub.setUsername(rs.getString("username"));
ub.setPassword(rs.getString("password"));
ub.setName(rs.getString("name"));
ub.setSex(rs.getBoolean("sex"));
ub.setRegdate(rs.getDate("regdate"));
res.add(ub);
}
}
DBConn.closeConnection();
return res;
}
public boolean userUpdate(UserBean userBean) throws Exception {
conn = DBConn.getConnection();
String sql = "update users set password=?,name=?,sex=? where id=?";
boolean bb = false;
if (conn != null) {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, userBean.getPassword());
ps.setString(2, userBean.getName());
ps.setBoolean(3, userBean.getSex());
ps.setInt(4, userBean.getId());
int row = ps.executeUpdate();
if (row > 0) {
bb = true;
} else {
bb = false;
}
}
DBConn.closeConnection();
return bb;
}
public boolean userDelete(int id) throws Exception {
boolean bb = false;
conn = DBConn.getConnection();
String sql = "delete from users where id=?";
if (conn != null) {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, id);
int row = ps.executeUpdate();
if (row > 0) {
bb = true;
} else {
bb = false;
}
}
DBConn.closeConnection();
return bb;
}
private String getUserSql(UserBean userBean) throws Exception {
StringBuffer sb = new StringBuffer("select * from users where 1=1");
if (null != userBean) {
if (userBean.getId() != null) {
sb.append(" and id=" + userBean.getId());
}
if (userBean.getUsername() != null
&& !"".equals(userBean.getUsername())) {
sb.append(" and username='" + userBean.getUsername() + "'");
}
if (userBean.getPassword() != null
&& !"".equals(userBean.getPassword())) {
sb.append(" and password='" + userBean.getPassword() + "'");
}
if (userBean.getName() != null && !"".equals(userBean.getName())) {
sb.append(" and name='" + userBean.getName() + "'");
}
if (userBean.getSex() != null && !"".equals(userBean.getSex())) {
sb.append(" and sex='" + userBean.getSex() + "'");
}
if (userBean.getRegdate() != null
&& !"".equals(userBean.getRegdate())) {
sb.append(" and regdate='" + userBean.getRegdate() + "'");
}
}
return sb.toString();
}
private UserBean getUserBean(ResultSet rs) throws Exception {
UserBean userBean = new UserBean();
userBean.setId(rs.getInt("id"));
userBean.setUsername(rs.getString("username"));
userBean.setPassword(rs.getString("password"));
userBean.setName(rs.getString("name"));
userBean.setSex(rs.getBoolean("sex"));
userBean.setRegdate(rs.getDate("regdate"));
return userBean;
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
JAVA的Struts2完整项目版(源码+数据库)
共54个文件
jar:11个
class:10个
java:10个
4星 · 超过85%的资源 需积分: 23 726 下载量 188 浏览量
2010-11-08
11:10:12
上传
评论 23
收藏 5.93MB RAR 举报
温馨提示
这是自己用Struts2框架写的一个完整的管理系统 里面包含了 用户的增删改查 登录 效验 后台 前台 分页 条件查询等功能 对做项目的很有帮助代码干净定义规范 可直接拿去用 希望对你带来大的帮助
资源推荐
资源详情
资源评论
收起资源包目录
Struts2增删改查(完整项目版+源码+数据库).rar (54个子文件)
Struts2用户登录增删改查(完整)
dd
.project 1KB
.settings
.jsdtscope 500B
org.eclipse.wst.jsdt.ui.superType.container 49B
org.eclipse.wst.jsdt.ui.superType.name 6B
.mymetadata 279B
WebRoot
success.jsp 721B
WEB-INF
web.xml 904B
lib
freemarker-2.3.13.jar 850KB
log4j-1.2.15.jar 383KB
struts2-dojo-plugin-2.1.6.jar 1.65MB
sqljdbc.jar 227KB
ognl-2.6.11.jar 164KB
commons-logging-1.0.4.jar 37KB
xwork-2.1.2.jar 2.18MB
commons-beanutils-1.7.0.jar 184KB
struts2-core-2.1.6.jar 719KB
commons-fileupload-1.2.1.jar 56KB
commons-io-1.3.2.jar 86KB
classes
log4j.properties 202B
com
yan
biz
IUserServ.class 586B
UserServImpl.class 3KB
utils
ServFactory.class 417B
DaoFactory.class 411B
DBConn.class 1KB
actions
UserAction.class 6KB
dao
UserDaoImpl.class 7KB
IUserDao.class 784B
domain
UserBean.class 2KB
PageBean.class 2KB
struts.xml 2KB
struts-2.1.dtd 4KB
index.jsp 1KB
Copy.jsp 377B
update_user.jsp 3KB
META-INF
MANIFEST.MF 39B
add_user.jsp 4KB
error.jsp 530B
show_user.jsp 2KB
.myeclipse
src
log4j.properties 202B
com
yan
biz
UserServImpl.java 2KB
IUserServ.java 541B
utils
ServFactory.java 200B
DBConn.java 766B
DaoFactory.java 190B
actions
UserAction.java 4KB
dao
UserDaoImpl.java 6KB
IUserDao.java 600B
domain
PageBean.java 1KB
UserBean.java 1KB
struts.xml 2KB
struts-2.1.dtd 4KB
.classpath 1KB
datebase
test_Data.MDF 1024KB
test_Log.LDF 1024KB
共 54 条
- 1
micyo202
- 粉丝: 1
- 资源: 5
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Screenshot_20240427_031602.jpg
- 网页PDF_2024年04月26日 23-46-14_QQ浏览器网页保存_QQ浏览器转格式(6).docx
- 直接插入排序,冒泡排序,直接选择排序.zip
- 在排序2的基础上,再次对快排进行优化,其次增加快排非递归,归并排序,归并排序非递归版.zip
- 实现了7种排序算法.三种复杂度排序.三种nlogn复杂度排序(堆排序,归并排序,快速排序)一种线性复杂度的排序.zip
- 冒泡排序 直接选择排序 直接插入排序 随机快速排序 归并排序 堆排序.zip
- 课设-内部排序算法比较 包括冒泡排序、直接插入排序、简单选择排序、快速排序、希尔排序、归并排序和堆排序.zip
- Python排序算法.zip
- C语言实现直接插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序、归并排序、计数排序,并带图详解.zip
- 常用工具集参考用于图像等数据处理
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
- 1
- 2
- 3
- 4
- 5
- 6
前往页