×

unix_timestamp 时间戳

时间戳是什么?UNIX_TIMESTAMP(tm) 在sql server下应该怎么改写

admin admin 发表于2022-06-11 10:29:19 浏览133 评论0

抢沙发发表评论

时间戳是什么


时间戳是自
1970

1

1
日(00:00:00
gmt)以来的秒数。它也被称为
unix
时间戳(unix
timestamp)。
unix时间戳(unix
timestamp),或称unix时间(unix
time)、posix时间(posix
time),是一种时间表示方式,定义为从格林威治时间1970年01月01日00时00分00秒起至现在的总秒数。unix时间戳不仅被使用在unix系统、类unix系统中,也在许多其他操作系统中被广泛采用。

UNIX_TIMESTAMP(tm) 在sql server下应该怎么改写


mysql中

UNIX_TIMESTAMP() 

返回值:自’1970-01-01 00:00:00’的到当前时间的秒数差


sqlserver下

select DATEDIFF(SS,’1970-01-01 00:00:00’,GETDATE())

解析mysql中UNIX_TIMESTAMP()函数与php中time()函数的区别


mysql
中:UNIX_TIMESTAMP(),
UNIX_TIMESTAMP(date)
若无参数调用,则返回一个Unix
timestamp
(’1970-01-01
00:00:00’
GMT
之后的秒数)
作为无符号整数。若用date
来调用UNIX_TIMESTAMP(),它会将参数值以’1970-01-01
00:00:00’
GMT后的秒数的形式返回。date
可以是一个DATE
字符串、一个
DATETIME字符串、一个
TIMESTAMP或一个当地时间的YYMMDD
或YYYMMDD格式的数字。
mysql》
SELECT
UNIX_TIMESTAMP();
-》
882226357
mysql》
SELECT
UNIX_TIMESTAMP(’1997-10-04
22:23:00’);
-》
875996580

UNIX_TIMESTAMP被用在
TIMESTAMP列时,
函数直接返回内部时戳值,
而不进行任何隐含的
“string-to-Unix-timestamp”转化。假如你向UNIX_TIMESTAMP()传递一个溢出日期,它会返回
0,但请注意只有基本范围检查会被履行
(年份从1970

2037,
月份从01到12,日期从
01
到31)。
这里我们可以使用
FROM_UNIXTIME(unix_timestamp),
FROM_UNIXTIME(unix_timestamp,format)来格式化一个UNIX_TIMESTAMP()时间戳,它将返回’YYYY-MM-DD
HH:MM:SS’或YYYYMMDDHHMMSS
格式值的unix_timestamp参数表示,具体格式取决于该函数是否用在字符串中或是数字语境中。
若format
已经给出,则结果的格式是根据format
字符串而定。
format
可以包含同DATE_FORMAT()
函数输入项列表中相同的说明符。
mysql》
SELECT
FROM_UNIXTIME(875996580);
-》
’1997-10-04
22:23:00’
mysql》
SELECT
FROM_UNIXTIME(875996580)
+
0;
-》
19971004222300
mysql》
SELECT
FROM_UNIXTIME(UNIX_TIMESTAMP(),
-》
’%Y
%D
%M
%h:%i:%s
%x’);
-》
’2003
6th
August
06:22:58
2003’
php中:time()
time
--
返回当前的
Unix
时间戳
返回自从
Unix
纪元(格林威治时间
1970

1

1

00:00:00)到当前时间的秒数。
从字面上理解他们是一样的,都是返回
自从
Unix
纪元到当前时间的秒数。
笔者在同一台服务器上做了一个测试,发现两者返回的结果是一样的

在mysql中用
FROM_UNIXTIME(
1156219870
,’%y-%m-%d’
)
和php中用date(
“y-m-d“,1156219870
)结果也是一样相同的!唯一不肯确定的是那一个反应更加快速。不过我还是倾向与用php中的time()函数!
-unix_timestamp