一、前言
记得在以前学习机房收费系统的时候,那个时候要计算上机时间,当时都是获取的自己本机的时间来计算的,其实当时自己这么做也是比较正确的,原因小编在后面道来。
二、对服务器时间的一些看法
当时只是获取的是系统的时间,而我们这里应该是要求获取服务器的时间,这里的服务器的时间具体指的是什么呢?经过咱们用了分布式后,咱们的服务器有很多,比如系统发布的服务器,系统数据库的服务器,文件服务器等等。小编分析后,咱们应该获取的是数据库服务器的时间。
原因很简单,咱们要获取信息,都要从数据库服务器取东西,所以数据库服务器的时间是比较准确的。
再回到自己当时做的机房收费系统,从自己当时的硬件环境来看:数据库和系统都在一台电脑上。经过小编测试,获取服务器的时间比获取系统System的时间快一秒。就差一秒,对于当时的机房收费系统没有必要计算了,完全可以省略掉。
三、获取服务器的时间
其实说是要获取服务器的时间,其实最简单的就是对数据库做手脚了,只需我们在建立数据库表的时候添加一个字段,并设置他的默认值属性,就可以解决这个问题了。
小编迄今为止接触了很多的数据库了,其中比较常用的有以下的三款,但是根据不同的数据库他们建立表的时候插入服务器时间的语句是不一样的。所以小编汇总了一下,以供大家共同学习。
3.1 SQL server
SQL server的很容易获得,直接DEFAULT GETDATE(),就可以使用。
- 建库语句
CREATE TABLE Orders
(
OrderId int NOT NULL PRIMARY KEY,
ProductName varchar(50) NOT NULL,
OrderDate datetime NOT NULL DEFAULT GETDATE()
)
- 查询语句
SELECT GETDATE()
3.2 MySQL
MySQL的字段默认值不可以是函数。除 TIMESTAMP字段可以用CURRENT_TIMESTAMP外。其它都使用常数为默认值。
- 建库语句
CREATE TABLE Orders
(
OrderId int(10) NOT NULL PRIMARY KEY,
ProductName varchar(50) NOT NULL,
OrderDate DATE NOT NULL ,
CheckDate TIMESTAMP not NULL DEFAULT CURRENT_TIMESTAMP()
)
-查询语句
select CURRENT_TIMESTAMP()
3.3 Oracle
从 Oracle 9i开始,可以在 DEFAULT 子句中使用诸如 SYSDATE 或 CURRENT_TIMESTAMPE ,不可以是SYSDATE()或者CURRENT_TIMESTAMPE()。而且Oracle的查询语句和其他的也不太一样,需要写form +表。
- 建库语句
CREATE TABLE Orders
(
OrderId int(10) NOT NULL PRIMARY KEY,
ProductName varchar(50) NOT NULL,
OrderDate DATE NOT NULL ,
CheckDate TIMESTAMP DEFAULT sysdate
)
- 查询语句
select sysdate from ORDERS
3.4 参考博客
四、小结
出来混总是要还的,但是还的时候就会更多了,当时只接处了SQL server,没有接触分布式的概念,所以有点模糊,但是当你在这条路上走的更加的远的时候,你就会发现我学到的东西还是有很多的。理解的也就越深刻!加油!