• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    MySQL中联表更新与删除的语法介绍

    前言

    相信大家在日常使用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,那么仅删除对应的那张表上的数据。

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

    您可能感兴趣的文章:
    • mysql嵌套查询和联表查询优化方法
    • mysql 行列动态转换的实现(列联表,交叉表)
    • mysql删除关联表的实操方法
    • MySQL联表查询的简单示例
    上一篇:如何查看MySQL连接的root密码
    下一篇:mysql查询结果输出到文件的方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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