Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/71.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_Select - Fatal编程技术网

SQL Server-选择最大值

SQL Server-选择最大值,sql,sql-server,select,Sql,Sql Server,Select,我有一个带有update语句的SQL Server存储过程: UPDATE Sale_Sheet SET concluded = 'True' , concluded_time = GETDATE() , saleNumber = (SELECT MAX(saleNumber) + 1 FROM Sale_Sheet) WHERE vatNumber = @vatNumber AND [user_id] = @user_id 两个用户同时启动一个过程,两个用户从Sale_

我有一个带有update语句的SQL Server存储过程:

UPDATE Sale_Sheet 
SET concluded = 'True'
    , concluded_time = GETDATE()
    , saleNumber = (SELECT MAX(saleNumber) + 1 FROM Sale_Sheet)
WHERE vatNumber = @vatNumber
  AND [user_id] = @user_id

两个用户同时启动一个过程,两个用户从Sale_Sheet接收到相同的最大值SELECT MAXsaleNumber+1。如何解决此问题?

您可以使用ROW\u NUMBER OVER只更新一行。看起来您需要一个自动增量列或序列。可能是交易?您应该使用销售标识列。\u Sheet.saleNumber。每当您看到id=select maxid+1…,您就错了。