6

对不起,我试图提供很多信息以避免不相关的解决方案。

我的目标是将至少 1 个 UPDATE 语句嵌入到 SELECT 语句中,这样我就有机会在 select 语句运行之前更新一些计算值(把它想象成 SELECT 上的 TRIGGER)。VIEW 没有立即解决,因为我受到我正在使用的系统的限制(见下文)。

我正在定制一个功能较弱的第 3 方商业 ERP(系统将保持无名!- 结果是您还没有听说过它,但它也不是本土开发的)。它有一个预设查询工具,我可以在其中使用文本/GUI 来构建 SELECT 查询。保存查询后,用户可以单击查询来执行它并查看结果。ERP 在 MS SQL Server 2000 上运行;版本升级现在不在卡上。我可以用我想要的任何语言在 ERP 之外编写我需要的任何功能集,如果功能允许的话,我过去曾这样做过。但是当我的自定义可以在 ERP 系统中完成时,我的用户社区发现它更容易。

查询可以任意复杂,但 ERP 包自己构建 SQL Select 语句。编译后的 ERP 内部是这样的(这只是一个猜测!):

"SELECT " + fieldList + " FROM " + tableListAndJoins + " WHERE " + whereCond

GUI builder 帮助新手用户构建 fieldList 等,但您可以绕过它并以文本形式编写子句,只要 SQL 在如上组合时有效。

我似乎找不到一个咒语来运行存储过程作为 SELECT 语句的副作用,无论它是在 select 子句、where 子句等中。我真的不在乎我如何越狱系统——一个稳定的SQL注入攻击没问题,只要它不意味着我必须修改底层sql server本身的安全性。我查看了 UDF,但您不能将 UPDATE 语句放入标量 UDF,尝试修改表 UDF 的返回没有意义(或者这样做?)。如果您可以从 VIEW 中更新,那么我想看一个示例,但我意识到我可以使用 VIEW 来计算列,这不是我正在寻找的解决方案。我在网上阅读了关于能够使用某种 XP_ 来完成此操作的暗示性声明,但至于哪个 XP_ 或如何做到这一点,我不知道。

这个问题本身不是解决方案:Updating a table within a select statement

4

5 回答 5

1

我想不出任何方法可以在 SQL 2000 中将 SELECT 与 UPDATE 结合起来(尽管在 2005 年及更高版本中,OUTPUT 子句可用)。但是,看起来你得到了三个字符串值(fieldList、tableListAndJoins、whereCond),它们与“SELECT”、“FROM”和“WHERE”连接在一起,并假设它们没有进行一些严重的类似于 SQL 注入的代码检测,你也许可以把这样的东西拼凑在一起:

fileList = "NULL where 1 = 0; UPDATE MyTable set MyColumn = 'Whatever' where SomeColumn = 'Criteria'; SELECT MyColumn"

tableListAndJoins = "MyTable"

whereCond = "SomeColumn = 'Criteria'"

[分号实际上是可选的,甚至可能在 SQL 2000 中不起作用——它们只是清楚地表明一个命令在哪里结束,下一个命令在哪里开始。]

这样做的缺点是您将返回两个数据集。第一个将是一个空的单列集合(如果您想要列的名称,则别名为 NULL),您想要的数据将在第二个集合中。其他变通方法可能是可能的,具体取决于这三个值的使用方式以及错误的捕获方式。(让第一个查询生成并出错,并希望更新和第二个查询通过?)

于 2009-06-29T20:46:59.463 回答
0

尝试在存储过程中使用动态 sql,如最后一个回复中所述

链接,以便原作者获得他/她应得的学分,希望对您有所帮助。

而且由于您希望在 UPDATE 之前选择 SELECT,因此您可以修改我发布的链接中的动态 sql,以先执行 SELECT。

于 2009-06-29T18:30:00.090 回答
0

我不确定我是否理解您的情况的限制,但是您能否一次运行两个语句,例如:

string sql = "update MyTable set x=y;select x from MyTable;";
于 2009-06-29T18:31:23.130 回答
0

存储函数会是一种选择吗?您可以比存储过程更无缝地调用它们(至少在 MySQL 中)——而不是“调用 PROCEDURE_NAME(x)”,您可以使用“SELECT FUNCTION_NAME(x)”。

于 2009-06-29T18:31:51.570 回答
0

我对 XP 的猜测是,您会编写自己的 XP 来进行更新并以某种方式将其包含在查询中。这是否可行以及它应该在查询中的哪个位置运行以便在 SQL 查看您的数据之前运行完全超出了我的范围。

听起来你已经尝试了我会尝试的所有东西。我对你有感觉,因为在你运行选择之后更新状态可能相当容易。

于 2009-06-29T18:34:16.387 回答