最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

sqlserver的updatefrom语句的深究_MySQL

来源:动视网 责编:小采 时间:2020-11-09 19:38:09
文档

sqlserver的updatefrom语句的深究_MySQL

sqlserver的updatefrom语句的深究_MySQL:一般来说update一个表, 使用where语句即可: 代码如下: UPDATE Ttest SET statusInd = 'ACTIVE' WHERE id = 123 注意: update 语句后面的table名称,是不可以启用别名的。 那么此时的id字段,就是来自Ttest表的(无可厚非) 但是,如果upda
推荐度:
导读sqlserver的updatefrom语句的深究_MySQL:一般来说update一个表, 使用where语句即可: 代码如下: UPDATE Ttest SET statusInd = 'ACTIVE' WHERE id = 123 注意: update 语句后面的table名称,是不可以启用别名的。 那么此时的id字段,就是来自Ttest表的(无可厚非) 但是,如果upda


一般来说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 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)

文档

sqlserver的updatefrom语句的深究_MySQL

sqlserver的updatefrom语句的深究_MySQL:一般来说update一个表, 使用where语句即可: 代码如下: UPDATE Ttest SET statusInd = 'ACTIVE' WHERE id = 123 注意: update 语句后面的table名称,是不可以启用别名的。 那么此时的id字段,就是来自Ttest表的(无可厚非) 但是,如果upda
推荐度:
标签: sql 语句 update
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top