【mysql技巧】如何在这个mysql语句执行前加个前提,也就是只有表里没有相同数据才进行添加插入操作

文章目录

  • 我们正常的mysql插入数据语句
  • 加个前提
  • 完结

我们正常的mysql插入数据语句

INSERT INTO `guild_nakadai`.`admin_role_permission` (`role_id`, `permission_id`, `type`) 
VALUES ((SELECT id FROM `guild_nakadai`.`admin_roles` WHERE name="员工"),(SELECT id FROM `guild_nakadai`.`admin_permissions` WHERE name="基础数据汇总"),3
);

他有一个缺点,当我们不小心执行了几次时,会插入多条相同的垃圾数据

加个前提

要在执行这个 MySQL 语句时添加一个前提条件,即只有表里没有相同数据才进行添加操作,你可以使用 INSERT IGNORE INTO 的方式来实现。案例:

INSERT IGNORE INTO `guild_nakadai`.`admin_role_permission` (`role_id`, `permission_id`, `type`) 
SELECT (SELECT id FROM `guild_nakadai`.`admin_roles` WHERE name="员工"),(SELECT id FROM `guild_nakadai`.`admin_permissions` WHERE name="基础数据汇总"),3
FROM dual
WHERE NOT EXISTS (SELECT 1 FROM `guild_nakadai`.`admin_role_permission` WHERE role_id = (SELECT id FROM `guild_nakadai`.`admin_roles` WHERE name="员工") AND permission_id = (SELECT id FROM `guild_nakadai`.`admin_permissions` WHERE name="基础数据汇总") AND type = 3
);

完结

赠人玫瑰,手有余香!如果文章内容对你有所帮助,请不要吝啬你的点赞评论和关注,以便我第一时间收到反馈,你的每一次支持都是我不断创作的最大动力。当然如果你发现了文章中存在错误或者有更好的解决方法,也欢迎评论私信告诉我哦!

好了,我是向宇,https://xiangyu.blog.csdn.net

一位在小公司默默奋斗的开发者,出于兴趣爱好,最近开始自学unity,闲暇之余,边学习边记录分享,站在巨人的肩膀上,通过学习前辈们的经验总是会给我很多帮助和启发!php是工作,unity是生活!如果你遇到任何问题,也欢迎你评论私信找我, 虽然有些问题我也不一定会,但是我会查阅各方资料,争取给出最好的建议,希望可以帮助更多想学编程的人,共勉~

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/718392.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity UGUI之Slider基本了解

在Unity中,Slider(滑动条)是一种常用的用户界面控件之一,允许用户通过拖动滑块来选择一个数值。常常应用于调节数值(如调节音量、亮度、游戏难度等)、设置选项等。 以下是Slider的基本信息和用法: 1、创建…

每日OJ题_斐波那契dp①_力扣1137. 第 N 个泰波那契数

目录 动态规划dp算法原理 力扣1137. 第 N 个泰波那契数 解析代码1 解析代码2 动态规划dp算法原理 动态规划(Dynamic Programming)算法的核心思想是:将大问题划分为小问题进行解决,从而一步步获取最优解的处理算法 动态规划算法…

快速幂(求解原理+例题)

目录 反复平方法(快速幂): 代码: 例题:快速幂求逆元 作用: 快速求出 的结果。 时间复杂度: O(logk) 如果使用一般做法,从1循环到k,时间复杂度是O(k) 反复平方法&am…

低代码流程引擎实战:让表单字段成为流程节点审批人的得力助手!

在现代企业的日常运营中,流程审批是保障工作高效、规范进行的关键环节。随着企业对于灵活性和高效性的需求不断增长,传统的固定审批人设置已无法满足多变的业务场景。在JVS低代码中“设置流程节点审批人为表单字段”这一功能,旨在通过动态配置…

C#入门:简单数据类型和强制类型转换

本文由 简悦 SimpRead 转码, 原文地址 mp.weixin.qq.com 本期来讲讲 unity 的脚本语言 —C#,C# 的简单数据类型及范围和强制类型转化的方法。这可是 unity 游戏开发必备技能。 1. 简单数据类型 各个类型的范围: byte -> System.Byte (字节…

黑马点评-短信登录业务

原理 模型如下 nginx nginx基于七层模型走的事HTTP协议,可以实现基于Lua直接绕开tomcat访问redis,也可以作为静态资源服务器,轻松扛下上万并发, 负载均衡到下游tomcat服务器,打散流量。 我们都知道一台4核8G的tomca…

网络问题排查必备利器:Pingmesh

背景 当今的数字化世界离不开无处不在的网络连接。无论是日常生活中的社交媒体、电子商务,还是企业级应用程序和云服务,我们对网络的依赖程度越来越高。然而,网络的可靠性和性能往往是一个复杂的问题,尤其是在具有大规模分布式架…

