Jump to content

Select que mostre idade dos "Clientes"


chell515
 Share

Recommended Posts

Boas a todos!

Como não tenho muita experiência a nível de SQL tenho-me deparado com alguns problemas e estou novamente a precisar da vossa ajuda.

Preciso de fazer um select em que me mostre a idade dos clientes. Esse calculo é feito através da data de nascimentos dos mesmos. Para calcular a idade de cada cliente eu já fiz a função que passo a mostrar:

declare @dataNasc			date
declare @cliente_id		int

set @cliente_id = 18
set @dataNasc	 = (select DataNascimento from LC_Clientes where ClienteID=@cliente_id)


select case when DATEADD(year,DATEDIFF(year,@dataNasc,GETDATE()),@dataNasc) <= GETDATE() then DATEDIFF(year,@dataNasc,GETDATE()) else
DATEDIFF(year,@dataNasc,GETDATE()) - 1 end as Idade

Agora eu gostaria de utilizar isto mas que me mostrasse numa tabela os dados de todos os meus clientes mas não o estou a conseguir fazer.

Obrigado por toda a ajuda que me possam dispensar 😛

Cumpz

Link to comment
Share on other sites

Boas a todos!

Como não tenho muita experiência a nível de SQL tenho-me deparado com alguns problemas e estou novamente a precisar da vossa ajuda.

Preciso de fazer um select em que me mostre a idade dos clientes. Esse calculo é feito através da data de nascimentos dos mesmos. Para calcular a idade de cada cliente eu já fiz a função que passo a mostrar:

declare @dataNasc			date
declare @cliente_id		int

set @cliente_id = 18
set @dataNasc	 = (select DataNascimento from LC_Clientes where ClienteID=@cliente_id)


select case when DATEADD(year,DATEDIFF(year,@dataNasc,GETDATE()),@dataNasc) <= GETDATE() then DATEDIFF(year,@dataNasc,GETDATE()) else
DATEDIFF(year,@dataNasc,GETDATE()) - 1 end as Idade

Agora eu gostaria de utilizar isto mas que me mostrasse numa tabela os dados de todos os meus clientes mas não o estou a conseguir fazer.

Obrigado por toda a ajuda que me possam dispensar 😛

Cumpz

Isto não serve?

SELECT *, CASE WHEN DATEADD(YEAR,DATEDIFF(YEAR,DataNascimento,GETDATE()),DataNascimento) <= GETDATE() THEN DATEDIFF(YEAR,DataNascimento,GETDATE()) ELSE
DATEDIFF(YEAR,DataNascimento,GETDATE()) - 1 END AS Idade
FROM LC_Clientes WHERE ClienteID=@cliente_id

Ou seja, em vez de carregares numa variavel a data de nascimento, aplicas no teu CASE o campo directamente.

Pus o WHERE ClienteID=@cliente_id mas podes remover se quiseres mostrar TODOS os clientes.

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.