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

Mysql之多种 Insert语句

在mysql常用命令与数据导入导出中记录过常用的sql语句,其中包括了插入语句. 今天单独记录一下mysql的插入语句的更多用法....into 这是最常用的插入语句,具体示例如下: insert into student(name,classNum) values("test2",20); 在数据库中成功插入了一条:名字为test2...,但是test2在数据库中主键已经存在,那么使用replace语句执行插入后,会发现,主键为test2的值仍然存在,但是classNum替换为了21. insert ignore into 当主键重复时...这种情形下我们可以使用insert ignore into语句,示例如下: mysql> select * from student; +-----------+----------+ | name...联系邮箱:huyanshi2580@gmail.com 更多学习笔记见个人博客——>呼延十 var gitment = new Gitment({ id: 'Mysql之多种 Insert语句',

93340

MySql批量插入语句(INSERT)

使用INSERT语句实现批量插入 前言 在初始化数据库或者导入一些数据时,常常会用到批量的操作,如果在循环的脚本中使用单条插入数据的语句时,就意味着多次与数据库建立连接,这样会急剧消耗服务器的性能。...那么,MySql是提供了批量插入语句的,和单条插入语句类似。...单条插入语句写法 INSERT INTO [表名] ([列名],[列名]) VALUES([列值],[列值]); 批量插入语句写法 INSERT INTO [表名]([列名],[列名]) VALUES...([列值],[列值])), ([列值],[列值])), ([列值],[列值])); 由此看来两者很相似,批量插入语句则是在前者的值后面继续添加新的值,并用逗号分隔。...`sex` VARCHAR(16), PRIMARY KEY ( `id` ) )ENGINE=InnoDB DEFAULT CHARSET=utf8; 查看结果 批量插入记录 INSERT

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

    图解MySQL | MySQL insert 语句的磁盘写入之旅

    本文来源:转载自公众号-图解 MySQL *爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。 ---- 一条 insert 语句在写入磁盘的过程中到底涉及了哪些文件?...顺序又是如何的? 下面我们用两张图和大家一起解析 insert 语句的磁盘写入之旅。 图 1:事务提交前的日志文件写入 ?...我们知道 InnoDB 会将数据页缓存至内存中的 buffer pool,所以 insert 语句到了这里并不需要立刻将数据写入磁盘文件中,只需要修改 buffer pool 当中对应的数据页就可以了。...但仅仅写入内存的 buffer pool 并不能保证数据的持久化,如果 MySQL 宕机重启了,需要保证 insert 的数据不会丢失。...综上(在 InnoDB buffer pool 足够大且上述的两个参数设置为双一时),insert 语句成功提交时,真正发生磁盘数据写入的,并不是 MySQL 的数据文件,而是 redo log 和 binlog

    4.6K32

    Mysql常用sql语句(22)- insert 插入数据

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 终于讲完基础的查询语句了...这篇讲的就是插入数据...insert 属于DML语句(数据操纵语句) insert ... values 的语法格式 INSERT INTO [ [ , … ] ] VALUES (值1) [...… , (值n) ]; 语法格式说明 :可以不指定,默认指定表的所有列名 values:字段有多少个,值就要有多少个,且顺序要对应,否则会报错 insert .. set 的语法格式 这个用的不多哈...,了解为主; INSERT INTO SET = , = , … 两种语法格式的区别 insert .. values...可以插入任意行数据,而 insert ... set 每次只能插入一行数据 看看 emp 表的结构,方便后面栗子演示 ?

    1.2K20

    MySQL中插入语句(Insert)的几种使用方式

    注意:insert这种简写的方式虽然非常简单,但是Values后面的值必须和表中的类顺序对应,且类型要保持一直,即使表中某一个列不需要值也必须赋值为null,比如我们的主键id设置的是递增实际上是不用设置值的...3.REPLACE INSERT语句 此语句的作用是当我们在插入一条数据时,如果此条已经存在,那么先删除原来存在的数据再添加插入的数据,如果不存在那么直接插入新的数据。...4.INSERT IGNORE INTO 语句 此语句的作用是如果插入的数据已经存在那么就忽略插入的数据(也就是不改变原来的数据),如果不存在则插入新的数据。...6.INSERT SELECT语句 1.此语句的作用是将SELECT语句的结果插入表中,可实现数据迁移。...查看被插入的表的所有数据 ? 执行INSERT SELECT语句并查看结果 ?

    2.3K30

    MySQL实战中,Insert语句的使用心得总结

    喏 → MySQL专栏目录 | 点击这里   提到MySQL的Insert语句,你肯定不陌生,或许已经张口就来:不就是insert into table values(xxx,xxx,xxx)嘛!...三、REPLACE INTO语法的“坑” 一、Insert的几种语法 1-1.普通插入语句 INSERT INTO table (`a`, `b`, `c`, ……) VALUES ('a', 'b'...注意事项:"INSERT INTO … ON DUPLICATE KEY UPDATE …"语句是基于唯一索引或主键来判断唯一(是否存在)的。...,INSERT语句将插入新记录,否则,当前username='chenhaha'的记录将被更新,更新的字段由UPDATE指定。...例如我插入10w条数据的SQL语句要操作的数据包超过了1M,MySQL会报如下错: 报错信息: Mysql You can change this value on the server by setting

    1.4K20

    MySQL DML语句insert全表数据添加语句以及注意事项

    MySQL DML语句insert全表数据添加语句以及注意事项 官方语法: INSERT  INTO  表名 [(字段名列表)]  VALUES (值列表); 字段名是可选的,如省略则依次插入所有字段...多个列表和多个值之间使用逗号分隔 值列表和字段名列表逐一对应 如插入的是表中部分数据,字段名列表必填 全表语法: INSERT  INTO  表名  VALUES (值列表); 需要添加表中所有的数据列信息...select * from student; # 添加语句insert insert into student values (0,'2023-9-16 10:00:00','2023-9-28...10:00:00','乔俞雅', '123456','15612245679',20,'女','信息安全1班大政委'); # insert语句使用总结 1、所有非中文内容均需要采用英文输入法写入..._general_ci】 5、确认关键字insert into ,values,显示颜色为蓝色,否则书写错误 6、每一条sql语句结束都需要添加一个【;】代表书写完毕。

    13710

    insert语句的加锁情况分析

    // insert语句的加锁情况分析 // 今天分享的内容是MySQL里面insert语句的加锁情况,废话就不多说了,直接从线上的例子开始吧。...`table_log` trx id B1354DEF lock mode AUTO-INC waiting 为了解释这个现象,我们需要知道在MySQL中,对于insert into select这个语句是如何加锁的...因此,为了避免这种情况发生,MySQL会在session 1中对表t添加了(-无穷,1]之间的next-key锁,来避免session2的insert语句并发插入。...语句执行完成之后才释放自增锁; b、当该值为1的时候,普通的insert语句,自增锁在申请之后马上释放,insert into select语句,自增锁还是要等语句结束之后才释放 c、该值为2的时候,所有的申请自增主键的动作都是申请完成之后就释放锁...MySQL认为这是欠妥当的,因此,对这种批量insert语句,包括load data等,它在内部做了一个自增值生成策略的优化: 1、批量执行的insert语句,第一次申请1个自增id 2、一个id用完了

    2.3K21

    insert 语句加锁机制

    T_T 二 基础知识 在分析死锁案例之前,我们先学习一下背景知识 insert 语句的加锁策略,来看看官方定义: "INSERT sets an exclusive lock on the inserted...否则出现等待M上的锁释放。比如插入4,MySQL查看到4 的下一个记录5上有Gap lock,Next-key lock, 阻塞insert intention,因此出现等待。...我们构造一个已经存在的记录c2=19 ,然后删除记录c2=19,在其他会话插入相同的记录。 通过这样的逻辑来测试insert 语句遇到唯一键的时候的加锁流程。...(1) 我们从时间线维度分析: T1: insert into t7(id,a) values(26,10) 语句insert 成功,持有a=10 的X 行锁(X locks rec but not...T3: insert into t7(id,a) values(40,9)该语句插入的a=9的值在T1申请的gap锁(4,10]之间,Gap lock 阻塞insert intention lock,故要等待

    3.2K30

    一条诡异的insert语句

    作者 | 天士梦 来源 | https://www.cnblogs.com/cchust/p/4601536.html 问题背景 有同事反馈在mysql上面执行一条普通的insert语句,结果报错,...为了方便说明,我将测试例子中的表和语句简化,但不影响问题重现。...但是,即使是字符集转换,也不应该导致插入报错,因为语句中的中文字符“校园网"都是普通汉字,UTF8->GBK不应该存在问题。...那我们在回过头来看看insert语句,唯一特殊的是使用了concat和char两个函数。会不会跟这两个函数有关系?...转换前,mysql将字符串‘cardName:校园网’看作是9个英文字符和3个汉字字符;转换后,mysql将其看作是18个字节的二进制串,其中,UTF8字符集的三个汉字“校园网”占了9个字节。

    32830

    一条诡异的insert语句

    问题背景 有同事反馈在mysql上面执行一条普通的insert语句,结果报错, execute failed due to >>> Incorrect string value: '\xA1;offl...为了方便说明,我将测试例子中的表和语句简化,但不影响问题重现。...但是,即使是字符集转换,也不应该导致插入报错,因为语句中的中文字符“校园网"都是普通汉字,UTF8->GBK不应该存在问题。...那我们在回过头来看看insert语句,唯一特殊的是使用了concat和char两个函数。会不会跟这两个函数有关系?...转换前,mysql将字符串‘cardName:校园网’看作是9个英文字符和3个汉字字符;转换后,mysql将其看作是18个字节的二进制串,其中,UTF8字符集的三个汉字“校园网”占了9个字节。

    58730

    insert into 语句的四种写法

    【特注】当 id 为自增,即 id INT PRIMARY KEY AUTO_INCREMENT 时,执行 insert into 语句,需要将除 id 外的所有 field 列举出来(有没有感觉,好不方便...,期待 mysql 提供一个简便方法来标记这种情况,因为在早测试数据的时候,普遍会使用,而列举出除 id 外所有字段,真有麻烦感)。...,以及可以通过相对较复杂的查询语句进行数据源获取,可能使用起来会更加的灵活一些,但我们也必须注意,我们在指定目标表的列时,一定要将所有非空列都填上,否则将无法进行数据插入,还有一点比较容易出错的地方就是...,当我们写成如下简写格式: 方式3.2、 INSERT INTO t2 SELECT colm1,colm2,…… FROM t1 此时,我们如果略掉了目标表的列的话,则默认会对目标表的全部列进行数据插入...(参考:mysql数据库中插入数据INSERT INTO SET的优势) 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/159651.html原文链接:https:

    76530

    mysql中一条insert语句批量插入多条记录

    但是这样一来,就会增加服务器的负荷,因为,执行每一次SQL服务器都要同样对SQL进行分析、优化等操作。幸好MySQL提供了另一种解决方案,就是使用一条INSERT语句来插入多条记录。...这并不是标准的SQL语法,因此只能在MySQL中使用。...一条INSERT语句插入批量数据的写法: INSERT INTO [表名]([列名],[列名]) VALUES ([列值],[列值])), ([列值],[列值])), ([列值],[列值...])); 可以看到,和原来的常规INSERT语句的区别,仅仅是在VALUES 后面增加值的排列,每条记录之间用英文输入法状态下的逗号隔开,是不是so easy。...建议: 在程序中,插入批量数据时,最好使用这种通过一条INSERT语句来一次性插入的方式。这样可以避免程序和数据库建立多次连接,从而增加服务器负荷。

    5.5K20

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券