MySQL中如何插入数据
插入数据
- 1数据插入
- 2插入完整行
- 3插入多个行
- 4插入检索出的数据
1数据插入
INSERT是用来插入(或添加)行到数据库表的。插入可以用几种方式使用:
- 插入完整的行;
- 插入行的一部分;
- 插入多行;
- 插入某些查询的结果。
2插入完整行
把数据插入表中的最简单的方法是使用基本的INSERT语法,要求指定表名和被插入到新行中的值。
输入
INSERT INTO Customers
VALUES('1000000006', 'Toy Land', '123 Any Street', 'New York', 'NY', '11111', 'USA', NULL, NULL);
分析:此例子插入一个新客户到customers表。存储到每个表列中的数据在VALUES子句中给出,对每个列必须提供一个值。如果某个列没有值(如上面的cust_contact和cust_email列),应该使用NULL值(假定表允许对该列指定空值)。各个列必须以它们在表定义中出现的次序填充。第一列cust_id也为NULL。这是因为每次插入一个新行时,该列由MySQL自动增量。你不想给出一个值(这是MySQL的工作),又不能省略此列(如前所述,必须给出每个列),所以指定一个NULL值(它被MySQL忽略,MySQL在这里插入下一个可用的cust_id值)。
编写INSERT语句的更安全(不过更烦琐)的方法如下:
INSERT INTO Customers(cust_id, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country, cust_contact, cust_email)
VALUES('1000000006', 'Toy Land', '123 Any Street', 'New York', 'NY', '11111', 'USA', NULL, NULL);
分析:此例子完成与前一个INSERT语句完全相同的工作,但在表名后的括号里明确地给出了列名。在插入行时,MySQL将用VALUES列表中的相应值填入列表中的对应项。VALUES中的第一个值对应于第一个指定的列名。第二个值对应于第二个列名,如此等等。
因为提供了列名,VALUES必须以其指定的次序匹配指定的列名,不一定按各个列出现在实际表中的次序。其优点是,即使表的结构改变,此INSERT语句仍然能正确工作。你会发现cust_id的NULL值是不必要的,cust_id列并没有出现在列表中,所以不需要任何值。
下面的INSERT语句填充所有列(与前面的一样),但以一种不同的次
序填充。因为给出了列名,所以插入结果仍然正确:
INSERT INTO customers(cust_name,cust_contact,cust_address,cust_email,cust_city,cust_state,cust_zip,cust_country) VALUES('Pep E. LaPew',NULL,NULL,'100 Main Street','Los Angeles','CA','90046','USA');
3插入多个行
INSERT可以插入一行到一个表中。但如果你想插入多个行怎么办?可以使用多条INSERT语句,甚至一次提交它们,每条语句用一个分号结束,如下所示:
INSERT INTO customers(cust_name,cust_address,cust_city,cust_state,cust_zip,cust_country) VALUES('Pep E. LaPew','100 Main Street','Los Angeles','CA','90046','USA'), ('M. MaRtian','42 Galaxy Way','New York','NY','11123','USA');
分析:其中单条INSERT语句有多组值,每组值用一对圆括号括起来,用逗号分隔。
4插入检索出的数据
INSERT一般用来给表插入一个指定列值的行。但是,INSERT还存在另一种形式,可以利用它将一条SELECT语句的结果插入表中。这就是所谓的INSERT SELECT,顾名思义,它是由一条INSERT语句和一条SELECT语句组成的。
假如你想从另一表中合并客户列表到你的customers表。不需要每次读取一行,然后再将它用INSERT插入,可以如下进行:
输入
INSERT INTO Customers(cust_id, cust_contact, cust_email, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country)
SELECT cust_id, cust_contact, cust_email, cust_name, cust_address, cust_city, cust_state, cust_zip, cust_country
FROM CustNew;
分析:这个例子使用INSERT SELECT从custnew中将所有数据导入
customers。SELECT语句从custnew检索出要插入的值,而不是列出它们。SELECT中列出的每个列对应于customers表名后所跟的列表中的每个列。这条语句将插入多少行有赖于custnew表中有多少行。如果这个表为空,则没有行被插入(也不产生错误,因为操作仍然是合法的)。如果这个表确实含有数据,则所有数据将被插入到customers。
这个例子导入了cust_id(假设你能够确保cust_id的值不重复)。你也可以简单地省略这列(从INSERT和SELECT中),这样MySQL就会生成新值。
MySQL中如何插入数据相关推荐
- MySQL中如何插入数据(DML)
添加数据(insert) 选择插入 Insert into 表名(列名1,列名2,列名3-) values(值1,值2,值3-) 例 向 departments 表中添加一条数据,部门名称为 mar ...
- MySQL中批量插入数据
不管怎么样, 你需要大量的数据, 那么问题来了, 怎么快速地插入呢? 1. 这是我创建的一个批量插入的存储过程- 当然, 你可以把参数去掉, 一次性插入1W, 10W- CREATE DEFINER= ...
- 初识Mysql(part12)--我需要知道的3条Mysql语句之插入数据
学习笔记,以代码和例子堆砌而成,方便查阅. 参考书籍:<Mysql必知必会>等 要点:INSERT INTO子句 此Blog里的例子都会用下面的grouping表和grouping2表. ...
- php数据存储mysql_php – 在MySQL中存储路线数据的最佳方式
我正在开发一个应用程序,它要求我存储一些位置的方向,下面是我试图存储的数据的示例: 方向1 从西部:乘528 East(Beechline),经过机场出口,然后从13号出口驶入Narcoossee R ...
- mysql数据库表插入数据
如何向mysql数据表中插入数据? 答:你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据. 以下为向MySQL数据表插入数据通用的 INSERT INTO ...
- 周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,表中没有的课程列值为空的解决方法
周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号.课程名称.选修人数,表中没有的课程列值为空的解决方法 实验前期准备 course表(课程表) 在其中: c ...
- MySQL中DQL查询数据——(四)
MySQL中DQL查询数据--(四) 本篇博客,是个人根据 西部开源-秦疆老师的教学视频整理出的笔记,想看最详细的教学笔记和提供的SQL语句素材,请点击如下链接: https://www.cnblog ...
- mysql常见问题处理-插入数据error code:1206
mysql常见问题处理-插入数据error code:1206 mysql error code:1206 the total number of locks exceeds the lock ta ...
- Spark-SQL从MySQL中加载数据以及将数据写入到mysql中(Spark Shell方式,Spark SQL程序)
1. JDBC Spark SQL可以通过JDBC从关系型数据库中读取数据的方式创建DataFrame,通过对DataFrame一系列的计算后,还可以将数据再写回关系型数据库中. 1.1. 从MySQ ...
最新文章
- python中raise stoplteration_推导表达式迭代器生成器模块和包 | 编程电脑技术交流...
- POJ3133(插头dp)
- [BZOJ3261] 最大异或和 (异或前缀和,可持久化Trie)
- android版多功能日历,欢迎大家测试
- boost::safe_numerics模块实现数组索引值可以超出数组边界的测试程序
- java 打印_剑指Offer面试题20(Java版):顺时针打印矩阵
- 是否有唯一的Android设备ID?
- USB 3.0 高清音视频采集芯片——MS2130
- Vim 大小写切换快捷键
- 《MATLAB 神经网络43个案例分析》:第3章 遗传算法优化BP神经网络——非线性函数拟合
- Android 能让你少走弯路的干货整理
- WP 微信导出聊天记录备份到电脑
- 网页设计中最常见的9种设计风格
- 【每周CV论文推荐】StyleGAN人脸属性编辑有哪些经典论文需要阅读
- mysql断电同步不起作用_记一次mysql主从同步因断电产生的不能同步问题 1236 and 1032...
- 飞信免费发短信API接口调用方式
- python的脑安装了ffmpeg_python脚本实现音频m4a格式转成MP3格式
- c语言编程Turbo C 程序假想初步
- 拼多多的搜索的参数anti_content怎么破
- linux清空网络错误包,centos – 删除包时PREUN scriptlet中的yum错误
热门文章
- mysql视图的特点有哪些_简述MySQL视图的优点
- 关于延时ACK的思考
- mysql设置127.0.0.1访问_请问如何设置以访问127.0.0.1
- 用户和计算机硬盘系统,技术宅教你一个固态硬盘硬盘装几十个电脑操作系统
- 适合自己才是最好的,又是一个能替代 Postman 的工具,Apifox 真香!
- CSS中设置字体样式的5种常用属性—让字体设置再无难点
- 图片转换成word的技巧
- ios拒审4.3 python自动生成辣鸡代码
- 电脑桌面云便签怎么绑定QQ互联登录或解绑QQ?
- js长度超过1逗号分开_js怎么用逗号或者换行分割字符串