MySQL的FROM_UNIXTIME()和UNIX_TIMESTAMP()函數的區別
2016-01-05 21:16
597 查看
MySQL的FROM_UNIXTIME()和UNIX_TIMESTAMP()函數的區別
from_unixtime()是MySQL里的時間函數date為需要處理的參數(該參數是Unix 時間戳),可以是欄位名,也可以直接是Unix 時間戳字元串
後面的 '%Y%m%d' 主要是將返回值格式化
例如:
mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y%m%d' )
->20071120
mysql>SELECT FROM_UNIXTIME( 1249488000, '%Y年%m月%d' )
->2007年11月20
UNIX_TIMESTAMP()是與之相對正好相反的時間函數
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() ; (執行使得時間:2009-08-06 10:10:40)
->1249524739
mysql> SELECT UNIX_TIMESTAMP('2009-08-06') ;
->1249488000
如何在不同編程語言中獲取現在的Unix時間戳(Unix timestamp)?
Java | time |
JavaScript | Math.round(new Date().getTime()/1000) getTime()返回數值的單位是毫秒 |
Microsoft .NET / C# | epoch = (DateTime.Now.ToUniversalTime().Ticks - 621355968000000000) / 10000000 |
MySQL | SELECT unix_timestamp(now()) |
Perl | time |
PHP | time() |
PostgreSQL | SELECT extract(epoch FROM now()) |
Python | 先 import time 然後 time.time() |
Ruby | 獲取Unix時間戳:Time.now 或 Time.new 顯示Unix時間戳:Time.now.to_i |
SQL Server | SELECT DATEDIFF(s, '1970-01-01 00:00:00', GETUTCDATE()) |
Unix / Linux | date +%s |
VBScript / ASP | DateDiff("s", "01/01/1970 00:00:00", Now()) |
其他操作系統 (如果Perl被安裝在系統中) | 命令行狀態:perl -e "print time" |
如何在不同編程語言中實現Unix時間戳(Unix timestamp) → 普通時間?
Java | String date = new java.text.SimpleDateFormat("dd/MM/yyyy HH:mm:ss").format(new java.util.Date(Unix timestamp * 1000)) |
JavaScript | 先 var unixTimestamp = new Date(Unix timestamp * 1000) 然後 commonTime = unixTimestamp.toLocaleString() |
Linux | date -d @Unix timestamp |
MySQL | from_unixtime(Unix timestamp) |
Perl | 先 my $time = Unix timestamp 然後 my ($sec, $min, $hour, $day, $month, $year) = (localtime($time))[0,1,2,3,4,5,6] |
PHP | date('r', Unix timestamp) |
PostgreSQL | SELECT TIMESTAMP WITH TIME ZONE 'epoch' + Unix timestamp) * INTERVAL '1 second'; |
Python | 先 import time 然後 time.gmtime(Unix timestamp) |
Ruby | Time.at(Unix timestamp) |
SQL Server | DATEADD(s, Unix timestamp, '1970-01-01 00:00:00') |
VBScript / ASP | DateAdd("s", Unix timestamp, "01/01/1970 00:00:00") |
其他操作系統 (如果Perl被安裝在系統中) | 命令行狀態:perl -e "print scalar(localtime(Unix timestamp))" |
相关文章推荐
- MySQL索引和查询优化
- (笔记)Mysql命令show databases:显示所有数据库
- (笔记)Mysql命令create:创建数据库
- (笔记)Mysql命令grant on:增加新用户并控制其权限
- (笔记)Mysql命令mysqladmin:修改用户密码
- (笔记)Mysql命令mysql:连接Mysql数据库
- mysql错误汇总
- mysql
- MySQL 去除字段中的换行和回车符
- MYSQL学习
- MySql解压版配置
- [实战]MVC5+EF6+MySql企业网盘实战(24)——视频列表
- mysql 乱码 utf8
- Mysql 数据库学习 简单的增删改查
- mysql 查看锁表解锁
- Pentaho 5.4.0 安装及mysql配置
- left,right,substring,substring_index MySQL截取字符串函数方法
- navicat 链接不上mysql
- mysql sql语句大全
- mysql数据库忘记密码时如何修改