在Excel和sqlserver中由身份证号码得到的相关信息

257 阅读1分钟

身份证号码的第7-10位表示出生年、第11-12位表示出生月、第13-14位表示出生日、第17位表示性别。在统计信息时,只需要统计准确的身份证号码,即可得到相关信息,不必重复统计。

一、出生日期

1、Excel

=DATE(MID(A2,7,4),MID(A2,11,2),MID(A2,13,2))

2、sqlserver

SELECT [sfzh],cast(substring(sfzh,7,8as dateas 出生日期 FROM [Table_1]

二、性别

1、Excel

=IF(MOD(MID(A2,17,1),2)=1,"男","女")

2、sqlserver

SELECT [sfzh],CASE SUBSTRING([sfzh],17,1)%2 WHEN 1 THEN '男' WHEN 0 THEN '女' END FROM [Table_1]

三、年龄

1、Excel的几种方式

=YEAR(NOW())-MID(A1,7,4)
=YEAR(TODAY())-MID(A1,7,4)
=YEAR(TODAY())-YEAR(DATE(MID(A1,7,4),MID(A1,11,2),MID(A1,13,2)))

2、sqlserver

SELECT [sfzh],year(getdate())- substring([sfzh],7,4) as 年龄  FROM [Table_1]