21.Prometheus的查询数据类API

平凡也就两个字: 懒和惰; 成功也就两个字: 苦和勤; 优秀也就两个字: 你和我。 跟着我从0学习JAVA、spring全家桶和linux运维等知识,带你从懵懂少年走向人生巅峰,迎娶白富美! 关注微信公众号【 IT特靠谱 】,每天都会分享技术心得~ 1.数据查询类API 1.1.API前缀路径说明 …

lanqiao:42点

题解: 1.首先,把字符转成数字。 2.创建二维数组存放枚举的结果,第一行一个数字13;第二行4个数字,分别是13和1的加减乘除;第三行16个数字,分别是第二行的每个数和12加减乘除的结果;…

基于SpringBoot的在线拍卖系统

目录 1、 前言介绍 2、主要技术 3、系统流程和逻辑 4、系统结构设计 5、数据库设计表 6、运行截图(部分) 6.1管理员功能模块 6.2用户功能模块 6.3前台首页功能模块 7、源码获取 基于SpringBoot的在线拍卖系统录像 1、 前言介绍 随着社会的发展,社会的各行…

安卓玩机工具推荐----ADB状态读写分区 备份分区 恢复分区 查看分区号 工具操作解析

在以往玩机过程中。很多机型备份分区 备份固件需要借助adb手动指令或者第三方手机软件或者特定的一些工具来操作。有些朋友需要查看当前机型分区名称和对应的分区号。此类操作我前面的博文专门说过对应的adb指令。但有些界面化的工具比较方便简单。 相关分区同类博文&#xff…

【C++】每周一题——2024.3.3(手滑再再写一篇)

题目 Cpp 【问题描述】 求N个字符串的最长公共子串&#xff0c;2 < N&#xff1c;&#xff1d;20&#xff0c;字符串长度不超过255。 例如&#xff1a;N&#xff1d;3&#xff0c;由键盘依次输入三个字符串为 What is local bus? Name some local buses. local bus is a h…

SpringBoot源码解读与原理分析(三十七)SpringBoot整合WebMvc(二)DispatcherServlet的工作全流程

文章目录 前言12.4 DispatcherServlet的工作全流程12.4.1 DispatcherServlet#service12.4.2 processRequest12.4.3 doService12.4.3.1 isIncludeRequest的判断12.4.3.2 FlashMapManager的设计 12.4.4 doDispatch12.4.4.1 处理文件上传请求12.4.4.2 获取可用的Handler&#xff0…

sscanf 函数的用法

sscanf 函数是 C 语言标准库 <stdio.h> 中的一个函数&#xff0c;用于按照指定的格式从一个字符串中读取输入。它的用法类似于 scanf 函数&#xff0c;但是 sscanf 从字符串中读取输入&#xff0c;而不是从标准输入&#xff08;键盘&#xff09;中读取输入。 以下是 ssc…

优优嗨聚集团:美团代运营服务,商家增长的新引擎

在当今数字化时代&#xff0c;线上平台已成为商家拓展业务、提升品牌影响力的重要渠道。美团作为国内领先的本地生活服务平台&#xff0c;拥有庞大的用户群体和丰富的商业资源。然而&#xff0c;对于许多商家而言&#xff0c;如何在美团平台上进行有效运营&#xff0c;实现业务…

Redis做分布式锁如何处理超时时间?

在使用Redis实现分布式锁时&#xff0c;处理超时时间是非常重要的&#xff0c;以确保在获取锁的客户端在一定时间内未能完成任务时&#xff0c;锁能够自动释放&#xff0c;避免造成死锁或长时间的阻塞。下面是一种处理超时时间的方法&#xff1a; 获取锁时设置超时时间&#xf…

双线服务器有哪些安全防御措施?

双线服务器的出现给企业带来了更广泛的业务发展&#xff0c;用户不再是固定的群体&#xff0c;而是有了一定的选择性&#xff0c;服务器的性能与可靠性进行了增强&#xff0c;使网络的运行速度变得更加流畅&#xff0c;给用户带来了良好的体验感。 今天我们主要就来聊一聊双线服…

【IOS】启动报错Cannot launch ‘/private/var/containers/Bundle/Application/....‘

问题 IOS项目启动报错Cannot launch ‘/private/var/containers/Bundle/Application/***.app’: Sending qLaunchSuccess packet failed 或者类似报错问题 无法启动launch的 解决 问题定位 我是在操作期间更换了应用的签名证书 也就是Signing & Capablities -> Sign…

【LeetCode:232. 用栈实现队列 + 栈 | 队列】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…