Mysql - 常用插入数据的三种方法详解及练习

这篇具有很好参考价值的文章主要介绍了Mysql - 常用插入数据的三种方法详解及练习。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

🥙8.1.1 mysql中常用的三种插入数据的语句

1. insert into - 插入数据

2. replace into - 插入替换数据

3. insert ignore - 如果已存在,忽略当前新数据

🥙8.1.2 以上三种方法的练习及区分

🥙8.1.3 说明

🥙8.1.4 牛客练习题


mysql插入语句,MySQL,mysql,数据库

🥙8.1.1 mysql中常用的三种插入数据的语句

1. insert into - 插入数据

数据库会检查主键,如果出现重复会报错;

# 第一种方式
insert into 表名(字段名1,字段名2,...) values(值1,值2,...);

# 第二种方式:按照表中所有字段进行插入数据,一定要与字段在表中定义的顺序一致
insert into  表名 values(值1,值2,...);

2. replace into - 插入替换数据

需求表中有PrimaryKey,或者unique索引,如果数据库已经存在数据,则用新数据替换,如果没有数据效果则和insert into一样;

# 第一种方式
replace into 表名(字段名1,字段名2,...) values(值1,值2,...);

# 第二种方式:按照表中所有字段进行插入数据,一定要与字段在表中定义的顺序一致
replace into 表名 values(值1,值2,...);

3. insert ignore - 如果已存在,忽略当前新数据

如果已经存在相同的记录,则忽略当前新数据;

# 第一种方式
insert ignore into 表名(字段名1,字段名2,...) values(值1,值2,...);

# 第二种方式:按照表中所有字段进行插入数据,一定要与字段在表中定义的顺序一致
insert ignore into 表名 values(值1,值2,...);

注:对于以上三种方法,如果表中没有设置主键或唯一索引;则效果都是一样的,即直接插入数据。

🥙8.1.2 以上三种方法的练习及区分

drop table if exists actor;
CREATE TABLE actor (
   actor_id  smallint(5)  NOT NULL PRIMARY KEY,
   first_name varchar(45) NOT NULL,
   last_name  varchar(45) NOT NULL,
   last_update DATETIME NOT NULL,
   addresses varchar(45));
insert into actor values ('3', 'WD', 'GUINESS', '2006-02-15 12:34:33','北京');

mysql插入语句,MySQL,mysql,数据库

问题1:用以上三种方式对于表actor插入如下数据

actor_id

first_name

last_name

last_update

addresses

'3'

'ED'

'CHASE'

now()

'上海’

① 使用insert into语句直接插入

insert into actor values('3','ED','CHASE',now(),'上海');

结果:由于主键重复报错

mysql插入语句,MySQL,mysql,数据库

②使用replace into语句插入

replace into actor values('3','ED','CHASE',now(),'上海');

插入成功,可以看到数据被替换了

mysql插入语句,MySQL,mysql,数据库

③使用insert ignore句插入

insert ignore actor values('3','ED','CHASE',now(),'上海');

结果没有报错,数据也没有更改

mysql插入语句,MySQL,mysql,数据库

问题2: 同时插入多行以下数据

actor_id

first_name

last_name

last_update

addresses

'4'

'ZS'

'Fuel'

now()

'上海’

'5'

'LS'

'Son'

now()

'南京’

# 可以同时插入多行
insert into actor values ('4', 'ZS', 'Fuel',now(),'上海'),
                         ('5', 'LS', 'Son',now(),'南京');

结果:

mysql插入语句,MySQL,mysql,数据库

如果VALUES前面的()中没有列出字段,那么默认就是为表中的所有字段赋值,那么个数与顺序与表结构中字段定义的一致

问题3:插入指定字段数据

actor_id

first_name

last_name

last_update

'6'

'PENELOP'

'GUINESS'

now()

insert into actor(actor_id,first_name,last_name,last_update)
values ('6', 'PENELOP', 'GUINESS',now());

结果

mysql插入语句,MySQL,mysql,数据库

对于没有列出的字段,像自增列就自动赋值,像默认值列就自动赋默认值,像允许NULL的列就自动赋NULL值,但是非空列又没有提供默认值会自动赋值为对应数据类型的默认值,例如字符串赋值为空字符串,int赋值为0;

🥙8.1.3 说明

1、值列表(值1,值2,......)的顺序、个数与字段列表(字段1,字段2,......) 中字段的顺序、个数一致

  • 如果个数少了就报Column count doesn’t match value count

  • 如果VALUES前面的()中没有列出字段,那么默认就是为表中的所有字段赋值,那么个数与顺序与表结构中字段定义的一致

2、关于自增长列、默认值列、允许为NULL列的赋值

  • 如果字段列表列出了字段名,那么值列表中就要为其赋值,哪怕它是自增长列,有默认值列,可以为NULL值的列。

  • InnoDB表的自动增长列可以手动插入合适的值,但是插入的值如果是NULL或者0,则实际插入的将是自动增长后的值;

  • 如果列声明了“默认约束”那么对应的位置可以赋值具体的值,也可以使用“DEFAULT”,表示使用默认值;

  • 如果列允许了NULL值,那么可以为对应的字段可以赋值为具体值也可以赋值为NULL

