插入数据

插入单个元组

一般格式:

insert
into <表名> [<列名1>, <列明2>, ……] -- 指出在表中新插入的值的列,
values(<常量1>, <常量2>, ……) -- 指出在表中插入新值的列的具体值
  • values 语句中各常量数据类型必须与 into 子句中对应列的数据类型兼容,且常量的数量必须与 into 子句中的列数相同。
  • into 子句中没有出现的列,新插入的元组在这些列上去空值。
  • 如果 into 子句省略指定插入新值的列,则新插入元组的每一列必须在 values 子句中均有值对应。
  • 如果某列定义为 not null,则该列的值必须出现在 values 子句中的常量列表中。
  • 这种方法一次只能插入一行数据。
  1. 栗子1:将一个新图书元组插入到图书表中。

    insert into 图书
    values('A019', '数据库', '王珊', '高等教育出版社', 33.8)

    本例中省略了 into 子句中的列名列表,因此 values 子句中常量的数据类型及个数必须与图书基本表中各列数据类型和个数匹配。

  2. 栗子2:插入一条借阅记录('140128', 'A002')

    insert
    into 借阅 (读者编号, 图书号)
    values ('140128', 'A002')

    也可写成:

    insert into 借阅
    values ('140128', 'A002', NULL, NULL)

插入子查询结果

可以使用 select 语句查询出的结果代替 values 子句,一次向基本表中插入多个元组。

一般格式为:

insert
into <表名> [<列名1>, <列明2>, ……]
<子查询>
  • <子查询>结果集合中的列数、列序和数据类型必须与<表名>所指的基本表中相应各项匹配或兼容。

栗子:求各个出版社图书的总数并存放与一张新表 CBS中。

  1. 建表:

    create table CBS
    (出版社 varchar(15), 总数 int)
  2. 插入:

    insert
    into CSB (出版社, 总数)
    select 出版社, count(*)
    from 图书
    group by 出版社

修改数据

一般格式:

update <表名>
set <列名> = <表达式> [, <列名> = <表达式>]……
[where <条件>] -- 如果省略该子句,则修改基本表中的所有元组

修改某一个元组的值

将 A002 号图书的单价改为 28:

update 图书
set 单价 = 28
where 图书号 = 'A002'

修改多个元组的值

将多有图书单价减一元:

update 图书
set 单价 = 单价 - 1

带子查询的修改语句

将读者李明的所有借阅记录的借阅日期置为系统当前日期,还书日期置为 NULL:

update 借阅
set 借阅日期=getdate(), 还书日期=NULL
where '李明' =
(
select 读者姓名
from 读者
where 借阅.读者编号 = 读者.读者编号
)

等价于:

update 借阅
set 借阅日期=getdate(), 还书日期=NULL
where 读者编号 in
(
select 读者编号
from 读者
where 读者姓名='李明'
)

删除数据

一般格式:

delete from <表名>
[where <条件>]

删除满足 where 子句条件的所有元组。

  • delete 删除的是基本表中的数据,而不是表的定义。
  • 省略 where 子句将删除所有元组。
  • 在 where 子句中也可以嵌入子查询。
  • 数据一旦被删除将无法恢复,除非有备份。

删除某一个元组的值

将 A002 号图书记录删除:

delete from 图书
where 图书号='A002'

删除多个元组的值

delete from 借阅

将借阅表中的所有元组都删除了,但是这个表还在,只是成了空表。

带子查询的删除语句

删除莫言所编写的图书的所有借阅记录:

delete from 借阅
where '莫言' = (
select 主编 from 图书
where 借阅.图书号 = 图书.图书号
)

等价于:

delete from 借阅
where 图书号 in (
select 图书号 from 图书
where 主编 = '莫言'
)

