第3章 关系数据库标准语言SQL--35-36_第1页
第3章 关系数据库标准语言SQL--35-36_第2页
第3章 关系数据库标准语言SQL--35-36_第3页
第3章 关系数据库标准语言SQL--35-36_第4页
第3章 关系数据库标准语言SQL--35-36_第5页
已阅读5页,还剩33页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数据库原理与应用数据库原理与应用第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL-3.5-3.5管理数据表管理数据表-3.6-3.6数据更新数据更新第第2 2页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL本章要点本章要点 本章介绍关系数据库标准语言本章介绍关系数据库标准语言SQLSQL。 SQLSQL语言包括语言包括数据定义语言(数据定义语言(DDLDDL,Data Definition Data Definition LanguageLanguage)、)、数据操纵语言(数据操纵语言(DMLDML,Data Manipu

2、lation Data Manipulation LanguageLanguage)和)和数据控制语言(数据控制语言(DCLDCL,Data Control Data Control LanguageLanguage)。)。数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL第第3 3页页本章主要内容本章主要内容3.1 SQL3.1 SQL语言的基本概念与特点语言的基本概念与特点3.2 SQL Server 20053.2 SQL Server 2005基础知识基础知识3.3 3.3 数据库的体系结构数据库的体系结构3.4 3.4 创建及管理数据库

3、创建及管理数据库 3.5 3.5 管理数据表(含数据类型)管理数据表(含数据类型)3.6 SQL3.6 SQL数据更新数据更新3.7 SQL3.7 SQL数据查询数据查询 3.8 3.8 视图视图3.9 SQL3.9 SQL数据控制数据控制3.10 3.10 嵌入式嵌入式SQLSQL语言语言* *习题习题第第4 4页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL3.5 3.5 管理数据表管理数据表 建立数据库最重要的一步就是创建其中的数据表建立数据库最重要的一步就是创建其中的数据表,即决定数即决定数据库包括哪些表,每个表中包含哪些字段,每个

4、字段的数据据库包括哪些表,每个表中包含哪些字段,每个字段的数据类型是什么等。类型是什么等。 创建表的实质就是定义表结构及约束等属性创建表的实质就是定义表结构及约束等属性,在创建数据表,在创建数据表之前,先要设计表,即确定表的名字、所包含的各字段名、之前,先要设计表,即确定表的名字、所包含的各字段名、字段的数据类型、长度、是否可为空值等等,这些属性构成字段的数据类型、长度、是否可为空值等等,这些属性构成表结构。表结构。3.5.1 3.5.1 数据类型数据类型3.5.2 3.5.2 界面方式下创建及编辑数据表界面方式下创建及编辑数据表3.5.3 3.5.3 命令方式下创建及编辑数据表命令方式下创建

5、及编辑数据表第第5 5页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL3.5.1 3.5.1 字段数据类型字段数据类型SQL Server系统数据类型系统数据类型第第6 6页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL1 1)整数型)整数型(常用(常用intint型)型)第第7 7页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL2 2)浮点型)浮点型(常用(常用floatfloat和和decimaldecimal) 浮点数据类型可以

6、用来存储含小数的十进制数,包括精确数浮点数据类型可以用来存储含小数的十进制数,包括精确数值类型和近似数值类型。值类型和近似数值类型。 精确数值类型精确数值类型numericnumeric和和decimaldecimal数据类型的语法如下所示:数据类型的语法如下所示: numeric (p, s)numeric (p, s)、 decimal decimal(p, s)(p, s) 在上面的语法中,在上面的语法中,p p表示数字的精度(不含小数点),表示数字的精度(不含小数点),s s表示数字的表示数字的小数位数小数位数。精度。精度p p的取值范围是的取值范围是1 1至至3838,默认值是,默认

7、值是1818。小数位数。小数位数s s的取的取值范围必须是值范围必须是0 0至至p p之间的数值之间的数值( (包括包括0 0和和p)p)。例如,例如,123.45,123.45,则则 p=5p=5,s=2s=2 近似浮点数值类型近似浮点数值类型floatfloat和和realreal数据类型的语法如下所示:数据类型的语法如下所示: floatfloat、realreal 注意:在注意:在 wherewhere子句搜索条件中(特别是子句搜索条件中(特别是 = = 和和 运算符),应避运算符),应避免使用免使用 floatfloat 或或 real real 列。最好限制使用列。最好限制使用 f

8、loatfloat 和和 real real 列做列做 或或 =0 and stuage=0 and stuage=100) default 20, studept varchar(30) studept varchar(30) ) )第第2222页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL练习练习用命令方式创建如下数据库用命令方式创建如下数据库: :1 1、数据库名称:、数据库名称:jxgl jxgl 2 2、数据库包含的表:、数据库包含的表:学生表:学生表:student(sno,sname,sex,age,dept)student

