在MySql中怎么将int类型转换为date类型
这种方式在MySQL查询语句中转换,优点是不占用PHP解析器的解析时间,速度快,缺点是只能用在数据库查询中,有局限性。数据库日期类型是int类型的,该查询结果是datetime类型的
mysql时间戳转日期 mysql时间戳转日期格式
mysql时间戳转日期 mysql时间戳转日期格式
timestampdiff(unit,datetime_expr1,datetime_expr2) --
SELECT from_unixtime( `daine` )
FROM cdb_ts
如果原来类型是datetime类型,查询结果要是int类型则
SELECT unix_timestamp( `daine` )
FROM cdb_ts
php时间转换,关键是看你在什么时候要获得对应的时间类型
$timestamp=1210003200;
$datetime=date('Y-m-d H:i:s',$timestamp);
echo "该时间戳代表的时间:".$datetime
echo"从此时间重新转回时间戳:".strtotime($datetime)
与目前时间比较,按天计算
select from kw_photo where TIMESPDIFF(day,from_unixtime(`cTime`),now())<=7(7天内)
请教,MYSQL如何根据UNIX时间戳,判定一周范伟内的数据
如果是从这一刻起往前一个星期应该是:
$sql = '........... WHERE 注:此函数仅在PHP 5.1+中有效。`daine`>'.$time-604800;
//604800 = 60秒 × 60分钟 × 24小时 × 7天
$sql = '............ WHERE `daine`>'.strtotime(date('Ymd').' 00:00:00');
应该这样写如果从当前时间算前一周的时间:
$awt=time()-3600247;
今天之前的一周时间:
$awt=strtoti本月是 28 天me(date('Y-m-d'))-3600247;
$sql="select from tablename where daine>$awt";
select from 表
where daine > (unix_timestamp()-3600247)
如何处理mysql中的时间戳读取问题
setlocale(LC_TIME, "fra_fra");1. MySQL 获得当前时间戳函数:current_timestamp, current_timestamp()
mysql> select current_timestamp, current_timestamp();
+---------------------+---------------------+
| current_timestamp | current_timestamp() |
+---------------------+---------------------+
| 2008-08-09 23:22:24 | 2008-08-09 23:22:24 |
+---------------------+---------------------+
2. MySQL (Unix 时间戳、日期)转换函数:
unix_timestamp(),
unix_timestamp(date),
from_unixtime(unix_timestamp),
from_unixtime(unix_timestamp,format)
// run some code下面是示例:
select unix_timestamp(); -- 1218290027
select unix_timestamp('2008-08-08 12:30:00'); -- 1218169800
select from_unixtime(1218290027); -- '2008-08-09 21:53:47'
select from_unixtime(1218169800); -- '2008-08-08 12:30:00'
select from_unixtime(1218169800, '%Y %D %M %h:%i:%s %x'); -- '2008 8th August 12:30:00 2008'
3. MySQL 时间戳(timestamp)转换、增、减函数:
timestamp(date) -- date to timestamp
timestamp(dt,time) -- dt + time
timestampadd(unit,interval,datetime_expr) --
请看示例部分:
select timestamp('2008-08-08'); -- 2008-08-08 00:00:00
select timestamp('2008-08-08 08:00:00', '01:01:01'); -- 2008-08-08 09:01:01
select timestamp('2008-08-08 08:00:00', '10 01:01:01'); -- 2008-08-18 09:01:01
select timestampadd(day, 1, '2008-08-08 08:00:00'); -- 2008-08-09 08:00:00
select date_add('2008-08-08 08:00:00', interval 1 day); -- 2008-08-09 08:00:00
MySQL timestampadd() 函数类似于 date_add()。
select timestampdiff(year,'2002-05-01','2001-01-01'); -- -1
select timestampdiff(day ,'2002-05-01','2001-01-01'); -- -485
select timestampdiff(hour,'2008-08-08 12:00:00','2008-08-08 00:00:00'); -- -12
select datediff('2008-08-08 12:00:00', '2008-08-01 00:00:00'); -- 7
如何建立mysql时间戳字段
如果是日期字符串类型就是~
(time datetime NOT NULL DEFAULT NOselect from_unixtime(1218124800); -- '2008-08-08 00:00:00'W(),
primary key(Sno,Cno),...
)如果是时间戳~
(time int NOT NULL DEFAULT CURRENT_TIMESP(),
...
)-----希望对你有帮助~
如果是插入的时候的话~在对应值上填写NOW()/CURRENT_TIMESP() 也是可以的
%Y.%m在MySQL中是什么意思?
echo date('w');通常是SQL查询时时间戳转成格式化日期时的写
如果是今天零点起往前一个星期应该是:比如:select FROM_UNIXTIME(表时间戳值字段名,'%Y.%m') from 表名
查出来的结果就是这样的:2019.12、2019.11、2019.10、2019.09
mysql 把时间换成时间戳进行存储在int字段中还是直接用datetime好
int比datetime计算简单,数据量大的话int比datSdept char(20)etime储存速度更快 一点。
时间戳(timesecho date('Y-m-d H:i:s',$row['ndate']);tamp),一个能表示一份数据在某个特定时间之前已经存在的、 完整的、 可验证的数据,通常是一个字符序列,识某一刻的时间。
使用数字签名技术产生的数据, 签名的对象包括了原始文件信息、 签名参数、 签名时间等信息。广泛的运用在知识产权保护、 合同签字、 金融帐务、 电子报价投标、 股票交易等方面。
扩展资料
时间戳有两类:
1、自建时间戳:此类时间戳是通过时间接收设备来获取时间到时间戳上,并通过时间戳签发时间戳证书。此种时间戳可用来企业内部认定,在法庭认证时并不具备法律效力。因其在通过时间接收设备接收时间时存在被篡改的可能,故此不能做为法律依据。
2、具有法律的效力的时间戳:它是由我国中科院授时中心与联合信任技术服务有限公司负责建设的我国第三方可信时间戳认证服务。由授时中心负责时间的授时与守时监测。
参考资料来源:
我们用的都是 int ,毕竟 时间戳 可以用FROM_UNIXTIME()等时间函数转换成时间格式,个人感觉 int 比 datetime 计算 和 比较 简单一点,还有是就是 感觉 数据量大的话 int 应该比 datetime 更快 一点,我们公司 数据库大牛 ,建的所有的数据表关于 时间的都是 int
php怎么将指定日期转换为时间戳?
应用此函数建立与当前环境兼容的日期字符串。在MySQL中完成
。下面介绍两种php将指定日期转换为时间戳的方法:
种:在MySQL中完成
UNIX时间戳转换为日期用函数:
FROM_UNIXTIME()
一般形式:select
日期转换为UNIX时间戳用函数:
UNIX_TIMESP()
一其余的都不是什么重要的考虑,自己喜欢就行。般形式:Select
UNIX_TIMESP('2006-11-04
12:23:00′);
举例:mysql查询当天的记录数:
$sql=”select
from
message
Where
DATE_FORMAT(FROM_UNIXTIME(chattime),'%Y-%m-%d')
=DATE_FORMAT(NOW(),'%Y-%m-%d')
order
by
id
desc”;
当然大家也可以选择在PHP中进行转换,下面说说在PHP中转换。
第二种:在PHP中完成 这种方式在PHP程序中完成转换,优点是无论是不是数据库中查询获得的数据都能转换,转换范围不受限制,缺点是占用PHP解析器的解析时间,速度相对慢。
UNIX时间戳转换为日期用函数:
date() 一般形式:date('Y-m-d
H:i:s',
1156219870);
日期转换为UNIX时间戳用函数:strtotime() 一般形式:strtotime('2010-03-24
08:15:42')
php中时间转换函数strtotime(date())
date("Y-m-d H:i",$unixtime)
php中获得今天零点的时间戳
要获得零点的unix时间戳,可以使用$todaytime=strtotime(“today”),然后再使用date("Y-m-d H:i",$todaytime)转换为日期。
时间戳转换函数:date("Y-m-d
H:i:s",time()),"Y-m-d
H:i:s"是转换后的日期格式,time()是获得当前时间的时间戳。如果是date("Y-m-d H:i:s",time()),则小时分秒一起显示;如果是date("Y-m-d ", time()),只显示年月日。例如:date("Y-m-d H:i:s",time())转换后为:2010-07-18 18:42:48
date("Y-m-d",time())。
php时间问题?mysql数据库的时间格式(Y-M-D H:I:S) 在PHP页面想这样显示(Y-M-D) ('.$rows['ndate'].')
此函数将可人为阅读的英文日期/时间字符串转换成UNIX时间标签。参考一下看看
fromPHP的日期时间函数date()
1,年-月-日
echo date('Y-m-j');
2007-02-6
echo date('y-n-j');
07-2-6
大写Y表示年四位数字,而小写y表示年的两位数字;
小写m表示月份的数字(带前导),而小写n则表示不带前导的月份数字。
echo date('Y-M-j');
2007-Feb-6
echo date('Y-m-d');
2007-02-06
大写M表示月份的3个缩写字符,而小写m则表示月份的数字(带前导0);
没有大写的J,只有小写j表示月份的日期,无前导o;若需要月份带前导则使用小写d。
echo date('Y-M-j');
2007-Feb-6
echo date('Y-F-jS');
2007-February-6th
大写M表示月份的3个缩写字符,而大写F表示月份的英文全写。(没有小写f)
大写S表示日期的后缀,比如“st”、“nd”、“rd”和“th”,具体看日期数字为何。
小结:
表示年可以用大写的Y和小写y;
表示月可以用大写F、大写M、小写m和小写n(分别表示字符和数字的两种方式);
表示日可以用小写d和小写j,大写S表示日期的后缀。
2,时:分:秒
默认情况下,PHP解释显示的时间为“格林威治标准时间”,与我们本地的时间相8个小时。
echo date('g:i:s a');
5:56:57 am
echo date('h:i:s A');
05:56:57 AM
小写g表示12小时制,无前导0,而小写h则表示有前导0的12小时制。
当使用12小时制时需要表明上下午,小写a表示小写的“am”和“pm”,大写A表示大写的“AM”和“PM”。
echo date('G:i:s');
14:02:26
大写G表示24小时制的小时数,但是不带前导的;使用大写的H表示带前导的24小时制小时数
小结:
字母g表示小时不带前导,字母h表示小时带前导;
3,闰年、星期、天
echo date('L');
今年是否闰年:0
echo date('l');
今天是:Tuesday
echo date('D');
今天是:Tue
大写L表示判断今年是否闰年,布尔值,为真返回1,否则为0;
小写l表示当天是星期几的英文全写(Tuesday);
而使用大写D表示星期几的3个字符缩写(Tue)。
今天星期:2
echo date('W');
本周是全年中的第 06 周
小写w表示星期几,数字形式表示
大写W表示一年中的星期数
echo date('t');
echo date('z');
今天是今年的第 36 天
小写t表示当前月份又多少天
小写z表示今天是本年中第几天
4,其他
echo date('T');
UTC
大写T表示的时间区域设置
echo date('I');
大写I表示判断当前是否为夏令时,为真返回1,否则为0
echo date('U');
1170769424
大写U表示从1970年1月1日到现在的总秒数,就是Unix时间纪元的UNIX时间戳。
echo date('c');
2007-02-06T14:24:43+00:00
小写c表示ISO8601日期,日期格式为YYYY-MM-DD,用字母T来间隔日期和时间,时间格式为HH:MM:SS,时区使用格林威治标准时间(GMT)的偏来表示。
echo date('r');
小写r表示RFC822日期。
小小的date()函数就显示出了PHP的强大功能和迷人魅力,再比较下ASP,呵呵。
checkdate($month,$date,$year)
如果应用的值构成一个有效日期,则该函数返回为真。例如,对于错误日期2005年2月31日,此函数返回为。
在日期用于计算或保存在数据库中之前,可用此函数检查日期并使日期生效。
// returns false
echo checkdate(2,30,2005) ? "valid" : "invalid";
// returns true
echo checkdate(4,6,2010) ? "valid" : "invalid";
?>
getdate($ts)
在没有自变量的情况下,该函数以结合数组的方式返回当前日期与时间。数组中的每个元素代表日期/时间值中的一个特定组成部分。可向函数提交可选的时间标签自变量,以获得与时间标签对应的日期/时间值。
// get date as associative array
$arr = getdate();
echo "Date is " . $arr['mday'] . " " . $arr['weekday'] . " " . $arr['year'];
echo "Time is " . $arr['hours'] . ":" . $arr['minutes'];
?>
mktime($hour, $minute, $second, $month, $day, $year)
此函数的作用与getdate()的作用相反:它由一系列的日期与时间值生成一个UNIX时间标签(GMT时间1970年1月1日到现在消逝的秒数)。不用自变量时,它生成当前时间的UNIX时间标签。
用此函数获得即时时间的UNIX时间标签。这种时间标签通常用于许多数据库与程序语言中。
// returns timestamp for 13:15:23 7-Jun-2006
echo mktime(13,15,23,6,7,2006);
?>
date($format, $ts)
此函数将UNIX时间标签格式化成一个可人为阅读的日期字符串。它是PHP日期/时间API中功能最为强大的函数,可用在一系列的修正值中,将整数时间标签转变为所需的字符串格式。
为显示格式化时间或日期时,应用此函数。
// format current date
// returns "13-Sep-2005 01:16 PM"
echo date("d-M-Y h:i A", mktime());
?>
strtotime($str)
// returns 13-Sep-05
echo date("d-M-y", strtotime("today"));
// returns 14-Sep-05
echo date("d-M-y", strtotime("tomorrow"));
// returns 16-Sep-05
echo date("d-M-y", strtotime("today +3 days"));
?>
strftime($format,$ts)
如前面的setlocale()函数定义的那样,此函数将UNIX时间标签格式化成适用于当前环境的日期字符串。
// set locale to France (on Windows)
// format month/day names
// as per locale setting
// returns "septembre" and "mardi"
echo strftime("Month: %B ");
echo strftime("Day: %A ");
?>
microtime()
如前面的setlocale()函数定义的那样,此函数将UNIX时间标签格式化成适用于当前环境的日期字符串。
// get starting value
$start = microtime();
for ($x=0; $x<1000; $x++) {
$null = $x $x;
}// get ending value
$end = microtime();
// calculate time taken for code execution
echo "Elapsed time: " . ($end - $start) ." sec";
?>
gmmktime($hour, $minute, $second, $month, $day, $year)
此函数由一系列用GMT时间表示的日期与时间值生成一个UNIX时间标签。不用自变量时,它生成一个当前GMT即时时间的UNIX时间标签。
用此函数来获得GMT即时时间的UNIX时间标签。
// returns timestamp for 12:25:23 9-Jul-2006
echo gmmktime(12,25,23,7,9,2006);
?>
gmdate($format, $ts)
用GMT表示时间标签时应用此函数。
// format current date into GMT
// returns "13-Sep-2005 08:32 AM"
echo gmdate("d-M-Y h:i A", mktime());
?>
date_default_timezone_set($tz)、date_default_timezone_get()
此函数此后所有的日期/时间函数调用设定并恢复默认的时区。
此函数是一个方便的捷径,可为以后的时间作设定时区。
// set timezone to UTC
date_default_timezone_set('UTC');
?>
//今天
$today = date("Y-m-d");
//昨天
$yesterday = date("Y-m-d", strtotime(date("Y-m-d"))-86400);
//上周
$lastweek_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w")+1-7,date("Y")));
$lastweek_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7-7,date("Y")));
//本周
$thisweek_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w")+1,date("Y")));
$thisweek_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7,date("Y")));
//上月
$lastmonth_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m")-1,1,date("Y")));
$lastmonth_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m") ,0,date("Y")));
//本月
$thionth_start = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),1,date("Y")));
$thionth_end = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("t"),date("Y")));
//本季度未一月天数
$getMonthDays = date("t",mktime(0, 0 , 0,date('n')+(date('n')-1)%3,1,date("Y")));
//本季度/
$thisquarter_start = date('Y-m-d H:i:s', mktime(0, 0, 0,date('n')-(date('n')-1)%3,1,date('Y')));
$thisquarter_end = date('Y-m-d H:i:s', mktime(23,59,59,date('n')+(date('n')-1)%3,$getMonthDays,date('Y')));
?>
不知道你的那个ndate是什么格式?试试strftime('%Y-%m-%d', strtotime($rows['ndate']))。
格式化呗,输出看看
echo date('Y-m-d',strtotime($rows['ndate']));
date(now(),'Y-m-d');这样子
mysql中的date类型直接比较大小是按照字符串比较还是时间戳
小写g、h表示12小时制,大写G、H表示24小时制。MySql中时间比较的实现
时间戳和字面时间的互转只是简单的计算,所消耗的资源远远达不到引发问题的地步。
使用时间戳的考虑是:你的应用是否涉及多时区,时间数据是否和时区相关。如果回答“是”,那么就必须使用时间戳,没有任何第二方案。
只有时间戳表示的时间是准确、恒定的,就连时间+日期+时区也不行——时区这玩意儿可不是恒定不变的……
一般认为坚持使用时间戳总是好的,在程序设计中只会提供便利,不会引入坏处。至于查看数据时暴露时间戳原值,那是显示环节的不完备(或故意设计),而不是用时间戳用错了,切勿张冠李戴抹黑好东西。
日期的应用此函数将非标准化的日期/时间字符串转换成标准、兼容的UNIX时间标签。字符串-时间互转、计算、比较及时区转换,请使用后台语言中提供的相关类,不自己造轮子就可以。
可以略微注意2038年问题的陷阱。对于MySQL而言,如果存时间戳请使用timestamp或bigint,而不要使用int。
[mysql]【日期类型】 怎样实现时间是从1970年1月1日现在的秒数,又该怎么进行转换(秒数--YYMMDDHH)
字段a;create table SC( //此表为从表
MySQL timestampdiff() 函数就比 datediff() 功能强多了,datediff() 只能计算两个日期(date)之间相的天数。Sno char(10),
Cno char(10),
Grade int,
foreign key(Sno) references Student(Sno),
foreign key(Cno) references Course(Cno),
check(Grade between 0 and 150))
create table Student( //此表为主表
Sno char(10),
Sname char(10),
Sgender char(10),
Sage int,
primary key(Sno),
check (Sage between 0 and 150))
create table Course( //此表为主表
Cno char(10),
Cname char(10),
Cpno char(10),
Ccredit char(10),
primary key(Cno),
check(Ccredit between 0 and 150))
主表student的sno 与 主表course的cno 共同构成sc的主键,由于是引用主表的主键,其主键就为外键,设置外键使用下列命令:
foreign key(从表主键1 sno) references 主表(主键sno),
foreign key(从表主键2 cno) references 主表(主键cno),
如何处理mysql中的时间戳读取问题
YEAR (datetime ) //年份1. MySQL 获得当前时间戳函数:current_timestamp, current_timestamp()
mysql> select current_timestamp, current_timestaTue, 06 Feb 2007 14:25:52 +0000mp();
+---------------------+---------------------+
| current_timestamp | current_timestamp() |
+---------------------+---------------------+
| 2008-08-09 23:22:24 | 2008-08-09 23:22:24 |
+---------------------+---------------------+
2. MySQL (Unix 时间戳、日期)转换函数:
unix_timestamp(),
unix_timestamp(date),
from_unixtime(unix_timestamp),
from_unixtime(unix_timestamp,format)
下面是示例:
select unix_timestamp(); -- 1218290027
select unix_timestamp('2008-08-08 12:30:00'); -- 1218169800
select from_unixtime(1218290027); -- '2008-08-09 21:53:47'
select from_unixtime(1218169800); -- '2008-08-08 12:30:00'
select from_unixtime(1218169800, '%Y %D %M %h:%i:%s %x'); -- '2008 8th August 12:30:00 2008'