1、增:插入数据
INSERT关键字可以插入新的行到数据库表中:
  • 插入完整的行
  • 插入行的一部分
  • 插入多行
  • 插入某些查询的结果

基本的INSERT语句是:
INSERT INTO R(A1, A2, ..., An) VALUES (V1, V2, ..., Vn); 
1
 
1
INSERT INTO R(A1, A2, ..., An) VALUES (V1, V2, ..., Vn); 

1.1 插入完整的行

如下例:
INSERT INTO Customers
VALUES
(
NULL,
'Pep E. LaPew',
'100 Main Street',
'Los Angeles',
'CA',
'90046',
'USA',
NULL,
NULL
)
13
 
1
INSERT INTO Customers
2
VALUES
3
(
4
NULL,
5
'Pep E. LaPew',
6
'100 Main Street',
7
'Los Angeles',
8
'CA',
9
'90046',
10
'USA',
11
NULL,
12
NULL
13
)
  • 每个列必须提供一个值,没有的话也应该填NULL
  • 插入内容必须以它们在表中定义出现的次序填充

这种语法简单,但是并不安全,而且繁琐,尽量避免使用。

1.2 插入行的一部分

如下例:
INSERT INTO customers
(
cust_address,
cust_city,
cust_state,
cust_zip,
cust_country
)
VALUES
(
'Pep E. LaPew',
'100 Main Street',
'Los Angeles',
'CA',
'90046',
'USA'
);
17
 
1
INSERT INTO customers
2
(
3
cust_address,
4
cust_city,
5
cust_state,
6
cust_zip,
7
cust_country
8
)
9
VALUES
10
(
11
'Pep E. LaPew',
12
'100 Main Street',
13
'Los Angeles',
14
'CA',
15
'90046',
16
'USA'
17
);
  • 这种方式可以替代之前的整行插入,只需要你把所有的列填完
  • VALUES必须跟SQL中制定的匹配列次序相同
  • VALUES不需要跟表中列的次序相同
  • 省略的列必须满足一定条件,即允许为NULL或表中有默认值设定

1.3 插入多个行

如下例:
INSERT INTO customers
(
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',
'11213',
'USA'
);
25
 
1
INSERT INTO customers
2
(
3
cust_address,
4
cust_city,
5
cust_state,
6
cust_zip,
7
cust_country
8
)
9
VALUES
10
(
11
'Pep E. LaPew',
12
'100 Main Street',
13
'Los Angeles',
14
'CA',
15
'90046',
16
'USA'
17
),
18
(
19
'M Martian',
20
'42 Galaxy Way',
21
'New York',
22
'NY',
23
'11213',
24
'USA'
25
);

1.4 插入某些查询的结果

这种方式是所谓的INSERT SELECT,顾名思义,即INSERT语句和SELECT语句组成的。如下例:
INSERT INTO
customers
(
cust_address,
cust_city,
cust_state,
cust_zip,
cust_country
)
SELECT
cust_address,
cust_city,
cust_state,
cust_zip,
cust_country
FROM
custnew;
17
 
1
INSERT INTO 
2
  customers
3
  (
4
  cust_address,
5
  cust_city,
6
  cust_state,
7
  cust_zip,
8
  cust_country
9
  )
10
SELECT
11
  cust_address,
12
  cust_city,
13
  cust_state,
14
  cust_zip,
15
  cust_country
16
FROM
17
  custnew;
  • 例中INSERT和SELECT列名虽然相同,但是并没有强制要求,它仍然是根据次序位置来填充数据的



2、删:删除数据

基本语句:
DELETE FROM R WHERE <选择条件>;
1
 
1
DELETE FROM R WHERE <选择条件>;



3、改:更新数据

基本语句:
UPDATE R SET A1=E1, A2=E2, ..., An=En WHERE <选择条件>;
 
1
UPDATE R SET A1=E1, A2=E2, ..., An=En WHERE <选择条件>;

