package com.pb.news.dao.impl;

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Timestamp;
import java.sql.Types;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.sql.Timestamp;

import com.pb.news.dao.BaseDao;
import com.pb.news.dao.NewsDao;
import com.pb.news.entity.News;
import com.pb.news.util.ConfigManager;
import com.pb.news.util.Page;

public class NewsDaoImpl extends BaseDao implements NewsDao{

@Override
//通过新闻ID获取新闻
public News getNewsById(int id) {
News news=null;
try{
//(3)获得Statement对象,执行SQL语句
String sql="select * from news_detail where id= "+id;

Object[] params={};
ResultSet rs=this.excuteSQL(sql, params);
////(4)处理执行结果(ResultSet)
if(rs.next()){
int categoryId=rs.getInt("categoryId");
String title=rs.getString("title");
String summary=rs.getString("summary");
String content=rs.getString("content");
String picPath=rs.getString("picPath");
String author=rs.getString("author");
Timestamp time=rs.getTimestamp("createdate");
//封装成新闻信息对象
news=new News();
news.setId(id);
news.setCategoryId(categoryId);
news.setTitle(title);
news.setSummary(summary);
news.setContent(content);
news.setPicpath(picPath);
news.setAuthor(author);
news.setCreatedate(time);

}
}catch(SQLException e){
e.getStackTrace();
}finally{
this.closeResource();
}

return news;
}
//查询新闻信息
public List<News> getNewsList(){
List<News> newList=new ArrayList<News>();
try {

//3.获得Statement对象,执行sql语句
String sql="select * from news_detail order by createdate ASC";
Object[] params={};
ResultSet rs=this.excuteSQL(sql, params);
//4.处理执行结果(ResultSet),释放资源
while(rs.next()){
int id=rs.getInt("id");
String title=rs.getString("title");
String summary=rs.getString("summary");
String content=rs.getString("content");
String author=rs.getString("author");
Timestamp time=rs.getTimestamp("createdate");

// System.out.println(id+"\t"+title+"\t"+summary+"\t"+
// content+"\t"+author+"\t"+time);

//封装成新闻信息对象
News news=new News();
news.setId(id);
news.setTitle(title);
news.setSummary(summary);
news.setContent(content);
news.setAuthor(author);
news.setCreatedate(time);

//将新闻对象放到集合中
newList.add(news);
}
}catch (SQLException e) {

e.printStackTrace();
}finally{
//释放资源
this.closeResource();
}
return newList;
}

//增加新闻信息
public boolean add(News news){
boolean flag=false;
try {

String sql="insert into news_detail(id,categoryId,title,summary,content,picPath,createdate,author) "
+ "values(SEQ_NEWS.nextval,?,?,?,?,?,?,?)";
Object[] params={news.getCategoryId(),news.getTitle(),news.getSummary()
,news.getContent(),news.getPicpath(),new java.sql.Timestamp(news.getCreatedate().getTime()),news.getAuthor()};

int i=this.excuteUpdate(sql, params);
//4.处理执行结果(ResultSet),释放资源
if(i>0){
System.out.println("插入新闻成功!");
}
flag=true;
}finally{
//释放资源
this.closeResource();
}

return flag;
}
//删除新闻信息
public boolean delete(int id){
boolean flag=false;

try {

//获取statement对象,执行sql语句
String sql="delete from news_Detail where id=?";
Object[] params={id};
//处理执行结果
int i=this.excuteUpdate(sql, params);
if(i>0){
System.out.println("册除新闻成功!");
}
flag=true;
} finally{
//释放资源
this.closeResource();

}
return flag;
}

//修改整个新闻信息
public boolean update(News news){
boolean flag=false;

try {

//获取statement对象,执行sql语句
String sql="update news_Detail set categoryId=?,title=?,summary=?,content=?,"
+ "picpath=?,author=?,modifydate=? where id=?";
Object[] params={news.getCategoryId(),news.getTitle(),news.getSummary(),
news.getContent(),news.getPicpath(),news.getAuthor(),
new java.sql.Timestamp(news.getModifydate().getTime()),news.getId()};
//处理执行结果
int i=this.excuteUpdate(sql, params);
if(i>0){
System.out.println("修改新闻成功!");
}
flag=true;
} finally{
//释放资源
this.closeResource();

}
return flag;
}

@Override
//获取新闻总数量
public int getTotalCount() {
int totalCount=0;
String sql="select count(*) from news_detail";
Object[] params={};
ResultSet rs=this.excuteSQL(sql, params);
try {
while(rs.next()){
totalCount=rs.getInt(1);
}
} catch (SQLException e) {

e.printStackTrace();
}finally{
this.closeResource();
}
return totalCount;
}

@Override
//分页获取新闻信息
public List<News> getPageNewsList(int pageNo, int pageSize) {
List<News> newsList=new ArrayList<News>();
String sql="SELECT id,title,author,createdate FROM (SELECT id,title,author,createdate,ROWNUM rn FROM news_detail) a WHERE a.rn>=? AND a.rn<=? ";
Page page=new Page();
page.setCurrPageNo(pageNo);//设置当前页码
page.setPageSize(pageSize);//每页显示记录数
//计算sql语句的起始记录数及结束记录数的行数
int startRow=page.getStartRow();
int endRow=page.getEndRow();
Object[] params={startRow,endRow};
ResultSet rs=this.excuteSQL(sql, params);
try {
while(rs.next()){
int id=rs.getInt("id");
String title=rs.getString("title");
String author=rs.getString("author");
Date date=rs.getDate("createdate");
News newInfo=new News();
newInfo.setId(id);
newInfo.setTitle(title);
newInfo.setAuthor(author);
newInfo.setCreatedate(new java.sql.Timestamp(date.getTime()));

newsList.add(newInfo);
}
} catch (SQLException e) {

e.printStackTrace();
}finally{
this.closeResource();
}
return newsList;
}

//获取新闻总数(执行存储过程)
public int getTotalCountProc(){
int totalCount=0;
CallableStatement proc=null;
String sql="{call getNewsCount(?)}";
getConnection();
try {
proc=conn.prepareCall(sql);
proc.registerOutParameter(1, Types.INTEGER);
proc.execute();
totalCount=proc.getInt(1);
} catch (SQLException e) {

e.printStackTrace();
}

return totalCount;
}

//测试
public static void main(String[] args) {
NewsDaoImpl newsDao=new NewsDaoImpl();
//newsDao.add(2,1,"快女选秀快讯","快女比赛正入白热化","她、她、她,谁是你心中的快女冠军",new Date());
//newsDao.update(3, "快女选秀快讯速递");
//newsDao.delete(3);
// List<News>newsList=newsDao.getNewsList();
// for (News news : newsList) {
// //System.out.println(id+"\t"+title+"\t"+summary+"\t"+
// content+"\t"+author+"\t"+time);
// System.out.println(news.getId()+"\t"+news.getTitle()+"\t"+news.getSummary()+"\t"+news.getContent()+"\t"+news.getPicpath()+"\t"+news.getAuthor()+"\t"+news.getCreatedate());
// }
// int totalCount=newsDao.getTotalCount();
// System.out.println("新闻总数量是:"+totalCount);
//第一页显示新闻信息(每页显示2条)
List<News>newsList=newsDao.getPageNewsList(1, 2);
//第2页显示新闻信息(每页显示2条)
// List<News>newsList=newsDao.getPageNewsList(2, 2);
//第3页显示新闻信息(每页显示2条)
//List<News>newsList=newsDao.getPageNewsList(3, 2);
// for (News news : newsList) {
// System.out.println(news.getTitle()+"\t"+news.getAuthor()+"\t"+news.getCreatedate());
// }

int totalCount=newsDao.getTotalCountProc();
System.out.println("新闻总数是:"+totalCount);
}

}

