MSSQL之三 在表中操纵数据

简介: MSSQL之三 在表中操纵数据

创建了数据库和表之后,下一步是在数据库中存储数据。作为一个数据库开发人员,你将需要修改或删除数据。你可以通过使用Transact-SQL的数据操纵语言(DML)语句来完成这些数据操纵。

本章讨论如何使用DML语句来操纵表中的数据。

重点

Ø      插入数据

Ø      更新数据

Ø      删除表中数据

预习功课

Ø        插入部分数据

Ø        批量插入数据

Ø        在表中更新数据

Ø        从表中删除数据

使用DML语句操纵数据

在表中存储数据

表创建之后只是一个空表,因此向表中插入数据是在表结构创建之后首先需要执行的操作。


向表中插入数据,应该使用INSERT语句。该语句包括了两个子句,即INSERT子句和VALUES子句。


INSERT子句指定要插入数据的表名或视图名称,它可以包含表或视图中列的列表。VALUES子句指定将要插入的数据。



Ø       在表中存储数据


你可以在表中加入数据的最小单位是行,你可以通过使用Insert DML语句添加行。Insert语句的语法是:


Insert[into]{table_name}  [(column_list)]


Values{Deafault| values_list | select_statement }


在向表中插入行的时候,必须考虑下面的指导方针:


1.     数据值的数量必须与表中或列表中的属性的数量一样。


2.     插入信息的顺序必须与为插入列出的属性的顺序相同。


3.     值从句不需要包含带有IDENTITY属性的列。


4.      信息的数据类型必须与表的列中的数据类型匹配。

【例3-1】向books表中插入一行完整数据

图 3-2

二.插入部分数据。

依赖与应用到表的列上的约束,你可以插入部分数据到表中,SQL SERVER允许你用NULL值或指定的默认约束的列插入部分数据

例如:

Insert Address

Values(104,’24,Herbon Apts’,null,56,’607009’)

【例3-3】向books表中插入部分列数据

.三.在相关表中插入数据

属于一个实体的数据可以被存储在多于一个表中。因此,当新实体添加信息的时候,你需要在所有相关的表中插入新行。在这样的情况下,你需要先在表中插入一行,它包含主键。然后,在包含外键的表中插入一行。

【例3-5】使用SELECT…INTO形式

四.在现有表中复制数据到新表。

在表中插入数据的时候,你可以将现有的表中数据复制到另一个表中,你可以用SELECT语言完成。

例子:

Select*into PreferredEmployee

From HumanResources EmployeePayHistory

Where Rate>=35

从表中更改数据

可以使用UPDATE语句更改新表中已经存在的数据。UPDATE语句既可以一次更新一行数据,也可以一次更新许多行,甚至可以一次更新表中的全部数据行。


在UPDATE语句中,使用WHERE子句指定要更新的数据行满足的基本条件,使用SET子句给出新的数据。新数据既可以是常量,也可以是指定的表达式。


UPDATE语句的基本语法形式如下:


Ø       UPDATE table_or_view_name


Ø       SET column_name = expression, …


Ø       WHERE search_condition


这里,


Table_name  指定你必须修改的表的名称。


Column_name  指定你必须修改的指定表中的列。value指定值,它是你必须更新的表的列。有些有效值包括表达式.列名和变量名。DEFAULT和NULL关键字也可以被应用。


FROM table_name   指定UPDATE语句中使用的表。


Condition   指定你必须更新的行。


【例3-7】查看books表中的数据

使用DELETE语句可以删除表中的一行或多行记录,其语法格式为:


   DELETE FROMtable_or_view [WHERE <search_condition>]


其中:table_or_view是指要删除数据的表或视图;WHERE子句指定待删除的记录应当满足的条件,WHERE子句省略时,则删除表中的所有记录。


下面是删除一行记录的例子。


【例 3-11】 删除啊成教师的记录。


   程序清单如下:


   DELETE FROMT WHERE TN=’ 啊成’


下面是删除多行记录的例子。


【例 3-12】 删除所有教师的授课记录。


程序清单如下:


   DELETE  FROM  TC


执行此语句后,TC表即为一个空表,但表的定义仍存在数据字典中。


【例 3-13】 删除李明同学选课的记录。


  DELETE FROMSC WHERE SNO=


  (SELECT SNOFROM S  WHERE SN=’ 李明’)


就像UPDATE语句一样,在DELETE语句中还可以再使用一个FROM子句指定将要删除的数据与其他表或视图之间的关系。也就是说,一个正常的DELETE语句中可以包含两个FROM子句,但是这两个FROM子句的作用是不同的。第一个FROM子句用于指定将要删除的数据所在的表或视图名称,第二个FROM子句用于指定将要删除的数据的其他复杂的条件。