9、(sno,sname,sex,age,dept)课程表:课程表:course(cno,cname,credit)course(cno,cname,credit)学生选课表:学生选课表:sc(sno,cno,score)sc(sno,cno,score) 注:自己确定字段类型,主外键,默认值,是否允许为空,注:自己确定字段类型,主外键,默认值,是否允许为空,约束条件等。约束条件等。第第2323页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL2 2)修改数据表)修改数据表T-SQLT-SQL中对数据表进行修改的语句是中对数据表进行修改的语句是A

10、LTER TABLEALTER TABLE,基本语法是:,基本语法是:ALTER TABLE ALTER TABLE tablenametablename ALTER COLUMN ALTER COLUMN column_namecolumn_name / /* *修改已有字段属性修改已有字段属性* */ /new_data_typenew_data_type ( precision , scale ) ( precision , scale ) NULL | NOT NULL NULL | NOT NULL | | ADDADD ,.n ,.n / /* *增加字段增加字段* */ /| |

11、 DROPDROP CONSTRAINT CONSTRAINT constraint_nameconstraint_name | COLUMN | COLUMN columncolumn ,.n ,.n / /* *删除字段删除字段* */ /第第2424页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL修改基本表说明修改基本表说明其中其中: : 指定需要修改的基本表,指定需要修改的基本表,ADDADD子句用于增加新列和新的完整性约束条件,子句用于增加新列和新的完整性约束条件,ALTERALTER子句用于修改原有的列定义,子句用于修改原有的列

12、定义,DROPDROP子句用于删除指定的完整性约束条件或原有列。子句用于删除指定的完整性约束条件或原有列。第第2525页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL示例示例 例例1 1 向向studentstudent表增加表增加“入学时间入学时间”列,其数据类型为日期型列,其数据类型为日期型 alter table student alter table student addadd scomescome datetimedatetime注:不论基本表中原来是否已有数据,新增加的列一律为空值。注:不论基本表中原来是否已有数据,新增加的列

13、一律为空值。 例例2 2 将年龄的数据类型改为半字长整数。将年龄的数据类型改为半字长整数。 alter table student alter table student alteralter column age column age smallintsmallint 注:修改原有的列定义,会使列中数据作新旧类型的自动转化,注:修改原有的列定义,会使列中数据作新旧类型的自动转化,有可能会破坏已有数据。有可能会破坏已有数据。 例例3 3 删除例删除例1 1增加的增加的“入学时间入学时间”列。列。 alter table s alter table s dropdrop column colum

14、n scomescome第第2626页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL3 3)删除数据表)删除数据表T-SQLT-SQL中对表进行删除的语句是中对表进行删除的语句是DROP TABLEDROP TABLE,该语,该语句的语法格式为:句的语法格式为:DROP TABLE table_nameDROP TABLE table_name其中其中table_nametable_name是要被删除的表名。是要被删除的表名。例如,要删除表例如,要删除表SCSC,使用的,使用的T-SQLT-SQL语句为:语句为:DROP TABLE SCD

15、ROP TABLE SC返回本节第第2727页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL3.6 SQL3.6 SQL数据更新数据更新1 1、插入数据、插入数据 INSERTINSERT2 2、修改数据、修改数据 UPDATEUPDATE3 3、删除数据、删除数据 DELETEDELETE第第2828页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL1 1、插入表数据、插入表数据插入一个元组基本格式插入一个元组基本格式INSERT INTO INSERT INTO (,) ) VALUE

