postgresql是如何求年龄的_Postgresql 通过出生日期获取年龄的操作

三个基础的时间表示函数 current_date/current_time/now()

select current_date ;

返回当前日期以 年-月-日(yyyy-mm-dd)的形式:

2019-01-10

select current_time;

返回当日时间以 时:分:秒+时区(hh:mm:ss )的形式:

17:49:11.585308+08

select now();

返回当前时间 以 年-月-日 时:分:秒(yyyy-mm-dd hh:mm:ss)的形式:

2019-01-10 17:50:45.354983+0

然后几个计算公式

第一种是直接对日期进行操作,

select (current_date - '1993-01-01')/365 age; select (current_date - '1993-01-01 16:00:00')/365 age;

输出 26 26 两种时间格式结果一致

第二种方式

select age(current_date, '1993-01-01') age; select age(current_date, '1993-01-01 16:00:00') age;

输出

26 years 9 days

26 years 8 days 08:00:00

age()函数会输出精确的年龄字符串,根据传入的时间不同,输出的时间格式相对应

如果使用now()函数计算,需要注意age()函数能输出正确结果,直接计算单位为day

select age(current_date, '1993-01-01') age;

select age(current_date, '1993-01-01 16:00:00') age;

select (now() - '1993-01-01')/365 age;

select (now() - '1993-01-01 16:00:00')/365 age

分别输出

26 years 9 days 19:20:46.395713

26 years 9 days 03:20:46.421816

26 days 01:02:21.497111

26 days 00:59:43.688958

补充:postgresql获取当前时间的四种方式

postgresql中有四种获取当前时间的方式。

1.now()

80ff60ec57010e48df4f6db559facfbb.png

返回值:当前年月日、时分秒,且秒保留6位小数。

2.current_timestamp

1053efaa786eec6335d8694760eba9fb.png

返回值:当前年月日、时分秒,且秒保留6位小数。(同上)

申明:now和current_timestamp几乎没区别,返回值相同,建议用now。

3.current_time

e598bc5ef5d4615129380108543c0cef.png

返回值:时分秒,秒最高精确到6位

4.current_date

3fdb4d207cd06fb9faa78e650a48c88e.png

返回值:年月日

以上为个人经验,希望能给大家一个参考,也希望大家多多支持萬仟网。如有错误或未考虑完全的地方,望不吝赐教。

希望与广大网友互动??

点此进行留言吧!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/246439.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python关闭浏览器删除session_Django操作session 的方法

session是存放在服务端的,在django中使用session必须要先在数据库中创建django_session表,session相关信息都要依赖此表获取sessionrequest.session[status]request.session.get(status)#一般用get,无此键返回None不报错设置session#在使用se…

python压缩文件不带根路径_python 压缩文件(解决压缩路径问题)

#压缩文件def Zip_files(): datapath filepath# 证据路径file_newname datapath .zip# 压缩文件的名字log.debug(file_newname) z zipfile.ZipFile(file_newname,w,zipfile.ZIP_DEFLATED) for dirpath,dirmanes,filenames in os.walk(datapath): fpath dirpath.replace(da…

python网页保存为图片_使用Python保存网页上的图片或者保存页面为截图

Python保存网页图片这个是个比较简单的例子,网页中的图片地址都是使用http://。。。。.jpg这种方式直接定义的。使用前,可以先建立好一个文件夹用于保存图片,本例子中使用的文件夹是 d:\\pythonPath这个文件夹代码如下:# -*- codi…

libnss mysql_Ubuntu通过LDAP集成AD域账号登录(libnss-ldap方式)

Ubuntu通过LDAP集成AD域账号登录(libnss-ldap方式):# apt-get install libnss-ldap (中间直接回车,忽略)# vi /etc/nsswitch.confpasswd: files ldapgroup: files ldapshadow: files ldap:wq# vi /etc/ldap.confbase dcming,dccomuri ldap://10.0.0.2…

mysql分页查询减轻压力_mysql分页查询优化

在实际的项目中,分页查询是在寻常不过的,甚至说不可避免的。通常数据量较少的时候,很难遇到效率的影响。但是当数据量较大时,一个普通的分页sql能让你恶心到家。我们常用的分页sql如下:1 SELECT * FROM table_name LIM…

python csv读写方法_python中csv文件的若干读写方法小结

如下所示: //用普通文本文件方式打开和操作with open("file.csv") as cf:linescf.readlines()...... //用普通文本方式打开,用csv模块操作import csvwith open("file.csv") as cf:linescsv.reader(cf)for line in lines:print(line)…

unity 世界坐标间角度_Unity 世界坐标局部坐标下的旋转

一、旋转方法在 Unity 中为物体旋转提供了各种 API ,例如 RotateAround、Rotate、LookAt 等方法。但为了避免万向节死锁的问题,一般使用四元数来表示物体的旋转。四元数的乘法可以看作对一个物体施加两次旋转,最终的旋转角度由这两次旋转的角…