《MySQL必知必会》[03] 表数据的增删改的更多相关文章

  1. Django框架之第二篇--app注册、静态文件配置、form表单提交、pycharm连接数据库、django使用mysql数据库、表字段的增删改查、表数据的增删改查

    本节知识点大致为:静态文件配置.form表单提交数据后端如何获取.request方法.pycharm连接数据库,django使用mysql数据库.表字段的增删改查.表数据的增删改查 一.创建app,创 ...

  2. PreparedStatement实现表数据的增删改 & 封装数据库链接和关闭操作

    PreparedStatement实现表数据的增删改 PreparedStatementUpdateTest package com.aff.PreparedStatement; import jav ...

  3. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

  4. MySQL表数据的增删改查

    1.增 INSERT INTO tb VALUES(v1,v2,v3...); INSERT INTO tb (field1,field2...) VALUES(v1,v2...); INSERT I ...

  5. MySQL必知必会-官方数据库表及SQL脚本导入生成

    最近在复习SQL语句,看的是MySQL必知必会这本书,但是发现附录中只有表设计,没有表的具体数据.所以在学习相应的语句中体验不是很好,去网上查了数据库的内容,自己慢慢导入到了数据库中.把表放出来作为参 ...

  6. 《MySQL必知必会》官方提供的数据库和表

    数据用于配合<MySQL必知必会>(MySQL Crash Course)这本书使用,配套SQL文件也可在Ben Forta网站下载. Ben Forta网址:http://forta.c ...

  7. MySql必知必会实战练习(三)数据过滤

    在之前的博客MySql必知必会实战练习(一)表创建和数据添加中完成了各表的创建和数据添加,MySql必知必会实战练习(二)数据检索中介绍了所有的数据检索操作,下面对数据过滤操作进行总结. 1. whe ...

  8. 【SQL必知必会笔记(1)】数据库基础、SQL、MySQL8.0.16下数据库、表的创建及数据插入

    文章目录 1.数据库基础 1.1 数据库(database) 1.2 表(table) 1.3 列和数据类型 1.4 行 1.5 主键 2.什么是SQL 3.创建后续练习所需数据库.表(MySQL8. ...

  9. 《MySQL必知必会》过滤数据,数据过滤(where ,in ,null ,not)

    <MySQL必知必会>过滤数据,数据过滤 1.过滤数据 1.1 使用 where 子句 在SEL ECT语句中,数据根据WHERE子句中指定的搜索条件进行过滤. WHERE子句在表名(FR ...

随机推荐

  1. TCP三次握手和四次挥手

    三次握手 (1)第一次握手:Client将标志位SYN置为1,随机产生一个值seq=J,并将该数据包发送给Server,Client进入SYN_SENT状态,等待Server确认. (2)第二次握手: ...

  2. What is the difference for delete/truncate/drop

    Same: delete/truncate/drop, all of them can support rollback/commit, the sample is as below: begin t ...

  3. 一个基于JRTPLIB的轻量级RTSP客户端(myRTSPClient)——解码篇:(二)用ffmpeg解码音频

    其实这篇的内容和(一)用ffmpeg解码视频基本是一样的,重点还是给ffmpeg指定callback函数,而这个函数是从RTSP服务端那里获取音频数据的. 这里,解码音频的示例代码量之所以比解码视频的 ...

  4. 【Maven】构建war包时排除web.xml

    在使用maven构建项目的war包时,有时并不需要src/webapp/WEB-INF/下的一些文件. 这时可以通过maven-war-plugin创建配置来排除这些文件.下面贴出我平时使用的pom. ...

  5. 改造继续之eclipse集成tomcat开发spring mvc项目配置一览

    在上一篇的环境配置中,你还只能基于maven开发一个javase的项目,本篇来看如果开发一个web项目,所以还得配置一下tomcat和spring mvc. 一:Tomcat安装 在.net web开 ...

  6. C/C++ 对优先级与结合性的理解

    优先级与结合性是指运算符与操作数的"紧密程度":   结合性表明了同一优先级的运算符对同一操作数的紧密程度:   如: a=b=c: 赋值运算符的结合性为从右至左: 所以a=b=c ...

  7. windows转储文件(dmp)

    1. 何为转储文件      转储文件也就是我们常说的dump文件.可以把转储文件看成软件的某个时刻的一个快照.转储文件一般都是在软件出现问题时手动生成或者程序自动生成.下面我们介绍几种生成转储文件的 ...

  8. Linux学习笔记-林耐斯Notes-Linux就该这么学

    Linux学习笔记... 参考的优秀Linux网站: http://www.w3cschool.cn/linux/ http://www.linuxeye.com/ http://linux.vbir ...

  9. java 5年规划---

    偶然看到别人,觉得写的很好,尤其对刚出来工作的人,不一定是最好,但至少可以给你一个方向,所以就把这篇文章放到自己博客来,时刻提醒自己 第一部分 在搭建SSM的过程中,可能会经常接触到一个叫maven的 ...

  10. struts2-Action处理请求参数

    struts2 和 MVC 定义关系 StrutsPrepareAndExecuteFilter : 控制器 JSP : 视图 Action : 可以作为模型,也可以是控制器 struts2 Acti ...