server sql 将出生日期转为年龄_sql server 根据身份证号计算出生日期和年龄的存储过程...

这篇博客介绍了一个在SQL Server中根据身份证号计算出生日期和年龄的存储过程实现。详细步骤包括从身份证号提取出生日期、计算当前年龄,并提供了存储过程的创建和调用示例。
摘要由CSDN通过智能技术生成

我这边有一个业务,需要客户填写身份证号,自动计算他的出生日期和年龄

在sql中,具体的存储过程实现是这样的:

/***********************************************

根据身份证号计算出生日期和年龄

Date:2017-10-15

Author:xzl

条件:身份证号码

返回:出生日期和年龄

***********************************************/

/***

*根据身份证号计算出生日期和年龄

***/

create proc [dbo].[sp_GetBirthDate_Age]

@IDCard varchar(20),

@BirthDate varchar(20) output,

@Age int output

as

begin

--声明变量--

declare @BirthDateStr varchar(10)

declare @YearStr varchar(10)

declare @MonthStr varchar(10)

declare @DayStr varchar(10)

declare @NowDateStr varchar(20)

declare @AgeStr varchar(10)

----1、根据身份证号,计算出生日期---

--设置IDCard值

--set @IDCard ='445182199403123781'

--1)获取身份证号中年月日部分(返回:19940312)--

set @BirthDateStr = SUBSTRING(@IDCard,7,8)

--2)将获取年月日字符串转化为对应日期格式--

--2.1)获取年部分--

set @YearStr = SUBSTRING(@BirthDateStr,1,4)

--2.2)获取月部分--

set @MonthStr = SUBSTRING(@BirthDateStr,5,2)

--2.3)获取日部分--

set @DayStr = SUBSTRING(@BirthDateStr,7,2)

--3)返回组合后的日期---

set @BirthDate = @YearStr +'-'+@MonthStr+'-'+@DayStr

--2、根据出生日期和当前日期,计算年龄--

--1)获取当前时间的日期部分(返回:2017-10-15)--

set @NowDateStr = CONVERT(varchar(10),GETDATE(),23)

--2)获取当前日期与出生日期的年份(年龄) 返回:23岁 --

set @AgeStr = DATEDI

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值