Jump to content
reznor

Constraints

Recommended Posts

reznor

Boa tarde!

Estou com dificuldades nas constraints, como por exemplo codigo postal...

Alguem sabe onde posso arranjar bons pedaços de codigo que me ajudem nisto?

Cumprimentos,

Share this post


Link to post
Share on other sites
reznor

foi por onde comecei :P

Eu explico, se puder ser util.

Tenho uma tabela cliente onde CodigoPostal é uma row. Na constraint declaro

ALTER TABLE [dbo].[Cliente]
ADD CONSTRAINT CK_Cliente_CodigoPostal
CHECK ( [CodigoPostal] LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9] ')
GO

O tipo de dados de CodigoPostal é char(10).

Ao inserir os dados no MSSQL dá erro de tipo de dados, o que poderá ser?

Share this post


Link to post
Share on other sites
pikax

tens um espaco a mais no final da expressao...

ALTER TABLE [dbo].[Cliente]
ADD CONSTRAINT CK_Cliente_CodigoPostal
CHECK ( [CodigoPostal] LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9]')
GO


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Share this post


Link to post
Share on other sites
reznor

tens um espaco a mais no final da expressao...

ALTER TABLE [dbo].[Cliente]
ADD CONSTRAINT CK_Cliente_CodigoPostal
CHECK ( [CodigoPostal] LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9]')
GO

mesmo assim, quando vou inserir para testar, por exemplo 1111-111, dá-me erro no mssql.... nao sei o que se passa

Share this post


Link to post
Share on other sites
pikax

em vez de ser char(10) mete como varchar(10)


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Share this post


Link to post
Share on other sites
pikax

SELECT 'Valido' WHERE '2010-115  ' LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9]' --devolve valido
SELECT 'Valido' WHERE '2010-115' LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9]' --devolve valido
SELECT 'Valido' WHERE '2010-115A' LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9]' --nenhum resultado
SELECT 'Valido' WHERE 'A010-115A' LIKE '[0-9][0-9][0-9][0-9]-[0-9][0-9][0-9]' --nenhum resultado

quais sao os resultados que te aparece?


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Share this post


Link to post
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

×
×
  • 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.