oracle数据库里两个字符型的日期数据怎样比较

oracle数据库里两个字符型的日期数据怎样比较,第1张

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数据库两个日期比较,一个日期比另一个日期大三个月以上的数据。。纠结。等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9530600.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存