2
나는 학생 연령을 연령 + 월로 변환하는 방법을 알아 내려고하고 있습니다. 예를 들어 학생 생년월일이 1/1/2000 인 경우 학생 연령은 16 개월과 6 개월로 표시됩니다.연령 형식 - 년 및 월
학생 연령을 전체 숫자로 표시하도록 스크립트를 작성할 수 있지만 오전 개월을 포함시키는 방법을 모릅니다. 무엇을 바꾸어야합니까? 당신은 정밀 걱정하지 않는 경우
ALTER procedure [dbo].[RP_Student_Attendance] (@perf_code varchar(10))
as
-- set @perf_code = '3496A'
SELECT
i.short_name,
i.text1 as perf_desc,
i.text2 perf_dates,
i.text3 perf_times,
p.perf_no,
h.[Role],
h.customer_no,
c.sex, b.birthday,
g.grade_level,
--(DATEDIFF(yy,b.birthday,GETDATE())) as student_age,
student_age = CASE
WHEN dateadd(year, datediff (year, b.birthday, GETDATE()),b.birthday) > GETDATE()
THEN datediff (year, b.birthday, GETDATE()) - 1
ELSE datediff (year, b.birthday, GETDATE())end,
c.fname + ' ' + c.lname as student_name
FROM T_INVENTORY i
JOIN T_PERF p on i.inv_no = p.perf_no
JOIN T_TICKET_HISTORY h on p.perf_no = h.perf_no and [Role] = 4
JOIN T_CUSTOMER c on h.customer_no = c.customer_no
LEFT JOIN (select customer_no, key_value as birthday from TX_CUST_KEYWORD where keyword_no = 1) b on c.customer_no = b.customer_no
LEFT JOIN (select customer_no, key_value as grade_level from TX_CUST_KEYWORD where keyword_no = 428) g on c.customer_no = g.customer_no
WHERE p.perf_code = @perf_code