作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将一些数据插入到包含两个内容的表中:“一个字符串”和“Order
列中的最大数字 + 1”。
这是我的查询:
INSERT INTO MyTable ([Text],[Order])
SELECT 'MyText' , (Max([Order]) + 1)
FROM MyTable
我的查询出了什么问题?
我使用的是 Microsoft SQL Server 2005 SP3。
最佳答案
您可以像这样测试这个查询:
我没有收到错误:
create table #MyTable
(
[Text] varchar(40),
[Order] int NOT NULL
)
INSERT INTO #MyTable([Text],[Order])
SELECT 'MyText' [Text], isnull(max([order]) + 1, 0) [Order]
FROM #MyTable
drop table #MyTable
原文:
INSERT INTO MyTable ([Text],[Order])
SELECT 'MyText' [Text], max([Order]) + 1 [Order]
FROM MyTable
或
INSERT INTO MyTable ([Text],[Order])
SELECT top 1 'MyText' [Text], max([Order]) + 1 [Order]
FROM MyTable
据我所知,限制在 SQL Server 中无效。
关于sql - INSERT INTO 使用子查询和一些操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8843047/
我是一名优秀的程序员,十分优秀!