16、S(VALUES(,) ) 插入一个查询结果插入一个查询结果INSERT INTO (,) 第第2929页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL插入操作举例插入操作举例 插入一个完整的元组插入一个完整的元组 INSERT INTO Student VALUES(200215121,李勇李勇,男男,20,CS) 插入一个不完整的元组插入一个不完整的元组 INSERT INTO Student(Sno,Sname) VALUES(200215122,刘晨刘晨) 插入一个查询结果插入一个查询结果 INSERT INTO Student2(

17、 SELECT * FROM Student) 第第3030页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL插入数据时注意事项插入数据时注意事项 新插入记录应与表结构定义匹配;新插入记录应与表结构定义匹配; 列名项数与提供值的数目应匹配;列名项数与提供值的数目应匹配; 可以指定列值为可以指定列值为NullNull; INTOINTO子句中没有出现的属性列,新记录在这些列上将取空值(子句中没有出现的属性列,新记录在这些列上将取空值(NullNull)或默认值;)或默认值; 如果如果INTOINTO子句中没有指明任何列名,则新插入的记录必须在每

18、子句中没有指明任何列名,则新插入的记录必须在每个属性列上均有值,且顺序应与表中属性列顺序一致。个属性列上均有值,且顺序应与表中属性列顺序一致。第第3131页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL练习练习 向向StudentStudent表中插入一条记录表中插入一条记录(200501,(200501,李勇李勇) 向向StudentStudent表中插入记录(表中插入记录(200502200502,男男)和(和(200503200503,女女) 向向StudentStudent表中插入记录(表中插入记录(200504200504,刘晨刘

19、晨)和()和(200505200505,女女)第第3232页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL2 2、修改表数据、修改表数据基本格式基本格式Update table_nameUpdate table_nameSet Set = , , = where where 含义:修改指定表中满足含义:修改指定表中满足wherewhere子句条件的结果子句条件的结果说明:说明: 一次可以更新多个属性的值;一次可以更新多个属性的值; 如果省略如果省略wherewhere语句,则表示要修改表中的所有记录。语句,则表示要修改表中的所有记录。第第3

20、333页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL 三种修改方式三种修改方式1 1、修改某一个元组的值、修改某一个元组的值2 2、修改多个元组的值、修改多个元组的值3 3、带子查询的修改语句、带子查询的修改语句 在修改之前建议先查看表记录(在修改之前建议先查看表记录(Select Select * * from table from table)第第3434页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL 查看数据表查看数据表StudentStudent所有记录所有记录SELECT

21、SELECT * * FROM Student FROM Student 查看数据表查看数据表StudentStudent中字段学号、姓名的所有记录中字段学号、姓名的所有记录SELECT SnoSELECT Sno,Sname FROM StudentSname FROM Student 给学号为给学号为200215122200215122的学生年龄增加的学生年龄增加1 1岁岁 UPDATE Student SET age = age+1 WHERE UPDATE Student SET age = age+1 WHERE Sno=Sno=200215122200215122 给给CSCS系的

22、男同学年龄增加系的男同学年龄增加1 1岁岁UPDATE Student SET age = age+1 UPDATE Student SET age = age+1 WHERE dept=WHERE dept=CSCS and sex= and sex=男男第第3535页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL 给所有课程的学分提高给所有课程的学分提高1 1分分UPDATE Course SET credit = credit +1UPDATE Course SET credit = credit +1 将学号为将学号为2005151

23、21200515121同学的姓名,性别,年龄分别设置为(张三,同学的姓名,性别,年龄分别设置为(张三,男,男,2020)UPDATE Student SET sname=UPDATE Student SET sname=张三张三,sex=sex=男男,age=20age=20WHERE Sno=200515121WHERE Sno=200515121 给给CSCS系的学生的选课成绩增加系的学生的选课成绩增加1010分分( (带子查询的修改语句带子查询的修改语句) )UPDATE SC SET score= score+10UPDATE SC SET score= score+10WHERE Sno= (SELECT Sno FROM StudentWHERE Sno= (SELECT Sno FROM StudentWHERE Student.dept =CS)WHERE Student.dept =CS)第第3636页页数据库原理与应用数据库原理与应用-第第3 3章章 关系数据库标准语言关系数据库标准语言SQLSQL练习练习 将数据表将数据表studentstudent中学号为中学号为200215121200215121的记录的性别及所在系的字的记录的性别及所在系的字段值改为(女,段值改为(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论