JDBC中关于取出某个时间内的所有数据的操作

                   JDBC中关于取出某个时间段内的数据的操作

  我们在平时的工作中,可能会经常使用到取出某个时间段内的数据的操作。比如在银行系统中就会经常用到这样的数据。

  package com.bjsxt.jdbc;

 

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.text.DateFormat;

import java.text.ParseException;

import java.text.SimpleDateFormat;

import java.util.Random;

 

 

/**

 * 测试时间处理(java.sql.Date,Time,Timestamp),取出指定时间段的数据

 * @author 高淇 www.sxt.cn

 *

 */

public class Demo08 {

/**

 * 将字符串代表的日期转为long数字(格式:yyyy-MM-dd hh:mm:ss)

 * @param dateStr

 * @return

 */

public static  long  str2Date(String dateStr){

DateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");

try {

return format.parse(dateStr).getTime();

} catch (ParseException e) {

e.printStackTrace();

return 0;

}

}

public static void main(String[] args) {

Connection conn = null;

PreparedStatement ps = null;

ResultSet rs = null;//这里表示的是一个结果集。

try {

//加载驱动类

Class.forName("com.mysql.jdbc.Driver");

conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/testjdbc","root","123456");

// ps = conn.prepareStatement("select * from t_user where regTime>? and regTime<?");

// java.sql.Date start = new java.sql.Date(str2Date("2015-4-10 10:23:45"));

// java.sql.Date end = new java.sql.Date(str2Date("2015-4-13 10:23:45"));

// ps.setObject(1, start);

// ps.setObject(2, end);

ps = conn.prepareStatement("select * from t_user where lastLoginTime>? and lastLoginTime<?  order by lastLoginTime ");

Timestamp start = new Timestamp(str2Date("2015-4-18 8:10:20"));

Timestamp end = new Timestamp(str2Date("2015-4-18  9:9:10"));

ps.setObject(1, start);

ps.setObject(2, end);

rs = ps.executeQuery();

while(rs.next()){

System.out.println(rs.getInt("id")+"--"+rs.getString("username")+"--"+rs.getTimestamp("lastLoginTime"));

}

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SQLException e) {

e.printStackTrace();

}finally{

try {

if(ps!=null){

ps.close();

}

} catch (SQLException e) {

e.printStackTrace();

}

try {

if(conn!=null){

conn.close();

}

} catch (SQLException e) {

e.printStackTrace();

}

}

}

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱coding的同学

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值