3、VALUES也可以写成VALUE,但是VALUES是标准写法

4、如果插入从表的数据,要注意查看主表参照字段的值是否存在

5、值的位置可以是常量值、表达式、函数

🥙8.1.4 牛客练习题

SQL229 批量插入数据文章来源地址https://www.toymoban.com/news/detail-843109.html

到了这里,关于Mysql - 常用插入数据的三种方法详解及练习的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 今天我们来说说常用的三种排序算法:选择排序、插入排序、快速排序

    原文链接:http://www.ibearzmblog.com/#/technology/info?id=8ac4902f82f525e1456624d5d7a545dc 选择排序、插入排序、快速排序这三种算法算是比较初级的排序算法,对它们的原理和技巧,可以方便我们对后面的算法理解。 温馨提示,因为动图不好弄,所以我在网上下载了AlgorithmMan来进行动图演示

    2024年02月16日
    浏览(26)
  • 数据库系列文章 之 MySQL分表的三种方法

    先说一下为什么要分表 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了。分表的目的就在于此,减小数据库的负担,缩短查询时间。 根据个人经验,mysql执行一个sql的过程如下: 1,接收到sql;2,把sql放到排队队列中

    2024年02月16日
    浏览(33)
  • SpringBoot+MyBatis批量插入数据的三种方式

    最近导入表格数据时需要同时插入修改大量数据,研究了一下有三种实现方式 1、用for循环调用sql插入数据 这种方式插入大量数据时,效率非常底下,不推荐 2、利用mybatis的foreach来实现循环插入 这种方式插入大量数据时,好处是不用频繁访问数据库,一条sql搞定,效率比较

    2024年02月16日
    浏览(29)
  • unity常用的三种拖拽方法

    在2d图片与3d场景中使用OnMouseDrag()的方法实现拖拽,而对于ui没有作用。 通过添加Event Tringger组件实现,按下Add New Event Type添加新的事件类型,下拉菜单中显示不同的事件类型,包括鼠标进入离开按下松开点击拖拽等,以及拖拽结束后的EndDrag事件。他看上去和Button组件中的o

    2024年02月04日
    浏览(38)
  • Unity常用的三种拖拽方法(内置方法 + 接口 + Event Trigger组件)

    目录 内置方法OnMouseDrag【对象含有Collider组件】 配对小游戏 Event Trigger组件 接口 窗口小案例 OnMOuseOver()检测鼠标是否进入到这个2D贴图 当鼠标进入或离开2D贴图,会相应的放大、缩小 private   void   OnMouseEnter ()     {         transform.localScale += Vector3.one * 0.1f;     }    

    2024年01月21日
    浏览(26)
  • mysql去重查询的三种方法

    数据库生成环境中经常会遇到表中有重复的数据,或者进行关联过程中产生重复数据,下面介绍三种剔除重复数据的方法,请针对自己的应用场景选择使用。 下图测试数据中user_name为lilei、zhaofeng的用户是重复数据。 代码如下(示例): 如下图,已将数据剔重,重复数据仅保

    2024年02月06日
    浏览(31)
  • 关于MySQL中创建表的三种方法分享

    本文主要介绍了MySQL中创建表的三种方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教 SQL 标准使用 CREATE TABLE 语句创建数据表;MySQL 则实现了三种创建表的方法,支持自定义表结构或者通过复制已有的表结构来创建新表,本文给大

    2024年02月08日
    浏览(40)
  • 计算字符串长度的三种方法(库函数 指针 )【详解】

    求字符串长度简单来说就是计算一个字符串(字符数组)中元素的个数即从数组头部计数,直到遇到字符串’\\0’结束符为止, 计数结果不包括’\\0’. C语言中的库函数strlen,它包含于string.h中,因此我们需要在使用前添加头文件 ,具体用法如下: strlen从数组头部计数,直到遇到字

    2024年02月06日
    浏览(58)
  • 详解redis的三种特殊数据类型

    14天学习训练营导师课程: 郑为中《Vue和SpringBoot打造假日旅社管理系统》 努力是为了不平庸~ 学习有些时候是枯燥的,但收获的快乐是加倍的,欢迎记录下你的那些努力时刻(学习知识点/题解/项目实操/遇到的bug/等等),在分享的同时加深对于知识点的理解,同时吸收他人

    2024年02月19日
    浏览(37)
  • mysql查询结果命令行方式导出/输出/写入到文件的三种方法

    直接执行命令: 在目录/tmp/下会产生文件test.xls 遇到的问题: 可能原因:mysql没有向/data/下写的权限 查询都自动写入文件: 跳出mysql命令行

    2024年02月11日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包