MySQL中联表更新与删除的语法介绍

作者:Juwend''s 时间:2024-01-13 11:18:54 

前言

相信大家在日常使用mysql,可能会遇到需要同时更新两张表时,我会采用在同一个事务中使用2句sql语句分别进行更新。其实,这种需要发送2句sql语句的方法效率相对来说是比较低的,有没有只用1句sql语句就可以完成这个操作的呢?

答案是有的,下面将是代码记录:

假设有2张表:

1,user表,字段为:id,user_name

2,user_role表,字段为:id,role_name,user_id

关联关系是 user.id = user_role.user_id

现要更改某一条user表的数据的的user_name字段以及该user对应的user_role表中的数据的role_name字段,那么用下面的sql就可以实现这个目的了:


update user, user_role set
user.user_name = ?, user_role.role_name = ?
where user.id = ? and user.id = user_role.user_id

上面写到联表更新,那么有没有联表删除呢?

答案也是有的,下面将是代码记录:

假设有2张表:

1,user表,字段为:id,user_name

2,user_role表,字段为:id,role_name,user_id

关联关系是 user.id = user_role.user_id

现要删除某一条user表的数据以及该user对应的user_role表中的数据,那么用下面的sql就可以实现这个目的了:


delete u, u_r from user u, user_role u_r
where u.id = ? and u.id = u.user_id

上述sql中,u是user的别名,u_r是user_role的别名,from语句前面要附上别名,这个别名适用于指定删除哪张表数据的,如果只有u或者u_r,那么仅删除对应的那张表上的数据。

来源:https://www.juwends.com/tech/mysql/mysql_join_delete.html

标签:mysql,联表,更新
0
投稿

猜你喜欢

  • Go语言并发编程之互斥锁Mutex和读写锁RWMutex

    2024-04-25 15:00:32
  • python中dict获取关键字与值的实现

    2022-03-11 14:00:42
  • 马化腾关于产品设计与用户体验的培训

    2009-02-12 11:45:00
  • 前端面试之输入npm run后执行原理

    2024-05-05 09:21:55
  • python numpy中cumsum的用法详解

    2022-09-17 03:21:17
  • php广告加载类用法实例

    2023-11-14 14:56:53
  • Python实现Windows上气泡提醒效果的方法

    2021-08-13 07:58:46
  • python argparse的使用步骤(全网最全)

    2023-06-14 01:13:45
  • Python 实现12306登录功能实例代码

    2021-04-07 08:55:35
  • Python可视化Matplotlib折线图plot用法详解

    2021-01-04 03:06:15
  • python实现简单http服务器功能

    2023-03-24 15:36:58
  • Python实现手写一个类似django的web框架示例

    2022-06-18 03:17:26
  • python魔法方法-自定义序列详解

    2022-10-08 08:56:12
  • python开发之str.format()用法实例分析

    2022-01-15 22:10:23
  • Mysql彻底解决中文乱码问题的方案(Illegal mix of collations for operation)

    2024-01-26 16:33:51
  • 如何解决tensorflow恢复模型的特定值时出错

    2023-12-22 14:59:36
  • 从零开始写jQuery框架

    2008-12-24 13:37:00
  • Python金融数据可视化汇总

    2023-04-12 21:27:41
  • python矩阵转换为一维数组的实例

    2023-09-13 18:34:10
  • 说说如何遍历Python列表的方法示例

    2023-05-26 14:01:52
  • asp之家 网络编程 m.aspxhome.com