![]() |
|
|||||||
|
|
Thread Tools | Display Modes |
|
#1
IP: 49.87.41.166
|
|||
|
|||
|
在mysql中关联删除与关联更新我们会使用到update与delete来实现,下面我来给大家举例介绍mysql 多表关联更新/删除sql语句,希望此方法对你有帮助。
1、mysql 多表关联delete中使用别名,tblwenhq是真实的表名,a是tblwenhq的别名,b是另一个表名 DELETE a FROM tblwenhq a,b where a.id=b.id 2、使用mysql进行delete from操作时,若子查询的 FROM 字句和更新/删除对象使用同一张表,会出现错误。 DELETE FROM tab1 WHERE col1 = ( SELECT MAX( col1 ) FROM tab1 ); ERROR 1093 (HY000): You can’t specify target table ‘tab1′ for update in FROM clause 正确用法:DELETE FROM tab1 WHERE col1 = ( SELECT MAX( col1 ) FROM tab1 as a); 表关联Update笔记 UPDATE b,a SET b.public=a.public WHERE b.id=a.id 例 对单表执行更新没有什么好说的,无非就是update table_name set col1 = xx,col2 = yy where col = zz,主要就是where条件的设置。有时候更新某个表可能会涉及到多张数据表,例如: update table_1 set score = score + 5 where uid in (select uid from table_2 where sid = 10); 其实update也可以用到left join、inner join来进行关联,可能执行效率更高,把上面的sql替换成 join的方式如下: update table_1 t1 inner join table_2 t2 on t1.uid = t2.uid set score = score + 5 where t2.sid = 10; 例1 MySQL多表关联数据同时删除 category(栏目信息表)和news(新闻数据表)。 category中的id(栏目编号)字段作为该表的主键(primary key).唯一标识了一个栏目的信息。 news 中的id字段作为该表的主键(primary key).唯一标识了一个栏目的信息。 category_id(栏目编号)字段与category表的id字段相关联。 1.SQL删除语句 delete category,news from category left join news on category.id = news.category_id |
| Currently Active Users Viewing This Thread: 1 (0 members and 1 guests) | |
|
|
Similar Threads
|
||||
| Thread | Thread Starter | Forum | Replies | Last Post |
| mysql 帮助文档使用 | Haddam | MySQL | 0 | 2014-11-26 06:43 PM |
| 如何导入导出MySQL数据库 | topvip | 建站交流 | 0 | 2006-10-10 07:43 AM |
| 使用XAMPP轻松建站(Linux版) | smiling | 服务器环境搭建 | 0 | 2006-05-13 04:01 AM |
| mysql安装与简单使用 | sunshine | 服务器环境搭建 | 0 | 2006-01-11 07:29 PM |
| winxp下安装全新的apache,php(5.0),mysql(5.0)... | topvip | 服务器环境搭建 | 0 | 2006-01-08 10:28 PM |