【问题标题】:How i can run this mysql query in SQL Server? [duplicate]我如何在 SQL Server 中运行这个 mysql 查询? [复制]
【发布时间】:2018-02-09 08:10:39
【问题描述】:

基本上我需要在 SQL Server 中运行这个查询。我在 MySQL 中执行,效果很好。

SET @startID:=29;
update test
set ID=@startID:=@startID+1;

谢谢

【问题讨论】:

  • 这个查询应该做什么?只是将一个字段设置为 30?你有没有尝试过,甚至检查过变量的语法?
  • 他正在尝试用变量@startID 的值更新ID 列,并使其在每次更新一行时递增。
  • 如果你想创建递增值,MySQL 查询实际上是一个很容易失败的 hack。 SQL Server 具有序列、IDENTITY 列和排名函数。
  • @MBijen 这是企图破解,而不是 OP 想要实现的目标。例如,为什么不在 UPDATE 之前增加值?为什么不从一开始就设置为 30?
  • @panagiotis-kanavos 我同意你的看法。

标签: mysql sql sql-server


【解决方案1】:

你可以这样做:

SET @startID = 29
update test
set user_id = @startID, @startID=@startID+1

它会在每次更新时递增@startID 变量。

【讨论】:

  • 为什么要这样做而不是在更新之前增加变量之前? OP 是否打算将所有 ID 设置为相同的数字?在 SQL Server 中创建数字序列的方法有很多,不需要古怪的更新
  • 提供的查询在 mysql 中创建了一个数字序列。我同意你的观点,在 SQL Server 中有更好的方法来做到这一点。
【解决方案2】:

试试这个格式

declare @startid int;
set @startid = 29;
update test set ID = @startid+1;

【讨论】:

  • 他想按顺序编号。
  • 您更新的是变量而不是表?
猜你喜欢
  • 1970-01-01
  • 2013-02-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-01-05
相关资源
最近更新 更多