mysql数据插入除了Insert into语句以外,原来还有这么多种写法
wptr33 2024-11-08 15:03 26 浏览
练习表
学生表,以下的SQL语句都是基于此表进行的操作,具体数据如下 :
普通插入
1.说明
- 向数据库的表中插入一条或多条数据 。
2.格式
insert into 表(字段1,字段2,...) values(值1,值2,...)
3.示例
# 需求 :插入一条数据
insert into students values(5,'项羽','男',10003,38) ;
insert into students(id,name,sex) values(6,'王翦',41) ;
# 结果 :学生表里多两条数据
插入或更新
1.说明
- 如果希望向一张表插入一条记录,但如果记录已经存在,就更新该记录 ;若此条记录不存在则执行插入操作 。
2.格式
insert into 表(字段1,字段2,...) values(值1,值2,...)
on duplicate key update 字段1=新值1,...
3.示例
# 需求 :向学生表插入一条记录 ,若此记录存在则更新sex,code和age .
insert into students values(6,'王翦','女','10004',41) on duplicate key update sex='男',code=10005,age=42;
4.备注
此SQL语句需要注意以下几点 :
- insert into … on duplicate key update …"语句是基于唯一索引或主键来判断唯一的 .
- 若数据库已经有此条记录 ,则直接执行update后面字段值更新,其它记录保持不变 ;若不存在此条记录,则执行insert into语句 。
插入或替换
1.说明
- 若想插入一条新记录,但如果此记录已经存在,就先删除原记录,再插入新记录 ;若不存在 ,则进行插入操作
2.格式
replace into 表(字段1,字段2,...) values(值1,值2,...)
3.示例
# 需求 :向学生表插入一条记录 ,若记录存在,替换此记录,否则插入新记录 .
replace into students values(6,'鲁肃','男','10008',38) ;
4.备注
- 如果插入行出现唯一索引或者主键重复时,则删除原记录,而录入新的记录;如果不会导致唯一索引或者主键重复时,就直接添加新行。
插入或忽略
1.说明
- 如果我们想插入一条新记录,但如果记录已经存在,就啥事也不干直接忽略 。
2.格式
insert ignore into 表(字段1,字段2,...) values(值1,值2,...);
3.示例
# 需求 :向学生表插入一条记录 ,若记录存在,则忽略此条记录 .
insert ignore into students values(6,'鲁肃','男','10009',40) ;
# 结果 :保持原来记录,因为已经有id=6的记录了
插入多条数据
1.说明
- 如果我们想通过一个insert语句插入多条记录,就可以使用多值情况 。
2.格式
insert into 表(字段1,字段2,...) values(值1,值2,...),(值3,值4,...),...;
3.示例
# 需求 :向学生表插入三条记录 .
insert into students values(7,'周瑜','男',10006,25),(8,'黄盖','男',10007,29),(9,'吕布','男',10009,39);
# 查询结果 :会一次性插入3条记录 。
插入值使用子查询
1.说明
- 如果插入数据时,使用的值来自于表中的某个其它值,这个时候我们可以使用子查询另外表的值作为其中的一个值。
2.格式
insert into 表(字段1,字段2,...) values(值1,值2,(select filed1 from 表 where ...)...);
3.示例
# 需求 :向学生表插入一条记录,其中年龄值来至于另外一个表中的值 .
insert into students values(10,'雷杰','男',10010,(select max(age) from g)) ;;
# 查询结果 :年龄的值会取g表的中最大年龄
3.备注
- 这种情况下,子查询的结果需要是单行子查询,即子查询的结果必须是单行单列的(一个具体的值);
插入设置
1.说明
- 若想插入一条数据,除了使用values也可以是下面的set关键字设置。
2.格式
insert into 表 set 字段1=值1,字段2=值2,...;
3.示例
# 需求 :向学生表插入一条记录,使用set关键字 .
insert into students set name= '吕布',age=32;
# 查询结果 :插入一条数据 ,只有两个字段的一行数据,其它的都是默认值
3.备注
- 若使用这种情况,必须至少为一列赋值 ,其实就是insert into ... values的另外一种实现方式
插入查询
1.说明
- 若需要将另外一张表的几列或全部列的数据复制到当前表中,就可以使用insert into ...select语句。
2.格式
insert into 表(字段1,字段2,...) select 字段1,字段2,... from 表1;
3.示例
# 需求1 :将一张表(students)的数据全部插入另外一张表(a)中 .
insert into a select * from students ;
# 查询结果 :表a 中的数据和students中的数据一致 ,需要注意的是,两者的字段是需要一致的 。
# 需求2 :将一张表(students)的部分列复制到另外一张表(g)中
insert into g(id,name,age) select id,name,age from students ;
# 查询结果 :会将students表中的id,name,age列的值全部拷贝到students中 。
3.备注
- 据说使用这个语句在数据量大的时候容易出现锁表,故建议谨慎使用。
相关推荐
- Linux高性能服务器设计
-
C10K和C10M计算机领域的很多技术都是需求推动的,上世纪90年代,由于互联网的飞速发展,网络服务器无法支撑快速增长的用户规模。1999年,DanKegel提出了著名的C10问题:一台服务器上同时...
- 独立游戏开发者常犯的十大错误
-
...
- 学C了一头雾水该咋办?
-
学C了一头雾水该怎么办?最简单的方法就是你再学一遍呗。俗话说熟能生巧,铁杵也能磨成针。但是一味的为学而学,这个好像没什么卵用。为什么学了还是一头雾水,重点就在这,找出为什么会这个样子?1、概念理解不深...
- C++基础语法梳理:inline 内联函数!虚函数可以是内联函数吗?
-
上节我们分析了C++基础语法的const,static以及this指针,那么这节内容我们来看一下inline内联函数吧!inline内联函数...
- C语言实战小游戏:井字棋(三子棋)大战!文内含有源码
-
井字棋是黑白棋的一种。井字棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、三子旗等。将正方形对角线连起来,相对两边依次摆上三个双方棋子,只要将自己的三个棋子走成一条线,对方就算输了。但是,有很多时...
- C++语言到底是不是C语言的超集之一
-
C与C++两个关系亲密的编程语言,它们本质上是两中语言,只是C++语言设计时要求尽可能的兼容C语言特性,因此C语言中99%以上的功能都可以使用C++完成。本文探讨那些存在于C语言中的特性,但是在C++...
- 在C++中,如何避免出现Bug?
-
C++中的主要问题之一是存在大量行为未定义或对程序员来说意外的构造。我们在使用静态分析器检查各种项目时经常会遇到这些问题。但正如我们所知,最佳做法是在编译阶段尽早检测错误。让我们来看看现代C++中的一...
- ESL-通过事件控制FreeSWITCH
-
通过事件提供的最底层控制机制,允许我们有效地利用工具箱,适时选择使用其中的单个工具。FreeSWITCH是一个核心交换与混合矩阵,它周围有几十个模块提供各种功能特性。我们完全控制了所有的即时信息,这些...
- 物理老师教你学C++语言(中篇)
-
一、条件语句与实验判断...
- C语言入门指南
-
当然!以下是关于C语言入门编程的基础介绍和入门建议,希望能帮你顺利起步:C语言入门指南...
- C++选择结构,让程序自动进行决策
-
什么是选择结构?正常的程序都是从上至下顺序执行,这就是顺序结构...
- C++特性使用建议
-
1.引用参数使用引用替代指针且所有不变的引用参数必须加上const。在C语言中,如果函数需要修改变量的值,参数必须为指针,如...
- C++程序员学习Zig指南(中篇)
-
1.复合数据类型结构体与方法的对比C++类:...
- 研一自学C++啃得动吗?
-
研一自学C++啃得动吗?在开始前我有一些资料,是我根据网友给的问题精心整理了一份「C++的资料从专业入门到高级教程」,点个关注在评论区回复“888”之后私信回复“888”,全部无偿共享给大家!!!个人...
- C++关键字介绍
-
下表列出了C++中的常用关键字,这些关键字不能作为变量名或其他标识符名称。1、autoC++11的auto用于表示变量的自动类型推断。即在声明变量的时候,根据变量初始值的类型自动为此变量选择匹配的...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mysql max (33)
- vba instr (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)