Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/26.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
SQL Server条件检查约束_Sql_Sql Server_Sql Server 2008_Tsql_Alter Table - Fatal编程技术网

SQL Server条件检查约束

SQL Server条件检查约束,sql,sql-server,sql-server-2008,tsql,alter-table,Sql,Sql Server,Sql Server 2008,Tsql,Alter Table,我正在使用SQLServer2008ManagementStudio。下面是我必须写的内容,对于第二个约束,我有一些困难。这让我有点困惑,我真的很感谢你的帮助 编写ALTER TABLE语句,将两个新的检查约束添加到AP数据库的发票表中。第一个选项应允许(1)PaymentDate仅在PaymentTotal为零时为null,并且(2)PaymentDate仅在PaymentTotal大于零时不为null。第二个约束应防止PaymentTotal和CreditTotal之和大于InvoiceTo

我正在使用SQLServer2008ManagementStudio。下面是我必须写的内容,对于第二个约束,我有一些困难。这让我有点困惑,我真的很感谢你的帮助

编写ALTER TABLE语句,将两个新的检查约束添加到AP数据库的发票表中。第一个选项应允许(1)PaymentDate仅在PaymentTotal为零时为null,并且(2)PaymentDate仅在PaymentTotal大于零时不为null。第二个约束应防止PaymentTotal和CreditTotal之和大于InvoiceTotal

ALTER TABLE Invoices WITH CHECK
ADD check (
    (PaymentTotal = 0 AND PaymentDate is NULL)
    OR
    (PaymentTotal > 0 AND PaymentDate is NOT NULL)
)
ADD CHECK (
    (PaymentTotal < InvoiceTotal = SUM)
    OR
    (CreditTotal < InvoiceTotal = SUM)
)
到目前为止,第一个约束有效,但第二个约束无效(PaymentTotal和CreditTotal之和不大于InvoiceTotal)

使用支票更改表格发票
加支票(
(PaymentTotal=0且PaymentDate为空)
或
(PaymentTotal>0且PaymentDate不为空)
)
加支票(
(付款总额<发票总额=总额)
或
(贷记总额<发票总额=总额)
)
提前谢谢。

。。。
...
ADD CHECK (
    PaymentTotal + CreditTotal <= InvoiceTotal
)
加支票(
PaymentTotal+CreditTotal您已经编写了一个没有参数的聚合函数(
SUM()

“第二个约束应防止PaymentTotal和CreditTotal之和大于InvoiceTotal。”这让我有点困惑,但您应该将其更改为:

ALTER TABLE Invoices WITH CHECK 
ADD check ( 
    (PaymentTotal = 0 AND PaymentDate is NULL) 
    OR 
    (PaymentTotal > 0 AND PaymentDate is NOT NULL) 
) 
go

ALTER TABLE Invoices WITH CHECK
ADD CHECK ( 
    (PaymentTotal + CreditTotal) <= InvoiceTotal 
) 
go
使用支票更改表格发票
加支票(
(PaymentTotal=0且PaymentDate为空)
或
(PaymentTotal>0且PaymentDate不为空)
) 
去
用支票更改表格发票
加支票(

(PaymentTotal+CreditTotal)第一步是告诉你发生了什么事非常感谢你帮我回答这个问题。我真的很感激。再次感谢你