sql server的 update from 语句的深究

 更新时间:2014年12月23日 15:45:22   作者:miqi770  
这篇文章主要介绍了sql server的 update from 语句的深究,需要的朋友可以参考下

一般来说update一个表, 使用where语句即可:

复制代码 代码如下:

UPDATE Ttest SET
    statusInd = 'ACTIVE' 
WHERE
    id = 123

注意:

update 语句后面的table名称,是不可以启用别名的。
那么此时的id字段,就是来自Ttest表的(无可厚非)

但是,如果update,还有额外的join table 条件约束,语句如下:

复制代码 代码如下:

UPDATE Ttest SET
    statusInd = 'ACTIVE'
FROM
    Tparent parent
WHERE
    Ttest.id = 123
AND Ttest.parentId = parent.id
AND parent.statusInd = 'ACTIVE'

注意:

update 后面的Ttest 不能使用别名
那么定位到,要修改的Ttest记录,就必须这样写:Ttest.id = 123

如果直接写id=123, 会分不清是 Ttest 表 还是 Tparent 表的  id
此sql语句的意思是,如果想修改自身的statusInd属性,得关联其parent的statusInd属性是否也是'ACTIVE'

此时,层级关系是使用两个表(Ttest和Tparent)来定义 。

但是如果,数据库表的设计,只是用一个表(Ttest),来表述数据之间的层级关系(Ttest.parentId = Ttest.id),
如何书写,可以实现目的呢?(如果想修改自身的statusInd属性,得关联其parent的statusInd属性是否也是'ACTIVE')

实现如下:

复制代码 代码如下:

UPDATE Ttest SET
    statusInd = 'ACTIVE'
FROM
    Ttest parent,
    Ttest
WHERE
    Ttest.id = 123
AND Ttest.parentId = parent.id
AND parent.statusInd = 'ACTIVE'

解释:

其需求是:修改自身的statusInd属性,得关联其parent的statusInd属性是否也是'ACTIVE'
update 后面的表(Ttest)不能,命名别名!
from 后面的表 也是 Ttest,但是 要update的Ttest 记录 和 from Ttest 记录并不一样 (要update 孩子,但是要from 关联其父亲)

from 后面 要多写 一个 没有别名的 Ttest ,用来指定此表的记录,就是要被update的。
而需要from join的 (Ttest)表,就必须有一个别名,来区别与update的表(Ttest)

相关文章

  • Microsoft SQL Server 2012 数据库安装图解教程

    Microsoft SQL Server 2012 数据库安装图解教程

    这篇文章主要为大家介绍下Microsoft SQL Server 2012 数据库安装教程,需要的朋友可以参考下
    2013-11-11
  • sql 版本详解 让你认识跟sql2000的区别

    sql 版本详解 让你认识跟sql2000的区别

    如果你是初学者,如果你只是想要在家里学习学习,如果你的环境是 WindowsXP Pro,那么,你应该选择的 是 SQL2005 Development(开发版),而不是 SQL2005 Enterprise (企业版)或 SQL2005 Express(简易版)。
    2010-05-05
  • T-sql语句修改SQL Server数据库逻辑名、数据库名、物理名的方法

    T-sql语句修改SQL Server数据库逻辑名、数据库名、物理名的方法

    这篇文章主要介绍了T-sql语句修改SQL Server数据库逻辑名、数据库名、物理名的方法,结合实例形式分析了T-SQL语句操作数据库的基本技巧,非常简单易懂,需要的朋友可以参考下
    2016-06-06
  • SQL语句示例

    SQL语句示例

    [红色]SQL语句示例...
    2006-10-10
  • 解析关于SQL语句Count的一点细节

    解析关于SQL语句Count的一点细节

    本篇文章是对关于SQL语句Count的一点细节进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • SQL Server查看当前连接数和最大连接数具体方法代码

    SQL Server查看当前连接数和最大连接数具体方法代码

    这篇文章主要介绍了SQL Server查看当前连接数和最大连接数的具体方法,讲解了使用系统视图、配置选项、实时监控和SQL Server Management Studio等方法,每种方法都给出了代码示例,需要的朋友可以参考下
    2025-04-04
  • SQL语句执行顺序详解

    SQL语句执行顺序详解

    本文给大家介绍SQL语句执行顺序详解,涉及到sql语句执行顺序相关知识,对sql语句执行顺序感兴趣的朋友一起看看吧
    2015-10-10
  • SQL Server模糊查询的常见方法总结

    SQL Server模糊查询的常见方法总结

    这篇文章主要给大家介绍了关于SQL Server模糊查询的常见方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • 深入理解Sql Server中的表扫描

    深入理解Sql Server中的表扫描

    这篇文章主要介绍了深入理解Sql Server中的表扫描,本文讲解了表扫描的相关知识、表扫描的运行原理等内容,需要的朋友可以参考下
    2015-02-02
  • Microsoft SQL Server错误: 233的原因及解决办法

    Microsoft SQL Server错误: 233的原因及解决办法

    这篇文章主要给大家介绍了关于Microsoft SQL Server错误: 233的原因及解决办法,这个错误代码是指Microsoft SQL Server遇到了一个数据库连接失败的问题,可能是由于数据库连接字符串不正确、数据库服务未启动、网络连接故障等原因,需要的朋友可以参考下
    2024-06-06

最新评论