插入数据

  • 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中如何插入数据相关推荐

  1. MySQL中如何插入数据(DML)

    添加数据(insert) 选择插入 Insert into 表名(列名1,列名2,列名3-) values(值1,值2,值3-) 例 向 departments 表中添加一条数据,部门名称为 mar ...

  2. MySQL中批量插入数据

    不管怎么样, 你需要大量的数据, 那么问题来了, 怎么快速地插入呢? 1. 这是我创建的一个批量插入的存储过程- 当然, 你可以把参数去掉, 一次性插入1W, 10W- CREATE DEFINER= ...

  3. 初识Mysql(part12)--我需要知道的3条Mysql语句之插入数据

    学习笔记,以代码和例子堆砌而成,方便查阅. 参考书籍:<Mysql必知必会>等 要点:INSERT INTO子句 此Blog里的例子都会用下面的grouping表和grouping2表. ...

  4. php数据存储mysql_php – 在MySQL中存储路线数据的最佳方式

    我正在开发一个应用程序,它要求我存储一些位置的方向,下面是我试图存储的数据的示例: 方向1 从西部:乘528 East(Beechline),经过机场出口,然后从13号出口驶入Narcoossee R ...

  5. mysql数据库表插入数据

    如何向mysql数据表中插入数据? 答:你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据. 以下为向MySQL数据表插入数据通用的 INSERT INTO ...

  6. 周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,表中没有的课程列值为空的解决方法

    周末杂谈:在MYSQL中,添加数据行后,使用右外连接查询所有课程的选修情况,要求列出课程编号.课程名称.选修人数,表中没有的课程列值为空的解决方法 实验前期准备 course表(课程表) 在其中: c ...

  7. MySQL中DQL查询数据——(四)

    MySQL中DQL查询数据--(四) 本篇博客,是个人根据 西部开源-秦疆老师的教学视频整理出的笔记,想看最详细的教学笔记和提供的SQL语句素材,请点击如下链接: https://www.cnblog ...

  8. mysql常见问题处理-插入数据error code:1206

    mysql常见问题处理-插入数据error code:1206 mysql  error code:1206 the total number of locks exceeds the lock ta ...

  9. Spark-SQL从MySQL中加载数据以及将数据写入到mysql中(Spark Shell方式,Spark SQL程序)

    1. JDBC Spark SQL可以通过JDBC从关系型数据库中读取数据的方式创建DataFrame,通过对DataFrame一系列的计算后,还可以将数据再写回关系型数据库中. 1.1. 从MySQ ...

最新文章

  1. python中raise stoplteration_推导表达式迭代器生成器模块和包 | 编程电脑技术交流...
  2. POJ3133(插头dp)
  3. [BZOJ3261] 最大异或和 (异或前缀和,可持久化Trie)
  4. android版多功能日历,欢迎大家测试
  5. boost::safe_numerics模块实现数组索引值可以超出数组边界的测试程序
  6. java 打印_剑指Offer面试题20(Java版):顺时针打印矩阵
  7. 是否有唯一的Android设备ID?
  8. USB 3.0 高清音视频采集芯片——MS2130
  9. Vim 大小写切换快捷键
  10. 《MATLAB 神经网络43个案例分析》:第3章 遗传算法优化BP神经网络——非线性函数拟合
  11. Android 能让你少走弯路的干货整理
  12. WP 微信导出聊天记录备份到电脑
  13. 网页设计中最常见的9种设计风格
  14. 【每周CV论文推荐】StyleGAN人脸属性编辑有哪些经典论文需要阅读
  15. mysql断电同步不起作用_记一次mysql主从同步因断电产生的不能同步问题 1236 and 1032...
  16. 飞信免费发短信API接口调用方式
  17. python的脑安装了ffmpeg_python脚本实现音频m4a格式转成MP3格式
  18. c语言编程Turbo C 程序假想初步
  19. 拼多多的搜索的参数anti_content怎么破
  20. linux清空网络错误包,centos – 删除包时PREUN scriptlet中的yum错误

热门文章

  1. mysql视图的特点有哪些_简述MySQL视图的优点
  2. 关于延时ACK的思考
  3. mysql设置127.0.0.1访问_请问如何设置以访问127.0.0.1
  4. 用户和计算机硬盘系统,技术宅教你一个固态硬盘硬盘装几十个电脑操作系统
  5. 适合自己才是最好的,又是一个能替代 Postman 的工具,Apifox 真香!
  6. CSS中设置字体样式的5种常用属性—让字体设置再无难点
  7. 图片转换成word的技巧
  8. ios拒审4.3 python自动生成辣鸡代码
  9. 电脑桌面云便签怎么绑定QQ互联登录或解绑QQ?
  10. js长度超过1逗号分开_js怎么用逗号或者换行分割字符串