NewsDaoImpl的更多相关文章

  1. 深入浅出Struts2+Spring+Hibernate框架

    一.深入浅出Struts2 什么是Struts2? struts2是一种基于MVC的轻量级的WEB应用框架.有了这个框架我们就可以在这个框架的基础上做起,这样就大大的提高了我们的开发效率和质量,为公司 ...

  2. SSH框架使用注解简化代码

    注释的优势: 1.最简单直接的优势就是减少了配置文件的代码量. 2.注释和Java代码位于一个文件中,而XML 配置采用独立的配置文件.配置信息和 Java 代码放在一起,有助于增强程序的内聚性.而采 ...

  3. SSH(Struts2+Spring4+HIbernate5)的简化

    今天给大家带来的是一个简单的新闻发布系统 首先在学习过程中我是深有体会,做事情不要浮躁,不要想着一口吃下一个胖子, 最最重要的是理解,理解透了学什么东西都是随心所欲的. 开发环境:win10系统 jd ...

  4. ssh简化后之事务管理

    为了能让大家更好的了解,所以今天跟大家分享整个项目.ps:ssh环境的搭建我就不一一讲解了,请大家参考 http://www.cnblogs.com/zczc1996/p/5842367.html. ...

  5. 搭建ssh后的简化

    对于SSh框架的简化,我们可以从下面几个方面来剖析: 1.实体类entity 2.注入 3.类注解 下面,我来一一为大家讲解.ps:写的不好还请多多指教,欢迎大家"来找茬". 关于 ...

  6. struts2+spring+hibernate 实现分页

    在这里要感谢下这位博友发表的博文 http://www.blogjava.net/rongxh7/archive/2008/11/29/243456.html 通过对他代码的阅读,从而自己实现了网页分 ...

  7. 使用spring注解@Controller @Service @Repository简化配置

    前言:在web项目中引入spring框架中的配置文件,我们给每一个java bean进行相关配置可以非常安全,便捷的管理我们的bean.那么,问题来了,如果一个项目中所涉及到的java bean十分庞 ...

  8. Spring的注解

    Action想使用serviceImpl时,都需要最原始的方法New一个接口,Service service = new serviceImpl();去实例化service了.都需要Action主动创 ...

  9. spring aop 声明式事务管理

    一.声明式事务管理的概括 声明式事务(declarative transaction management)是Spring提供的对程序事务管理的方式之一. Spring的声明式事务顾名思义就是采用声明 ...

