I want not to allow my DB user to enter bigger dates than 2017-03-18. How can add this constraint to my table?
Is this Correct?
(Year([ContractEnd])<2017) and (Month([ContractEnd])<03) and (Day([ContractEnd])<18)
You can add a constraint like that to an existing table like so:
alter table t add constraint chk_ContractEnd_lt_20170319
check (ContractEnd<'20170319');
rextester demo: http://rextester.com/FQWFMI88817
create table t (
id int not null identity(1,1)
, ContractEnd date
/* at table creation */
, constraint chk_ContractEnd_lt_20170319 check (ContractEnd<'20170319')
)
alter table t drop constraint chk_ContractEnd_lt_20170319;
/* to existing table */
alter table t add constraint chk_ContractEnd_lt_20170319
check (ContractEnd<='20170318');
insert into t values ('20161231')
insert into t values ('20170318')
/* all good */
insert into t values ('20170319')
/* -- Error, constraint violation */
datetime or datetime2, then using ContractEnd < '20170102' might be necessary.Try
[ContractEnd] DATE CHECK ([ContractEnd] <= '20170318')
alter table Professor add constraint . do you know how to remove it?SELECT * FROM sys.check_constraints WHERE object_id = OBJECT_ID(N'CK_Professor') AND parent_object_id = OBJECT_ID(N'Professor')
ContractEnd?DATETIME?