[SQL]数据更新的更多相关文章

  1. 4 SQL 数据更新

    4 数据更新 4-1 数据的插入(INSERT语句的使用方法) 通过create table语句创建出来的表,可以将其比作一个空空如也的箱子.只有把数据装入到这个箱子后,它才能称为数据库.用来装入数据 ...

  2. SQL数据库基本语句

    SQL特点--> 1)综合统一.SQL是集数据定义.数据操作和数据控制于一体,语言峰峰统一,可独立完成数据库生命周期的所有活动. 2)高度非过程化.SQL语言是高度非过程化语言,当进行数据操作时 ...

  3. VB6.0数据库开发五个实例——罗列的总结

    实例一: 系统登录对话框 设计分析:数据库管理系统登录对话框两种基本方法:数据库中建立数据表用于保存系统用户登录信息:支持安全验证的数据库管理系统,可将系统用户定义为数据库用户. 技术要领:1.Ent ...

  4. MySQL基础和JDBC

    第一章 命令行工具 mysqladmin:MySQL服务器管理工具 mysql:MySQL客服端链接工具 mysqldump 演示链接到服务器host=127.0.0.1,用户名为root,密码为空 ...

  5. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  6. 分享一段数据库中表数据更新SQL

    应用场景 我们在应用程序开发的时候,经常会遇到这样的一种情况:附属表更新了,主表的数据没有更新,这个关联表不只是外键的关联(通过附属表 ID 关联),主表中还会存在一些附属表的字段,这样一般做的目的是 ...

  7. SQL从入门到基础–03 SQLServer基础1(主键选择、数据插入、数据更新)

    一.SQL语句入门 1. SQL语句是和DBMS“交谈”专用的语句,不同DBMS都认SQL语法. 2. SQL语句中字符串用单引号. 3. SQL语句中,对于SQL关键字大小写不敏感,对于字符串值大小 ...

  8. 《SQL 基础教程》第四章:数据更新

    数据更新包括了表存在的情况下数据的添加,数据的删除和数据的更新,主要是下面三个语句: INSERT 语句 DELETE 语句 UPDATE 语句 在本章的最后,讲了关于「事务」的相关知识,用于对作出的 ...

  9. SQL Fundamentals: 数据更新及事务处理(INSERT INTO,UPDATE,DELETE,事务,锁)

    SQL Fundamentals || Oracle SQL语言 在SQL语句中,数据操作语言DML由两部分组成,查询(DQL).更新操作(增加,修改,删除). 增加数据(INSERT INTO) 数 ...

随机推荐

  1. Java反射机制开发经验总结

    我在实际项目当中有经常用到反射机制,故而将学会的反射用法做一些汇总笔记,当做以后复盘所用. 存在这样一个类: package com.example.demo; import com.alibaba. ...

  2. Pandas高级教程之:plot画图详解

    目录 简介 基础画图 其他图像 bar stacked bar barh Histograms box Area Scatter Hexagonal bin Pie 在画图中处理NaN数据 其他作图工 ...

  3. jquery combo.select. 下拉选择插件

    演示地址:http://www.dowebok.com/demo/179/index5.html 引入js.css 即可使用,效果如图所示: 这个插件的好处是可以在输入框里面输入数据 自动检索内容. ...

  4. CentOS-yum安装Redis(单点)

    源文件安装(推荐安装) 在CentOS系统中,首先安装EPEL仓库,然后更新yum源: $ yum install epel-release -y $ yum update -y 然后安装Redis数 ...

  5. HADOOP及SPARK安装步骤及问题解决

    说明:主节点IP:192.168.35.134   主机名:master 从节点slave1 IP: 192.168.35.135   主机名:slave1 从节点slave2 IP: 192.168 ...

  6. CTF反序列化逃逸

    刷了一下CTF反序列化的题,去年没有好好了解.又补了一次PHP,害太菜了.每天看看别人的博客真的可以鼓舞人.简单记录一下两道字符串逃逸问题 推荐一个反序列化总结的很好的笔记https://www.cn ...

  7. CF1539A Contest Start[题解]

    Contest Start 题目大意 有 \(n\) 个人报名参加一个比赛,从 \(0\) 时刻开始每隔 \(x\) 分钟有一个人开始比赛,每个人参赛时间相同,均为 \(t\) .定义一个选手的不满意 ...

  8. python使用笔记008-模块

    模块的原理: 1.就是一个python文件 2.标准模块是python自带的 3.第三方模块需要自己安装 导入模块的顺序: 1.从当前目录下找 2.从python的环境变量中找 一.自己定义的模块 1 ...

  9. LeetCode通关:听说链表是门槛,这就抬脚跨门而入

    分门别类刷算法,坚持,进步! 刷题路线参考:https://github.com/youngyangyang04/leetcode-master       https://github.com/ch ...

  10. P4774-屠龙勇士-扩展中国剩余定理

    屠龙勇士 很久很久以前,巨龙突然出现,带来了灾难带走公主又消失不见.王国十分危险,世间谁最勇敢,一位英雄出现-- 学习于该大佬博客 那么你就是这位英雄,不过不同的是,你面对的是一群巨龙,虽然巨龙都不会 ...