Re: Где в MS SQL server настраивается формат времени?
- From
- Миклашевич Антон (2:5020/400)
- To
- Vit Karetny
- Date
- 2005-11-01T04:25:42Z
- Area
- SU.DBMS.SQL
From: "Миклашевич Антон" <666@kamtel.ru>
Hello, Vit!
You wrote to Миклашевич Антон on Mon, 31 Oct 2005 13:01:27 +0000 (UTC):
VK> Милостивый государь г-н Миклашевич Антон!
VK> Mon Oct 31 2005 13:40, Миклашевич Антон wrote to Vit Karetny:
VK>>> Например, в одной из таблиц есть такое ограничение для поля
VK>>> CREATDDT: (datepart(hour,[CREATDDT]) = 0 and
VK>>> datepart(minute,[CREATDDT]) = 0 and datepart(second,[CREATDDT]) = 0
VK>>> and datepart(millisecond,[CREATDDT]) = 0)
МА>> Тип поля CREATDDT?
VK> Datetime, естественно.
Мне этого отсюда не видать.
VK>>> В старой БД оно пропускает записи с датой и нулевым временем, а в
VK>>> новой вставка записи '2005-10-31 12:00:00 AM' отвергается с кодом
VK>>> @@ERROR=547.
МА>> Текст ошибки?
VK> Тексты все берутся из таблицы master.dbo.sysmessages по ключу
VK> Error=547:
Ты мне случаем не предлагаешь самому лезть за текстом ошибки? Хамишь.
VK> 'Insert statement conflicted with ... constraint ... The conflict
VK> occurred in database ..., table ...'
VK> Ничего удивительного, и в самом деле конфликтует, ведь Datepart(hour,
VK> поле) получается не нуль. Только как его, проклятого, свести к нулю?
VK> Мне пришлось использовать такую громоздкую конструкцию:
Выполнил у себя в QA след. код:
set dateformat ymd
declare @d datetime
set @d = '2005-10-31 12:00:00 AM'
select
datepart(hour, @d),
datepart(minute, @d),
datepart(second, @d),
datepart(millisecond, @d)
Возвратило все нули. А у тебя?
Кстати, попробуй констрэйнт такой:
convert(char(12), [CREATDDT], 114) = '00:00:00:000'
--- ifmail v.2.15dev5.3
* Origin: Demos online service (2:5020/400)
SEEN-BY: 46/50 50/12 203 520 450/159 186 1024 451/30 454/9 461/43 132 640
SEEN-BY: 469/999 4614/20 4616/3 4625/8 4627/10 4641/444 5000/76 5000 5001/5001
SEEN-BY: 5006/1 5007/1 5010/53 70 5011/13 5012/23 46 5015/10 28 5019/31
SEEN-BY: 5020/86 118 175 194 400 545 604 639 715 758 830 892 982 1042 1057
SEEN-BY: 5020/1200 1523 1604 1665 1909 1922 2013 2020 2238 4441 5021/3 29
SEEN-BY: 5022/128 5025/3 750 5026/10 14 45 5027/16 5029/32 5030/115 217 436
SEEN-BY: 5030/473 556 966 1063 1339 1900 5035/38 5036/1 34 5040/47 5042/13
SEEN-BY: 5045/7 5047/43 47 5049/1 5051/15 5053/16 5054/1 8 9 28 35 37 45 63 67
SEEN-BY: 5055/95 5057/1 5059/9 5060/88 5061/15 5062/1 5066/18 5069/7 5070/1222
SEEN-BY: 5077/70 5080/68 1003 5081/2 5082/6 5083/21 5084/32 5085/13 5090/106
SEEN-BY: 5093/27 5095/20 5099/133 6000/12 254 6009/1
PATH: 5020/400 4441 545 5054/1 37