首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql技巧:如果记录存在则更新如果不存在则插入的三种处理方法

) ) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='员工表' 插入几条数据...要求: 新增一个员工时,如果该员工已存在(以员工号f_emp_code作为判断依据),则更新,否则插入。而且工资f_salary,更新时,不得低于原工资(即:工资只能涨,不能降)。...方法一:传统方法 插入 INSERT INTO t_emp( f_emp_code , f_emp_name , f_city , f_salary ) SELECT '10007' , '...这个方法有一个很大的问题,如果记录存在,每次执行完,主键自增id就变了(相当于重新insert了一条),对于有复杂关联的业务场景,如果主表的id变了,其它子表没做好同步,会死得很难看。...但是有另外一个问题,如果这个表上有不止一个唯一约束,在特定版本的mysql中容易产生dead lock(死锁),见网友文章https://blog.csdn.net/pml18710973036/article

9.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【MySQL数据库】多表关系与多表联合查询

    ​​目录MySQL多表关系一对一一对多多对多MySQL外键约束创建外键数据插入删除多表联合查询交叉连接查询内连接查询外连接查询子查询关键字自关联MySQL多表关系MySQL表与表之间的三种关系一对多关系...•假如A表有m行数据,B表有n行数据,则返回m*n行数据 •笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选 select * from 表1,表2,表3….; 内连接查询隐式内连接...返回的数据类型单行单列:返回的是一个具体列的内容,可以理解为一个单值数据;单行多列:返回一行数据中多个列的内容;多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围;多行多列:查询返回的结果是一张临时表...有数据结果”(至少返回一行数据), 则该EXISTS() 的结果为“true”,外层查询执行该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为“false”,外层查询不执行EXISTS...后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时,推荐使用EXISTS关键字select

    3K30

    【MySQL数据库】多表关系与多表联合查询

    目录 MySQL多表关系 一对一 一对多 多对多 MySQL外键约束 创建外键 数据插入 删除 多表联合查询 交叉连接查询 内连接查询 外连接查询 子查询关键字 自关联 MySQL多表关系 MySQL...• 假如 A 表有 m 行数据, B 表有 n 行数据,则返回 m*n 行数据 • 笛卡尔积会产生很多冗余的数据,后期的其他查询可以在该集合的基础上进行条件筛选...返回的数据类型 单行单列:返回的是一个具体列的内容,可以理解为一个单值数据; 单行多列:返回一行数据中多个列的内容; 多行单列:返回多行记录之中同一列的内容,相当于给出了一个操作范围; 多行多列:查询返回的结果是一张临时表...EXISTS 该子查询如果“有数据结果”(至少返回一行数据), 则该EXISTS() 的结果为“true”,外层查询执行 该子查询如果“没有数据结果”(没有任何数据返回),则该EXISTS()的结果为...“false”,外层查询不执行 EXISTS后面的子查询不返回任何实际数据,只返回真或假,当返回真时 where条件成立 注意,EXISTS关键字,比IN关键字的运算效率高,因此,在实际开发中,特别是大数据量时

    2.8K20

    MySQL插入数据与更新和删除数据

    插入多行; 4.插入某些查询的结果; - 注意,由于MySQL的安全机制,需要注意权限。 插入完整的行 需要指定插入的表名和行值。一般插入操作没有返回值,举例, 分析:第一列cust_id为。...这是因为在表中,该列由MySQL自动增量,所以指定一个值。 注意,虽然此语法简单,但并非安全。上面语句高度依赖表中列的次序。...所以,纵使与表中列的次序不同,也可以完成插入操作。因此当比给出列名的时候,必须正确的给出每列的值。 如果表的定义允许,可以选择在操作时忽略某些列。忽略的列必须满足如下条件, 1....该列定义为允许; 2. 表中给出默认值; 注意,为避免影响到数据库瞬时速度,可以将插入操作降低优先级。,此操作同样适用于和。 插入多行 插入多行,只需要在每组值用圆括号并且逗号隔开即可。...更新数据的两种方式, 语句由三部分组成, 例子,更新单列, 分析:总是以要更新的表的名字开始,为赋值命令 例子,使用多列更新时,只需要一次命令即可 分析: 1、如果多列更新,并且在一行或多行赋值时出现错误

    2.4K60

    MY SQL存储过程、游标、触发器--Java学习网

    如果开发人员和应用程序都使用了同一存储过程,则所使用的代码是相同的。还有就是防止错误,需要执行的步骤越多,出错的可能性越大。防止错误保证了数据的一致性。 3 简化对变动的管理。...如果命令行实用程序要解释存储过程自身的 ; 字符,则他们最终不会成为存储过程的成分,这会使存储过程中的SQL出现句法错误 解决方法是临时更改命令实用程序的语句分隔符 DELIMITER...IF语句检查taxable是否为真,如果为真,则用另一SELECT语句增加营业税到局部变量total,最后用另一SELECT语句将total(增加了或没有增加的)保存到ototal中。...都与mysql语句匹配的行(0行或多行),使用简单的SELECT语句,没有办法得到第一行、下一行或前10行,也不存在每次行地处理所有行的简单方法(相对于成批处理他们) 有时,需要在检索出来的行中前进或后退一行或多行...单个触发器不能与多个事件或多个表关联,所以,如果你需要一个对INSERT 和UPDATE存储执行的触发器,则应该定义两个触发器 触发器失败 如果BEFORE(之前)触发器失败,则MySQL将不执行SQL

    1.9K30

    【MySQL】MySQL数据库的进阶使用

    ,不忽略任何一列,加上括号时,可以自己指定某些列进行插入,但值得注意的是如果某些列没有default约束,你还将其忽略进行数据插入的话,则插入数据的操作一定会失败。...在插入数据时,如果遇到主键冲突或唯一键冲突,可能导致数据插入失败,此时有一种同步更新操作的语法可以保证,当数据插入失败时,可以更新为新的数据进行插入。...where子句是select在查询时常用的一个筛选条件,当where条件判断为真时,select在会将查询结果显示出来,下面我们通过多个使用案例,来熟悉where条件的使用以及逻辑运算符的使用。...MySQL中判断是否相等一般用=,还有一个比较鸡肋的东西就是,=是NULL不安全的,是NULL安全的,其实这里的安全不安全指的就是NULL在作为判断条件时候的判断结果,一般判断是否等于null...update用于更改表中某一行或者多行的数据,值得注意的是,在使用update对表中数据进行更新的时候,如果不跟上where子句进行数据筛选的话,则update会对表中所有的行进行某一列字段值的更新,因为

    35120

    【Mysql】通过实验掌握Mysql基本操作

    在发布之前,先跟着我把Mysql的基本操作一起敲一遍吧~ Here we go ~ Part.1 基本操作 基本操作 1、连接数据库 mysql -h ip -u root ip password ?...14、limit 查询 先手工插入多行数据: ? 从第1行开始,查询2行(数据库第一行为第0行) ? 查询前4行: ? Part.2 高级操作 高级操作 1、排序 order by 降序排序: ?...Part.3 Information_schema 数据库 元数据库 在Mysql数据库5.0版本中存在着一个元数据库information_schema,其中存放着用户在Mysql中创建的所有其他数据库的信息...所以,在id被以字符型进行查询时,直接插入and语句,后面的查询内容不会生效!!...在or条件下前后如果都为真则返回所有结果,否则只返回条件为真的一方的值。 Part.5 结语 这就是今天的全部内容了,大家都明白了吗? Peace !

    91320

    Linux云计算运维之Shell

    i : 插入,在当期行前插入一行或多行。插入多行时,除最后一行外,每行末尾需要用“\”代表数据未完结。 d : 删除,删除指定的行。 p :打印,输出指定的行。...如果旧则为真) 文件 1 -ef 文件 2 判断文件 1 是否和文件 2 的Inode号一致,可以理解为两个文件是否为同一个文件。...判断 逻辑非,使原始的判断式取反 流程控制 1. if条件判断 1)单分之if条件语句 单分之条件语句最为简单,就是只有一个判断条件,如果符合条件则执行某个程序,否则什么事情都不做。...#如果变量test1和test2的值为空,则证明num1和num2是数字 then #如果 test1和test2是数字,则执行以下命令 if [ "$ope" == '+' ]...如果数值符合,则执行对应的程序,如果数值不符,则依次比较下一个值。如果所有的值都不符合,则执行“)” (“”代表所有其他值)中的程序 case语句以“case” 开头,以 “esac” 结尾。

    5.7K30

    MySQL:表的增删查改

    value_list: value, [, value] ... 1.1 单行数据+全列插入 单行指定列插入: 单行全列插入: into也可以省略: 1.2 多行数据+全列插入 多行全列插入:...多行指定列插入: 1.3 插入否则更新 我们知道,如果发生主键或者唯一键冲突的时候,会报错。...| +-------------+ | 2 | +-------------+ 1.3.2 要插入的值与原数据没有冲突则正常插入 如果要插入的值在原数据中并没有,则相当于正常插入语句...1.3.3 要插入的值与原数据有冲突但是连续更新了两次 如果我们想更新原数据,但是连着运行了两次命令,则第一次正常修改,第二次并不会改变什么。...1.4 替换 -- 主键 或者 唯一键 没有冲突,则直接插入; -- 主键 或者 唯一键 如果冲突,则删除后再插入 REPLACE INTO students (sn, name) VALUES

    6310

    mysql 必知必会整理—数据插入和更新还有删除

    在插入的时候为了安全起见,那么每次插入的时候应该写好列名。 不管使用哪种INSERT语法,都必须给出VALUES的正确数目。 如果不提供列名,则必须给每个表列提供一个值。...如果提供列名,则必须对每个列出的列给出一个值。 如果不这样,将产生一条错误消息,相应的行插入不成功。 省略列 如果表的定义允许,则可以在INSERT操作中省略某些列。省略的列必须满足以下某个条件。...该列定义为允许NULL值(无值或空值)。 在表定义中给出默认值。这表示如果不给出值,将使用默认值 提高整体性能 数据库经常被多个客户访问,对处理什么请求以及用什么次序处理进行管理是MySQL的任务。...如果数据检索是最重要的(通常是这样),则你可以通过在INSERT和INTO之间添加关键字LOW_PRIORITY,指示MySQL降低INSERT语句的优先级。...; IGNORE关键字 如果用UPDATE语句更新多行,并且在更新这些行中的一行或多行时出一个现错误,则整个UPDATE操作被取消(错误发生前更新的所有行被恢复到它们原来的值)。

    1.1K20

    MySQL(九)插入、更新和删除

    一、insert insert:用来插入(或添加)行到数据库中,常见方式有以下几种: ①插入完整的行; ②插入行的一部分; ③插入多行; ④插入某些查询的结果; 1、插入完整的行 例如:insert into...insert使用注意事项: ①无论使用哪种insert语法,都必须给出values的正确数目,如果不提供列名,则必须给每个表列提供一个值;如果提供列名,则必须对每个列出的列给出一个值; ②如果表定义允许...,则可以在insert操作中省略某些列,列必须满足这两个条件(1.改列定义为允许null值;2.在表定义中给出默认值【如果不给出值,则使用默认值】); ③数据库被多个用户访问,一般检索是最重要的,可以通过在...PS:如果用update更新多个行,且更新中一行或多行出现错误,则update操作将被取消(错误发生前执行的动作将被回滚到最初状态。...如果希望删除一个值,可以将它设置为null(如果表定义允许null值),例子如下:    update usertable    set user_email = null    where user_id

    2K20

    mysql表中数据的增删改

    情况1:为表的所有字段按默认顺序插入数据 使用INSERT同时插入多条记录时,MySQL会返回一些在执行单行插入时没有的额外信息,这些信息的含义如下: ● Records:表明插入的记录条数。...一个同时插入多行记录的INSERT语句等同于多个单行插入的INSERT语句,但是多行的INSERT语句在处理过程中效率更高。...因为MySQL执行单条INSERT语句插入多行数据比使用多条INSERT语句快,所以在插入多条记录时最好选择使用单条INSERT语句的方式插入。...如果省略 WHERE 子句,则表中的所有数据都将被更新。 ...更新中的数据完整性错误   删除数据 使用 DELETE 语句从表中删除数据  table_name指定要执行删除操作的表;“[WHERE ]”为可选参数,指定删除条件,如果没有WHERE子句,DELETE

    2.6K30

    Perl 工作积累(不定期更新)

    比如在"" 里面还要使用",则\";  2....secureCRT sz/rz 也会遇到目录权限的问题 5)倒数据不要全量重新倒,可以设定时间起始点甚至表自增id,从文件读出写入;当tmmp表为空时,perl sql执行以下语句返回还是为真,需要再次判断...idmax的值是否为"" mysql> select max(id) idmax from tmmp;                                                            ...+-------+ | idmax | +-------+ |  NULL | +-------+ 6)perl 对类型还是要注意,如$url为字符串,则如果判断 $url == 0 很可能为真,字符串比较尽量用...如果字符串中只是存在单一的 \(后面没有跟 ", ', \, n, r, b 等),那么db 将不插入任何字符。

    1.4K00

    魔法程序员的奥妙指南:Java基本语法

    这些关键字具有固定的语法和含义,开发人员不能将它们用作标识符或变量名 以下是Java所有的关键字 关键字 描述 abstract 声明抽象类或者抽象方法 assert 断言条件为真 boolean 声明布尔型变量...break 跳出当前循环 byte 声明字节型变量 case 为switch语句定义一个条件 catch 捕获异常并处理 char 声明字符型变量 class 定义类 const* 保留关键字,未使用...continue 结束当前循环的当前迭代,继续下一次迭代 default 针对switch语句,设置默认情况 do 执行语句块,并在条件语句为真时重复执行 double 声明双精度浮点型变量 else...若条件语句为假,则执行语句块 enum 声明枚举类型 extends 扩展一个类 final 声明一个不可改变的值或者指示一个类不可继承 finally 在try块之后执行一个语句块,无论是否有异常发生...float 声明单精度浮点型变量 for 创建一个for循环 goto* 保留关键字,未使用 if 对条件进行测试,如果为真则执行代码块 implements 实现一个接口 import 导入另一个Java

    12010

    【C语言指南】注释

    C语言注释有三种方式 ,分别是单行注释,多行注释和条件编译注释,其中前两种在初级编程较为常见 1.单行注释 C99标准引入的注释方式 将注释放在双斜杠 // 后面,从双斜杠到行尾都属于注释。...0; } 2.多行注释(块注释) 将注释放在 /*...*/ 之间,内部可以分多行。...*/ return 0; } 这种注释也可以插入在行内 比如下面这个例子,注释来对函数参数进行说明,跟在它后⾯的代码依然会有效执行。...条件编译指令#if后面跟整型常量表达式。如果表达式为非零,则表达式为真,编译器条件执行代码块;反之,编译器忽略代码块。...# if 0 注释内容 # endif 下面这个例子中,第一个代码块被忽略,第二个代码块执行,输出abc; 如果想要换成执行第一个代码块,输出ABC,则只需将“1”和“0”位置互换 #include

    11410

    【mysql】比较运算符

    = >= 比较运算符用来对表达式左边的操作数和右边的操作数进行比较,比较的结果为真则返回1,比较的结果为假则返回0,其他情况则返回NULL。...如果等号两边的值都是整数,则MySQL会按照整数来比较两个值的大小。 如果等号两边的值一个是整数,另一个是字符串,则MySQL会将字符串转化为数字进行比较。...如果等号两边的值、字符串或表达式中有一个为NULL,则比较结果为NULL。...LIKE运算符 LIKE运算符主要用来匹配字符串,通常用于模糊匹配,如果满足条件则返回1,否则返回0。如果给定的值或者匹配条件为NULL,则返回结果为NULL。...REGEXP运算符 REGEXP运算符用来匹配字符串,语法格式为:expr REGEXP 匹配条件。如果expr满足匹配条件,返回1;如果不满足,则返回0。

    2.5K30
    领券