随机推荐

  1. Linux下Samba服务器的安装和配置

    第一步:sudo apt-get install samba smbclient 安装samba服务器. 第二步:打开/etc/samba/smb.conf文件,在末尾添加下面的字段: [用户名] c ...

  2. redis 清空缓存

    redis 清空缓存 Redis 命令: flushall --> 清空整个 Redis 服务器的数据(删除所有数据库的所有 key ) flushdb --> 清空当前数据库中的所有 k ...

  3. JMETER 不同线程组 变量值 的参数传递

    线程组 1   在线程组1中使用__setProperty函数设置jmeter属性值(此值为全局变量值),将所需变量值如${token}设置为jmeter属性值,即newtoken,示例: 1.添加- ...

  4. 用border或者div制作三角形等图形

    一般情况下, 我们设置盒子的宽高度, 及上下左右边框, 具体代码如下: 通过上述代码,div的具体样式如下: 现在在上面基础上, 我们把div的宽高度都设为0时, 现在我们再次查看效果,如下图: 这时 ...

  5. Tomcat 连接池详解

    (转) JDBC 连接池 org.apache.tomcat.jdbc.pool 是Apache-Commons DBCP连接池的一种替换或备选方案. 那究竟为何需要一个新的连接池? 原因如下: Co ...

  6. 写给Android App开发人员看的Android底层知识(7)

    (十二)ContentProvider (1)ContentProvider是什么? ContentProvider,简称CP. 做App开发的同学,尤其是电商类App,对CP并不熟悉,对这个概念的最 ...

  7. zepto源码分析系列

    如果你也开发移动端web,如果你也用zepto,应该值得你看看.有问题请留言. Zepto源码分析-架构 Zepto源码分析-zepto(DOM)模块 Zepto源码分析-callbacks模块 Ze ...

  8. sql还原(.mdf文件还原)

    第一步: 把备份文件放到目录:C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA (默认)(这里用 MyDB.md ...

  9. HTML输入框只能输入数字或数字字母组合

    JS判断只能是数字和小数点 1.文本框只能输入数字代码(小数点也不能输入) <input onkeyup="this.value=this.value.replace(/\D/g,'' ...

  10. Hybrid App开发之JavaScript基础

    前言: 前面学习了html和css的基本使用,今天开始学习JavaScript的使用. 什么是JavaScript JavaScript是一种基于对象(Object)和事件驱动(Event Drive ...