select from 表名 where to_date(jssj,'yyyymmddhh24miss')-
to_date(kssj,'yyyymmddhh24miss')>900/24/60/60
解释下:那两个日期要转成日期型来做比较
条件是大于15分钟,正常两个日期减得到的是天
所以要用900秒除24小时,除60分钟,除60秒,将这个15分钟转成天
有错误,你给的$time = date("Y-m-d G:i:s");是日期的格式化字符串,比较的时候要用引号因起来,另外你这个sql的意思是查询已经开始并且没有过期的记录条数,并没有判断哪条记录已经开始或过期,应该这样写:
$time = date("Y-m-d G:i:s");
$sql="select ExamInfo_Begin,ExamInfo_End from kl_examinfo where id='$id'";
//$id是你要查询的记录的主键值;
$query=mysql_query($sql);
list($begin,$end)=mysql_fetch_row($query);
if($begin<'$time')
{
echo "已经开始";
}
else
{
echo "还未开始";
}
if($end>'$time')
{
echo "没有过期";
}
else
{
echo "已经过期";
}
看看,你的 cfsj 是什么类型的数据, 都有什么值?
我有点怀疑 to_date(cfsj,'yyyy-mm-dd hh24:mi:ss') ,这步就有错误了。
你执行一下这个查询:
select to_date(cfsj,'yyyy-mm-dd hh24:mi:ss') from tbl_jycxcfxxb
看是否正常?
要进行日期的比较是肯定要转化成日期格式的,这个你可以在asp中处理,也可以在SQL中处理,在asp中处理如下:
if CDate(数据库时间)< CDate(now() )
{
ResponseWrite("信息经过期");
}
怎么才能愉快地处理日期和时间?答案是:立刻升级到Java 8!
Java 8新增了LocalDate和LocalTime接口,为什么要搞一套全新的处理日期和时间的API?因为旧的javautilDate实在是太难用了。
javautilDate月份从0开始,一月是0,十二月是11,变态吧!javatimeLocalDate月份和星期都改成了enum,就不可能再用错了。
javautilDate和SimpleDateFormatter都不是线程安全的,而LocalDate和LocalTime和最基本的String一样,是不变类型,不但线程安全,而且不能修改。
javautilDate是一个“万能接口”,它包含日期、时间,还有毫秒数,如果你只想用javautilDate存储日期,或者只存储时间,那么,只有你知道哪些部分的数据是有用的,哪些部分的数据是不能用的。在新的Java 8中,日期和时间被明确划分为LocalDate和LocalTime,LocalDate无法包含时间,LocalTime无法包含日期。当然,LocalDateTime才能同时包含日期和时间。
新接口更好用的原因是考虑到了日期时间的 *** 作,经常发生往前推或往后推几天的情况。用javautilDate配合Calendar要写好多代码,而且一般的开发人员还不一定能写对。
LocalDate
看看新的LocalDate怎么用:
// 取当前日期:
LocalDate today = LocalDatenow(); // -> 2014-12-24
// 根据年月日取日期,12月就是12:
LocalDate crischristmas = LocalDateof(2014, 12, 25); // -> 2014-12-25
// 根据字符串取:
LocalDate endOfFeb = LocalDateparse("2014-02-28"); // 严格按照ISO yyyy-MM-dd验证,02写成2都不行,当然也有一个重载方法允许自己定义格式
LocalDateparse("2014-02-29"); // 无效日期无法通过:DateTimeParseException: Invalid date
日期转换经常遇到,比如:
// 取本月第1天:
LocalDate firstDayOfThisMonth = todaywith(TemporalAdjustersfirstDayOfMonth()); // 2014-12-01
// 取本月第2天:
LocalDate secondDayOfThisMonth = todaywithDayOfMonth(2); // 2014-12-02
// 取本月最后一天,再也不用计算是28,29,30还是31:
LocalDate lastDayOfThisMonth = todaywith(TemporalAdjusterslastDayOfMonth()); // 2014-12-31
// 取下一天:
LocalDate firstDayOf2015 = lastDayOfThisMonthplusDays(1); // 变成了2015-01-01
// 取2015年1月第一个周一,这个计算用Calendar要死掉很多脑细胞:
LocalDate firstMondayOf2015 = LocalDateparse("2015-01-01")with(TemporalAdjustersfirstInMonth(DayOfWeekMONDAY)); // 2015-01-05
LocalTime
LocalTime只包含时间,以前用javautilDate怎么才能只表示时间呢?答案是,假装忽略日期。
LocalTime包含毫秒:
LocalTime now = LocalTimenow(); // 11:09:09240
你可能想清除毫秒数:
LocalTime now = LocalTimenow()withNano(0)); // 11:09:09
构造时间也很简单:
LocalTime zero = LocalTimeof(0, 0, 0); // 00:00:00
LocalTime mid = LocalTimeparse("12:00:00"); // 12:00:00
时间也是按照ISO格式识别,但可以识别以下3种格式:
12:00
12:01:02
12:01:02345
JDBC
最新JDBC映射将把数据库的日期类型和Java 8的新类型关联起来:
SQL -> Java
--------------------------
date -> LocalDate
time -> LocalTime
timestamp -> LocalDateTime
再也不会出现映射到javautilDate其中日期或时间某些部分为0的情况了。
以上就是关于oracle数据库里两个字符型的日期数据怎样比较全部的内容,包括:oracle数据库里两个字符型的日期数据怎样比较、SQL 数据库时间比较、oracle数据库两个日期比较,一个日期比另一个日期大三个月以上的数据。。纠结。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)