package com.java1234.dao;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import com.java1234.model.Diary;
import com.java1234.model.PageBean;
import com.java1234.util.DateUtil;
import com.java1234.util.StringUtil;
/**
* 日记DAO类
* @author
*
*/
public class DiaryDao {
/**
* 日记列表
* @param con 数据库连接
* @param pageBean 分页
* @param s_diary 日记实体
* @return
* @throws Exception
*/
public List<Diary> diaryList(Connection con,PageBean pageBean,Diary s_diary)throws Exception{
List<Diary> diaryList=new ArrayList<Diary>();
StringBuffer sb=new StringBuffer("select * from t_diary t1,t_diaryType t2 where t1.typeId=t2.diaryTypeId ");
if(StringUtil.isNotEmpty(s_diary.getTitle())){
sb.append(" and t1.title like '%"+s_diary.getTitle()+"%'");
}
if(s_diary.getTypeId()!=-1){
sb.append(" and t1.typeId="+s_diary.getTypeId());
}
if(StringUtil.isNotEmpty(s_diary.getReleaseDateStr())){
sb.append(" and DATE_FORMAT(t1.releaseDate,'%Y年%m月')='"+s_diary.getReleaseDateStr()+"'");
}
sb.append(" order by t1.releaseDate desc");
if(pageBean!=null){
sb.append(" limit "+pageBean.getStart()+","+pageBean.getPageSize());
}
PreparedStatement pstmt=con.prepareStatement(sb.toString());
ResultSet rs=pstmt.executeQuery();
while(rs.next()){
Diary diary=new Diary();
diary.setDiaryId(rs.getInt("diaryId"));
diary.setTitle(rs.getString("title"));
diary.setContent(rs.getString("content"));
diary.setReleaseDate(DateUtil.formatString(rs.getString("releaseDate"), "yyyy-MM-dd HH:mm:ss"));
diaryList.add(diary);
}
return diaryList;
}
/**
* 获取日记数量
* @param con 数据库连接
* @param s_diary 日记实体
* @return
* @throws Exception
*/
public int diaryCount(Connection con,Diary s_diary)throws Exception{
StringBuffer sb=new StringBuffer("select count(*) as total from t_diary t1,t_diaryType t2 where t1.typeId=t2.diaryTypeId ");
if(StringUtil.isNotEmpty(s_diary.getTitle())){
sb.append(" and t1.title like '%"+s_diary.getTitle()+"%'");
}
if(s_diary.getTypeId()!=-1){
sb.append(" and t1.typeId="+s_diary.getTypeId());
}
if(StringUtil.isNotEmpty(s_diary.getReleaseDateStr())){
sb.append(" and DATE_FORMAT(t1.releaseDate,'%Y年%m月')='"+s_diary.getReleaseDateStr()+"'");
}
PreparedStatement pstmt=con.prepareStatement(sb.toString());
ResultSet rs=pstmt.executeQuery();
if(rs.next()){
return rs.getInt("total");
}else{
return 0;
}
}
/**
* 根据月份统计日记数量
* @param con
* @return
* @throws Exception
*/
public List<Diary> diaryCountList(Connection con)throws Exception{
List<Diary> diaryCountList=new ArrayList<Diary>();
String sql="SELECT DATE_FORMAT(releaseDate,'%Y年%m月') as releaseDateStr ,COUNT(*) AS diaryCount FROM t_diary GROUP BY DATE_FORMAT(releaseDate,'%Y年%m月') ORDER BY DATE_FORMAT(releaseDate,'%Y年%m月') DESC;";
PreparedStatement pstmt=con.prepareStatement(sql);
ResultSet rs=pstmt.executeQuery();
while(rs.next()){
Diary diary=new Diary();
diary.setReleaseDateStr(rs.getString("releaseDateStr"));
diary.setDiaryCount(rs.getInt("diaryCount"));
diaryCountList.add(diary);
}
return diaryCountList;
}
/**
* 根据日记id获取日记
* @param con 数据库连接
* @param diaryId 日记id
* @return
* @throws Exception
*/
public Diary diaryShow(Connection con,String diaryId)throws Exception{
String sql="select * from t_diary t1,t_diaryType t2 where t1.typeId=t2.diaryTypeId and t1.diaryId=?";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, diaryId);
ResultSet rs=pstmt.executeQuery();
Diary diary=new Diary();
if(rs.next()){
diary.setDiaryId(rs.getInt("diaryId"));
diary.setTitle(rs.getString("title"));
diary.setContent(rs.getString("content"));
diary.setTypeId(rs.getInt("typeId"));
diary.setTypeName(rs.getString("typeName"));
diary.setReleaseDate(DateUtil.formatString(rs.getString("releaseDate"),"yyyy-MM-dd HH:mm:ss"));
}
return diary;
}
/**
* 添加日记
* @param con 数据库连接
* @param diary 日记实体
* @return
* @throws Exception
*/
public int diaryAdd(Connection con,Diary diary)throws Exception{
String sql="insert into t_diary values(null,?,?,?,now())";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, diary.getTitle());
pstmt.setString(2, diary.getContent());
pstmt.setInt(3, diary.getTypeId());
return pstmt.executeUpdate();
}
/**
* 删除日记
* @param con 数据库连接
* @param diaryId 日记id
* @return
* @throws Exception
*/
public int diaryDelete(Connection con,String diaryId)throws Exception{
String sql="delete from t_diary where diaryId=?";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, diaryId);
return pstmt.executeUpdate();
}
/**
* 日记更新
* @param con 数据库连接
* @param diary 日记实体对象
* @return
* @throws Exception
*/
public int diaryUpdate(Connection con,Diary diary)throws Exception{
String sql="update t_diary set title=?,content=?,typeId=? where diaryId=?";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, diary.getTitle());
pstmt.setString(2, diary.getContent());
pstmt.setInt(3, diary.getTypeId());
pstmt.setInt(4, diary.getDiaryId());
return pstmt.executeUpdate();
}
/**
* 根据日记类别id判断是否有日记
* @param con 数据库连接
* @param typeId 日记类别id
* @return
* @throws Exception
*/
public boolean existDiaryWithTypeId(Connection con,String typeId)throws Exception{
String sql="select * from t_diary where typeId=?";
PreparedStatement pstmt=con.prepareStatement(sql);
pstmt.setString(1, typeId);
ResultSet rs=pstmt.executeQuery();
if(rs.next()){
return true;
}else{
return false;
}
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
Java源码通常是指用Java编程语言编写的程序源代码。这些源代码可以被Java编译器编译成字节码,然后在Java虚拟机(JVM)上运行。Java是一种面向对象的编程语言,广泛应用于各种应用场景,从桌面应用到大型企业级应用,从移动应用到嵌入式系统。 适合人群:大学生、上班族、初学者、开发人员、软件工程师、系统架构师等。 介绍格式:知识领域 + 技术关键词 + 内容关键词 + 用途 知识领域:编程语言、软件开发 技术关键词:Java编程语言、面向对象编程(OOP)、Java虚拟机(JVM)、Java开发工具(如Eclipse、IntelliJ IDEA) 内容关键词:变量、数据类型、运算符、控制流、类、对象、继承、多态、异常处理、集合框架、泛型、多线程、网络编程、文件IO、数据库连接(JDBC)等 用途:Java源码系统是用于学习、实践和开发Java应用程序的资源。通过阅读和分析Java源码,可以帮助学习者深入理解Java编程语言的特性和最佳实践,提高编程技能,解决实际问题。同时,Java源码也是开发人员进行软件开发的基础,可以用于构建各种类型的应用程序和系统。 这个Java源码系统,经过亲自测试,确实可用。它适合大学生作为学习材料,帮助理解Java编程的基本概念和实践;适合上班族作为提升技能的资源,学习如何在实际工作中应用Java;也适合初学者入门Java编程,逐步掌握从基础到高级的知识和技能。
资源推荐
资源详情
资源评论
收起资源包目录
基于java的日记本源码.zip (351个子文件)
DiaryDao.class 6KB
MainServlet.class 6KB
UserServlet.class 5KB
DiaryTypeServlet.class 5KB
DiaryServlet.class 5KB
LoginServlet.class 3KB
DiaryTypeDao.class 3KB
UserDao.class 2KB
Diary.class 2KB
LoginFilter.class 2KB
User.class 2KB
DbUtil.class 1KB
DateUtil.class 1KB
MD5Util.class 1KB
DiaryType.class 1KB
PropertiesUtil.class 1006B
PageBean.class 825B
StringUtil.class 598B
.classpath 548B
org.eclipse.wst.common.component 469B
org.eclipse.wst.jsdt.ui.superType.container 49B
bootstrap.css 124KB
bootstrap.min.css 104KB
editor_ie7.css 37KB
editor_iequirks.css 36KB
editor_ie8.css 36KB
editor_ie.css 35KB
editor_gecko.css 34KB
editor.css 34KB
bootstrap-responsive.css 22KB
dialog_ie7.css 17KB
dialog_ie8.css 17KB
bootstrap-responsive.min.css 16KB
dialog_iequirks.css 16KB
dialog_ie.css 16KB
dialog_opera.css 16KB
dialog.css 15KB
sample.css 5KB
outputxhtml.css 2KB
contents.css 2KB
diary.css 1KB
toolbar.css 1KB
wsc.css 1KB
sample.css 53B
outputforflash.fla 84KB
star.gif 6KB
spacer.gif 43B
datafiltering.html 34KB
inlineall.html 10KB
outputforflash.html 10KB
toolbar.html 8KB
magicline.html 8KB
fullpage.html 8KB
jquery.html 7KB
dialog.html 7KB
outputhtml.html 7KB
api.html 7KB
xhtmlstyle.html 7KB
replacebyclass.html 7KB
replacebycode.html 7KB
inlinebycode.html 6KB
index.html 6KB
inlinetextarea.html 5KB
divreplace.html 4KB
uilanguages.html 4KB
enterkey.html 4KB
tmp.html 3KB
readonly.html 3KB
ajax.html 2KB
uicolor.html 2KB
tabindex.html 2KB
tmpFrameset.html 2KB
appendto.html 2KB
ciframe.html 2KB
mysql-connector-java-3.1.12-bin.jar 436KB
standard.jar 343KB
jstl.jar 17KB
DiaryDao.java 6KB
MainServlet.java 6KB
DiaryTypeServlet.java 5KB
DiaryServlet.java 5KB
UserServlet.java 4KB
DiaryTypeDao.java 3KB
LoginServlet.java 3KB
Diary.java 2KB
UserDao.java 2KB
LoginFilter.java 1KB
User.java 1KB
DateUtil.java 1KB
DbUtil.java 978B
MD5Util.java 880B
DiaryType.java 832B
PageBean.java 626B
PropertiesUtil.java 614B
StringUtil.java 520B
20140224085322.jpg 81KB
20140330033128.jpg 61KB
sample.jpg 18KB
ckeditor.js 449KB
jQuery.js 90KB
共 351 条
- 1
- 2
- 3
- 4
资源评论
Echo-Niu
- 粉丝: 215
- 资源: 1974
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- vlmcsd-1113-2020-03-28-Hotbird64(最新版本KMS)
- 433.基于SpringBoot的冷链物流系统(含报告).zip
- com.harmonyos4.exception.PowerFailureException(怎么解决).md
- 使用 Python 字典统计字符串中每个字符的出现次数.docx
- com.harmonyos4.exception.SystemBootFailureException(怎么解决).md
- 球队获胜数据集.zip
- ERR-NULL-POINTER(解决方案).md
- <项目代码>YOLOv8 航拍行人识别<目标检测>
- 计算机网络-socket-inet-master.zip
- Java编程学习路线:从基础到实战全攻略
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功