【数据库】获取服务器时间

一、前言

      记得在以前学习机房收费系统的时候,那个时候要计算上机时间,当时都是获取的自己本机的时间来计算的,其实当时自己这么做也是比较正确的,原因小编在后面道来。

二、对服务器时间的一些看法

      当时只是获取的是系统的时间,而我们这里应该是要求获取服务器的时间,这里的服务器的时间具体指的是什么呢?经过咱们用了分布式后,咱们的服务器有很多,比如系统发布的服务器,系统数据库的服务器,文件服务器等等。小编分析后,咱们应该获取的是数据库服务器的时间。

      原因很简单,咱们要获取信息,都要从数据库服务器取东西,所以数据库服务器的时间是比较准确的。

      再回到自己当时做的机房收费系统,从自己当时的硬件环境来看:数据库和系统都在一台电脑上。经过小编测试,获取服务器的时间比获取系统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,没有接触分布式的概念,所以有点模糊,但是当你在这条路上走的更加的远的时候,你就会发现我学到的东西还是有很多的。理解的也就越深刻!加油!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你个佬六

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值