删除mysql会不会留下痕迹_MySQL使用痕迹清理~/.mysql_history

mysql会给出咱们最近执行的SQL命令和脚本;同linux command保存在~/.bash_history同样,你用mysql链接MySQL server的全部操做也会被记录到~/.mysql_history文件中,这样就会有很大的安全风险了,如添加MySQL用户的sql也一样会被明文记…

ioc框架 java_从零开始实现一个简易的Java MVC框架(三)--实现IOC

Spring中的IOCIoC全称是Inversion of Control,就是控制反转,他其实不是spring独有的特性或者说也不是java的特性,他是一种设计思想。而DI(Dependency Injection),即依赖注入就是Ioc的一种实现方式。关于Ioc和DI的具体定义和优缺点…

java word文档生成目录_JAVA合并word文档生成目录

/*** 先临时生成一个合并完成后的docx格式文档,doc会出现乱码。*parampathList 所有需要合并的文档的绝对路径*paramsavePath 一个路径,但是没有文件的后缀,之后进行拼接。*return状态,是否保存成功*/public static boolean merge…

java 链表实现堆栈_《Java数据结构与算法》笔记-CH5-链表-4用链表实现堆栈

//用链表实现堆栈/*** 节点类*/class LinkS {private long data;public LinkS next;public LinkS(long d) {this.data d;}public String toString() {return String.valueOf(data);}}/*** 链表类*/class LinkSList {private LinkS first;public LinkSList() {first null;}pub…

java set去重复元素_java List去掉重复元素的几种方式

使用LinkedHashSet删除arraylist中的重复数据(有序)List words Arrays.asList("a","b","b","c","c","d");HashSet setnew LinkedHashSet<>(words);for(String word:set){System.out.println(word);}使用Has…

b树索引 java_B树索引最通俗易懂的介绍

先来一段有莫的对话&#xff1a;前几天下班回到家后正在处理一个白天没解决的bug&#xff0c;厕所突然传来对象的声音&#xff1a;对象&#xff1a;xx&#xff0c;你有《时间简史》吗&#xff1f;我&#xff1a;我去&#xff01;妹子&#xff0c;你这啥癖好啊&#xff0c;我有时…

jython mysql_Jython

gomysql###介绍gomysql是基于go-sql-driver基础上开发的orm&#xff0c;这是一个轻量级的库。它会使数据库的增删改查变得非常容易。当然也是测试开发版&#xff0c;会一直优化和更新&#xff01;请时刻关注我们###安装go get github.com/go-sql-driver/mysqlgo get github.com…

java人种_Java面向对象练习题继承之人种

//People类package 继承;public class People {private String name;private double height;private double weight;public String getName() {return name;}public void setName(String name) {this.name name;}public double getHeight() {return height;}public void setHe…

java gz文件解压_java – 批量解压缩.gz文件

a)Zip是一种存档格式,而gzip则不是.因此,除非(例如)你的gz文件是压缩的tar文件,否则入口迭代器没有多大意义.你想要的可能是&#xff1a;File outFile new File(infile.getParent(),infile.getName().replaceAll("\\.gz$",""));b)你只想解压缩文件吗&…

java调C接口_java通过jni调用C程序接口

打算写一个FbSetApp去操作framebuffer的设备文件&#xff0c;以便能够去设置FB的一些参数。新建两个classFbParams.java&#xff1a;package org.trident.fbset;public class FbParams {int pos_x;int pos_y;int size_x;//Widthint size_y;//Height}用于传递FB起始位置和大小的…

java 5 新特性 for_java5 新特性

java1.5 放宽了对类继承过程中方法覆盖的限制&#xff0c;在此之前&#xff0c;除必须一致的方法名及参数列表外&#xff0c;返回类型也必须相同而 java1.5 以后&#xff0c;子类中覆盖的方法的返回类型可以是父类中被覆盖方法返回类型的子类这个小小的变化让 java 的面向对象编…

java与bartender_Java调取Bartender使用教程.md

# Java调取Bartender使用教程[toc]## 非首次安装### 一、在已安装目录中双击"stop.vbs"停止原有程序![enter description here](http://img.huijia21.com/blog/1611538410129.png)### 二、下载新的打印模板"JavaBarTenderPrint.zip"并解压![enter descript…

java Ajax cache_ajax之cache血与泪~~

场景&#xff1a;项目以ie5渲染页面&#xff0c;点击导出列表数据(Excel形式)&#xff0c;点击导出发送get请求&#xff0c;后台生成Excel文件&#xff0c;返回文件地址信息异常&#xff1a;ie第一次返回的信息正常&#xff0c;之后返回的都是第一次的结果&#xff0c;google正…