DELETE语句只是删除表中的数据,表结构依然存在于数据库中。如果需要删除表结构,那么应该使用DROP TABLE语句。在删除表中的全部数据时,还可以使用TRUNCATE TABLE语句。TRUNCATE TABLE语句和DELETE语句都可以将表中的全部数据删除,但是两条语句又有不同的特点。


使用DELETE语句删除

也可以使用TRUNCATE语句删除。

TRUNCATE语句的语法是:

 TRUNCATE      TABLE        table_name


这里,


table_name 指定你必须删除行的表的名称。


但是,TRUNCATE  TABLE被执行的很快。


TRUNCATE  TABLE不支持WHERE从句。而且,TRUNCATE TABLE语句不触发触发器。当truncate被使用的时候,删除行不进入事务日志。

实践问题

1、当插入行到表中的时候,哪个语句是不正确的?


A、数据值的数量必须与表中或列表的属性中的数量一样。


B、 插入信息的顺序不需要与为了插入列出的属性的顺序一致。


C、Values从句不需要包含带IDENTITY属性的列。


D、信息的数据类型必须与表中列的数据类型匹配。


2、你如何在相关的表中插入数据?


3、解释DELETE  TABLE和TRUNCATE  TABLE 语句的区别

小结

1、INSERT语句被用于插入数据到表中。


2、当插入数据到表中的时候,信息的数据类型必须与表中列的数据类型匹配。


3、你可以通过使用SELECT INTO命令从一个表中赋值内容到另一表中。


4、SQL Server提供称为UPDATE的行更新语句以修改表中的值。


5、你可以使用DELETE语句从表中删除一行。


6、你可以使用TRUNCATE  TABLE语句从表中删除所有的行。


目录
相关文章
|
7月前
|
SQL 关系型数据库 MySQL
Mysql基础第二十四天,创建表和操纵表
Mysql基础第二十四天,创建表和操纵表
56 0
Mysql基础第二十四天,创建表和操纵表
|
SQL Go 数据库
MSSQL系列之二.二数据库与表管理
MSSQL系列之二.二数据库与表管理
58 0
|
6月前
|
关系型数据库 MySQL 数据库
关系型数据库MySQL开发要点之多表查询2024详解
关系型数据库MySQL开发要点之多表查询2024详解
39 2
|
7月前
|
SQL 关系型数据库 MySQL
MySQL必知必会:第十六章《创建高级联结》
MySQL必知必会:第十六章《创建高级联结》
|
7月前
|
SQL 存储 Oracle
数据库技术--数据库引擎,数据访问接口及其关系详解(附加形象的比喻)
数据库技术--数据库引擎,数据访问接口及其关系详解(附加形象的比喻)
|
数据库
delphi insert各种类型数据(数据库InterBase)
delphi insert各种类型数据(数据库InterBase)
|
数据库
数据库系统概论第三章示例数据库表建立与插入代码
数据库系统概论第三章示例数据库表建立与插入代码
95 0
|
存储 SQL 关系型数据库
【MySQL从入门到精通】【高级篇】(二十六)建了索引就能用么?我看未必。来看看几种索引失效的情况吧
【MySQL从入门到精通】【高级篇】(二十五)EXPLAIN中ref、rows、filtered、Extra字段的剖析 通过前面几篇文章的学习,相信小伙伴们对EXPLAIN命令有了一个更加深入理解。这篇文章我们将来学习索引失效的11种情况。有时候并不是说加了索引,就一定能用上索引,还是要具体情况具体分析。
179 0
【MySQL从入门到精通】【高级篇】(二十六)建了索引就能用么?我看未必。来看看几种索引失效的情况吧
|
关系型数据库 MySQL 数据库
MySQL数据库基础学习小终结:连接查询、表结构的修改、约束条件、MySQL与python交互
MySQL数据库基础学习小终结:连接查询、表结构的修改、约束条件、MySQL与python交互
157 0
MySQL数据库基础学习小终结:连接查询、表结构的修改、约束条件、MySQL与python交互
|
关系型数据库 MySQL 数据库
MySQL数据库基础学习小终结:连接查询、表结构的修改、约束条件、MySQL与python交互3
MySQL数据库基础学习小终结:连接查询、表结构的修改、约束条件、MySQL与python交互
245 0
MySQL数据库基础学习小终结:连接查询、表结构的修改、约束条件、MySQL与python交互3