mysql多表关联更新/删除sql语句
发布:smiling 来源: PHP粉丝网 添加日期:2014-10-02 16:00:58 浏览: 评论:0
在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 //phpfensi.com
正确用法: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
Tags: mysql多表关联 mysql多表更新
相关文章
- ·MySql多表关联Update更新sql语句(2014-10-08)
- ·MySQL多表关联数据同时删除sql语句(2014-10-10)
- ·mysql中多表关联删除数据时同时删除关联数据(2014-10-13)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)