mysql从一个表提取数据更新另外一个表(Cross Table Update with MySQL)
2010-04-14 10:59
513 查看
使用MySQL 4.0版或更高更新您可以通过加入两个或多个表一起一表;注意,本文中的例子所示无法与MySQL 3.23或更早版本。通过加入两个表连同您可以更新一个表的记录在相关领域的总部设在另一个表。
让我们举例说你有一个产品表,其中存储有关产品和产品价格表,其中有价格信息,您想更新时,该产品是建立在下面你要折扣所有的旧东西的例子(根据价格信息80%的现行价格)。
在MySQL中你可以这样做两种方式之一。第一是现在所做的一切联接使用逗号,像这样:
第二种方法是使用内部联接的语法如下所示。此语法是更灵活一点,因为它意味着你可以使用左,右联接以及内部联接,而前面的例子,是一个隐含的内部联接。
这样做的另一个例子,但在MySQL使用一个左联接到所有的国旗没有assocated在产品价格表项产品如下:
这不一定是一个很现实的例子,你将更有可能要直接进行删除不匹配的条目,或者使用一个选择查询,而不是显示在列表中进行编辑,但它说明了如何可以做到的。有关如何与MySQL删除记录使用交叉连接使用这些例子删除,而不是更新的文章。
请注意,它也可以在MySQL更新所有的加入在查询表中的值。在这个例子中,我们正在做的是在头两个例子相同的查询,还更新了“dateUpdated”在产品表中的价值。
http://php.dayanmei.com/cross-table-update-with-mysqlmysql-update-from-another-table.htm
from http://www.electrictoolbox.com/article/mysql/cross-table-update/
让我们举例说你有一个产品表,其中存储有关产品和产品价格表,其中有价格信息,您想更新时,该产品是建立在下面你要折扣所有的旧东西的例子(根据价格信息80%的现行价格)。
在MySQL中你可以这样做两种方式之一。第一是现在所做的一切联接使用逗号,像这样:
UPDATE product p, productPrice pp SET pp.price = pp.price * 0.8 WHERE p.productId = pp.productId AND p.dateCreated < '2004-01-01'
第二种方法是使用内部联接的语法如下所示。此语法是更灵活一点,因为它意味着你可以使用左,右联接以及内部联接,而前面的例子,是一个隐含的内部联接。
UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8 WHERE p.dateCreated < '2004-01-01'
这样做的另一个例子,但在MySQL使用一个左联接到所有的国旗没有assocated在产品价格表项产品如下:
UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8 WHERE p.dateCreated < '2004-01-01'
这不一定是一个很现实的例子,你将更有可能要直接进行删除不匹配的条目,或者使用一个选择查询,而不是显示在列表中进行编辑,但它说明了如何可以做到的。有关如何与MySQL删除记录使用交叉连接使用这些例子删除,而不是更新的文章。
请注意,它也可以在MySQL更新所有的加入在查询表中的值。在这个例子中,我们正在做的是在头两个例子相同的查询,还更新了“dateUpdated”在产品表中的价值。
UPDATE product p INNER JOIN productPrice pp ON p.productId = pp.productId SET pp.price = pp.price * 0.8, p.dateUpdate = CURDATE() WHERE p.dateCreated < '2004-01-01'
http://php.dayanmei.com/cross-table-update-with-mysqlmysql-update-from-another-table.htm
from http://www.electrictoolbox.com/article/mysql/cross-table-update/
相关文章推荐
- mysql update from 关联更新 从一个表字段 到另外一个表字段
- update数据从一个表到另外一个表中
- MySQL 依赖另外一个统计出来数据更新表数据的范例
- Mysql 根据一个表数据更新另外一个表
- python 采集MySQL数据,并更新到另外一个库
- Mysql从一个表获取数据插入另外一个表[备忘]
- SQL从一个表查询数据更新到另外一个表
- 在mysql中如何使用一个表中的数据去更新另外一个表的数据
- MySQL触发器更新本表数据异常:Can’t update table ‘tbl’ in stored function/trigger because it is already used by s
- 如何从一个表的数据更新到另外一个表的列或者插入
- MYSQL从一个数据库的表中读出数据 循环向另外一个库的表中写入数据
- 用一个表的数据更新另外一个表数据的用法(update from)
- oracle 从一个表复制、更新数据到另外一个表
- mysql update 两个表关联{两个关联表如何更新其中一个表的数据}
- [置顶] 【mysql 数据迁移】mysql中同一服务器,要从一个数据库里复制一个表到另一个数据库
- SQL之merge into 批量更新数据 Merge关键字是一个神奇的DML关键字。它在SQL Server 2008被引入,它能将Insert,Update,Delete简单的并为一句。M
- 根据一个表更新另外一表的数据
- 如何把将微软账户中的数据从一个账户转移到另外一个账户
- MSSQL 把一个表的数据更新到另外一个表里
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?