Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4188058
  • 博文数量: 601
  • 博客积分: 15410
  • 博客等级: 上将
  • 技术积分: 6884
  • 用 户 组: 普通用户
  • 注册时间: 2007-05-16 08:11
个人简介

独学而无友,则孤陋而寡闻!

文章分类

全部博文(601)

文章存档

2020年(1)

2018年(4)

2017年(7)

2016年(42)

2015年(25)

2014年(15)

2013年(36)

2012年(46)

2011年(117)

2010年(148)

2009年(82)

2008年(37)

2007年(41)

分类: Mysql/postgreSQL

2010-11-26 10:24:44

mysql从一个表提取数据更新另外一个表(Cross Table Update with MySQL)


  mysql从一个表提取数据更新另外一个表(Cross Table Update with MySQL) 收藏

使用MySQL 4.0版或更高更新您可以通过加入两个或多个表一起一表;注意,本文中的例子所示无法与MySQL 3.23或更早版本。通过加入两个表连同您可以更新一个表的记录在相关领域的总部设在另一个表。

让我们举例说你有一个产品表,其中存储有关产品和产品价格表,其中有价格信息,您想更新时,该产品是建立在下面你要折扣所有的旧东西的例子(根据价 格信息80%的现行价格)。

在MySQL中你可以这样做两种方式之一。第一是现在所做的一切联接使用逗号,像这样: 

  1. UPDATE product p, productPrice pp  
  2. SET pp.price = pp.price * 0.8  
  3. WHERE p.productId = pp.productId  
  4. AND p.dateCreated < '2004-01-01'  

第二种方法是使用内部联接的语法如下所示。此语法是更灵活一点,因为它意味着你可以使用左,右联接以及内部联接,而前面的例子,是一个隐含的内部联 接。

  1. UPDATE product p  
  2. INNER JOIN productPrice pp  
  3. ON p.productId = pp.productId  
  4. SET pp.price = pp.price * 0.8  
  5. WHERE p.dateCreated < '2004-01-01'  

这样做的另一个例子,但在MySQL使用一个左联接到所有的国旗没有assocated在产品价格表项产品如下:

  1. UPDATE product p  
  2. INNER JOIN productPrice pp  
  3. ON p.productId = pp.productId  
  4. SET pp.price = pp.price * 0.8  
  5. WHERE p.dateCreated < '2004-01-01'  

这不一定是一个很现实的例子,你将更有可能要直接进行删除不匹配的条目,或者使用一个选择查询,而不是显示在列表中进行编辑,但它说明了如何可以做 到的。有关如何与MySQL删除记录使用交叉连接使用这些例子删除,而不是更新的文章。

请注意,它也可以在MySQL更新所有的加入在查询表中的值。在这个例子中,我们正在做的是在头两个例子相同的查询,还更新了 “dateUpdated”在产品表中的价值。

  1. UPDATE product p  
  2. INNER JOIN productPrice pp  
  3. ON p.productId = pp.productId  
  4. SET pp.price = pp.price * 0.8,  
  5. p.dateUpdate = CURDATE()  
  6. WHERE p.dateCreated < '2004-01-01'  

from


阅读(6664) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~