ImageVerifierCode 换一换
格式:DOCX , 页数:17 ,大小:24.37KB ,
资源ID:4792976      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4792976.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(SQLSERVER复习提纲.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

SQLSERVER复习提纲.docx

1、SQLSERVER复习提纲SQL SERVER复习提纲第一部分 SQL 常用命令一、 数据库操作 1创建数据库 简单创建 CREATE DATABASE 数据库名 例:create database test 完整定义:例:CREATE DATABASE sales_1ON PRIMARY(NAME= sales_1_data,FILENAME=d: sales_1.mdf,SIZE=10,MAXSIZE=unlimited,FILEGROWTH=20%)LOG ON(NAME= sales_1_log,FILENAME=d: sales_1_log.ldf,SIZE=3,MAXSIZE=10

2、,FILEGROWTH=2) 2更改数据库名称 sp_renamedb oldname, newname 例:sp_renamedb test, test1 3修改数据库大小 例:DBCC SHRINKDATABASE(test,40,NOTRUNCATE) DBCC SHRINKFILE(test_1,4) 4删除数据库 DROP DATABASE 数据库名 5查看数据库信息 sp_helpdb 查看当前服务器上的所有数据库信息,可以指定数据库名称 sp_databases查看当前服务器上的所有可以使用的数据库 sp_helpfile 查看当前数据库中的所有文件信息,可以指定文件名 sp_h

3、elpfilegroup 查看当前数据库中的所有文件组信息,可以指定文件组二、表操作 1创建表 CREATE TABLE 数据表名(字段1名 字段1的数据类型,字段2名 字段2的数据类型,. . . ,字段n名 字段n的数据类型) 例:create table card(card_id char(6),card_name char(10),card_type char(10),card_credit decimal(5,2), card_date datetime) Create table usecard (card_id char(6), exp_type char(20) exp cha

4、r(100),score decimal(10,2),scoredate datetime)注意:常用数据类型整型: int 不能设置长度浮点型:Decimal(长度,小数) numeric(长度,小数) 字符型:char(10) varchar(10)日期型:datetime 不能设置长度 当要创建表同时创建主键约束:create table card(card_id char(6) constraint pk_name(约束名) PRIMARY KEY CLUSTERED,card_name char(10),card_credit decimal(5,2), card_date date

5、time) 2修改表结构 在表中增加一个的字段 ALTER TABLE 数据表名 ADD 字段名 字段数据类型 例:alter table card add card_grade int 在表中删除一个字段ALTER TABLE 数据表名 DROP COLUMN 字段名 例:alter table card drop column card_grade 修改表中某字段数据类型ALTER TABLE 数据表名 ALTER COLUMN 字段名 字段数据类型 例:alter table card alter column card_grade decimal(5,2) 为已存在的表设置主键(先将要

6、设置成主键的字段修改为NOT NULL)ALTER TABLE 数据表名 ADD CONSTRAINT card_pk PRIMARY KEY CLUSTERED(card_id) 例:alter table card ADD constraint pk_name(约束名) PRIMARY KEY CLUSTERED(card_id)3 查看表 sp_help 数据表名 sp_depends 查看表的相关性 sp_helpconstraint 查看表的约束4 删除表DROP TABLE 数据表名 例:drop table card 5 重命名表sp_rename oldname,newname

7、 例:sp_rename card1,card6 插入记录INSERT INTO 数据表名(字段1,字段2,. . .,字段n) VALUES(字段1值,字段2值,. . .,字段n值) 例:insert into card(card_id,card_name,card_credit,card_date) values(1001,王晓明,15,20070101)7 更新记录UPDATE 数据表名 SET 字段1名=字段1值,字段2名=字段2值,. . .,字段n名=字段n值例:update card set card_name=wanghong,card_credit=20 where car

8、d_id=10018 删除记录DELETE FROM 数据表名 WHERE 条件 例:delete from card where card_id=1001 9查询命令SELECT select_ist FROM table_source WHERE search_condition GROUP BY groupby_expression HAVING serch_conditing ORDER BY order_expressionASC|DESC例: 1查询card表中的所有记录 select * from card2查询card表中card_credit字段,并去掉重复值 select

9、distinct card_credit from card 3查询card表中card_id,card_name,card_credit字段 select card_id,card_name,card_credit from card4查询card表中的前10条记录 select top 10 * from card5查询card表中前面10%的记录 select top 10 percent * from card 6用INTO子句创建一个新表card1,表中包含card表的前10%的记录 select top 10 percent * into card1 from card7查询car

10、d表中card_credit大于15的记录 select * from card where card_credit158查询card表中card_credit大于15,并且日期在20070101之前的记录 select * from card where card_credit15 and card_date2) 三、视图操作 1创建视图 CREATE VIEW 视图名AS 查询命令 例:create view card_view as select * from card 2查看视图信息 sp_help 视图名 例:sp_help card_view sp_helptext 显示视图的定义

11、 例:sp_helptext card_view sp_depends 显示视图所依赖的对象 例:sp_depends card_view 3修改视图ALTER VIEW 视图名AS 查询语句 WITH CHECK OPTION例:alter view card_view as select * from card where card_credit20 with check option注意 WITH CHECK OPTION 是对条件进行检查,如果没有with check option 不符合条件的记录也会被插入表中 例:insert into card_view values(1001,

12、王晓明,15,20070101) 插入的card_credit 是15 比20小,但因为没做检查还是插入到表里了 4通过视图插入数据记录INSERT INTO 视图名VALUES(字段1值,字段2值,. . .,字段n值) 例:insert into card_view values(1001,王晓明,21,20070101) 5通过视图修改数据记录 UPDATE 视图名 SET 字段1名=字段1值,字段2名=字段2值,. . .,字段n名=字段n值例:update card_view set card_name=wanghong,card_credit=20 where card_id=10

13、01 6通过视图删除数据记录DELETE FROM 视图名 WHERE 条件 例:delete from card_view where card_id=1001 7重命名视图sp_rename oldname,newname 例:sp_rename card_view,card_view1 8删除视图DROP VIEW 视图名 例:drop view card_view四、索引的使用 1创建索引CREATE INDEX 索引名 ON 表或视图(字段名) 创建聚集唯一索引例:create unique clustered index in_card on card(card_id) 创建唯一索

14、引例:create unique index card_index on card(card_id) 创建复合索引例:create index card_comindex on card(card_name,card_date) 2查看索引sp_helpindex 索引名所属的表名 3重命名索引sp_rename objnameoldname,newname,index 例:sp_rename card.card_index,card_index1,index 4删除索引 DROP INDEX 表名索引名 例:drop index card.card_index五、存储过程 1创建存储过程 创

15、建存储过程之前要先判断这个存储过程名是否已经存在(用IF EXISTS判断)例:IF EXISTS(SELECT name FROM sysobjects WHERE name=card_pro AND type=P) DROP PROCEDURE card_pro 创建不带参数的存储过程CREATE PROCEDURE 存储过程名 AS 查询语句例:CREATE PROCEDURE stu_pro AS select * from exam执行该存储过程有2种方式: 直接打存储过程名: 例:stu_pro 用EXECUTE存储过程名: 例:EXECUTE stu_pro 创建带参数的存储过程

16、CREATE PROCEDURE 存储过程名 变量名 变量数据类型 AS 查询语句例:CREATE PROCEDURE stu_pro2 tnum char(8) AS select * from exam where t_number=tnum执行该存储过程有3种方式: 直接打存储过程名 参数的值: 例:stu_pro2 20040301 用EXECUTE存储过程名:例:execute stu_pro2 20040301 用EXECUTE存储过程名:例:execute stu_pro2 tnum=20040301 创建带参数且有返回值的存储过程例:CREATE PROCEDURE stu_p

17、ro3 tnum char(8),cnum char(6),grade char(10) output AS declare errorvalue intset errorvalue=0select grade=t_grade from exam where t_number=tnum and c_number=cnumif (ERROR0) set errorvalue=ERRORreturn errorvalue执行:declare returnvalue int,tnum char(8),cnum char(6),grade char(10)select tnum=20040301,cn

18、um=100101execute returnvalue=stu_pro3 tnum,cnum,grade outputselect returnvalue as aselect grade as b 2查看存储过程 sp_help 存储过程名 例:sp_help card_pro sp_helptext 显示存储过程的定义 例:sp_helptext card_pro sp_depends 显示存储过程所依赖的对象 例:sp_depends card_pro sp_stored_procedures 当前存储过程列表3修改存储过程ALTER PROCEDURE 存储过程名 AS 查询语句例:

19、alter procdure card_pro as select * from card where t_grade100 5重命名存储过程sp_rename oldname,newname 例:sp_rename card_pro,card_pro1 6删除存储过程: DROP PROCEDURE 存储过程名 例:drop procedure card_pro1六、触发器 1创建触发器 创建触发器之前要先判断这个触发器名是否已经存在(用IF EXISTS判断)例:IF EXISTS(SELECT name FROM sysobjects WHERE name= insert_data AN

20、D type=Tr) DROP TRIGGER card_pro 创建INSERT触发器CREATE TRIGGER 触发器名 ON 表名/视图名 AFTER INSERT AS 触发内容 例:创建在exam表中当输入分数大于100就拒绝这条记录插入 if exists(select name from sysobjectsWhere name=insert_data and type=tr) Drop trigger insert_datacreate trigger insert_data on exam after insert as if(select t_grade from ins

21、erted)100beginprint not over 100rollback end 创建UPDATE触发器 CREATE TRIGGER 触发器名 ON 表名/视图名AFTER UPDATE AS 触发内容 例:创建在exam表中当输入分数大于100就拒绝这条记录修改if exists(select name from sysobjectsWhere name=update_data and type=tr) Drop trigger update_datacreate trigger update_data on exam after update asif update(t_grad

22、e) begin if(select t_grade from inserted)100 begin print 分数不能大于 100 rollback transaction endend 创建INSERT、UPDATE触发器CREATE TRIGGER 触发器名 ON 表名/视图名AFTER INSERT,UPDATE AS 触发内容 例:if exists(select name from sysobjectsWhere name=update_data and type=tr) Drop trigger update_datacreate trigger update_data on

23、exam for insert,update asif update(t_grade) begin if(select t_grade from inserted)100 begin print 分数不能大于 100 rollback transaction endend 创建INSTEAD OF 触发器CREATE TRIGGER 触发器名 ON 表名/视图名 INSTEAD OF DELETE AS 触发内容例:create trigger exam_tri on exam instead of delete as 不允许删除记录! 2查看触发器 sp_help 触发器名 例:sp_hel

24、p exam_tri sp_helptext 显示触发器的定义 例:sp_helptext exam_tri sp_depends 显示触发器所依赖的对象 例:sp_depends exam_tri 3修改触发器 修改INSERT触发器ALTER TRIGGER 触发器名 ON 表名/视图名 AFTER INSERT AS 触发内容 修改UPDATE触发器 ALTER TRIGGER 触发器名 ON 表名/视图名AFTER UPDATE AS 触发内容 修改INSERT、UPDATE触发器ALTER TRIGGER 触发器名 ON 表名/视图名AFTER INSERT,UPDATE AS 触发

25、内容 修改INSTEAD OF 触发器ALTER TRIGGER 触发器名 ON 表名/视图名 INSTEAD OF DELETE AS 触发内容 4重命名触发器sp_rename oldname,newname 例:sp_rename card_tri,card_tri1 5删除触发器 DROP TRIGGER触发器名 例:drop trigger card_tri1第二部分 知识点一、 数据库的有关概念: 数据:文字、图表、数字、图片等等 数据库对象:表、视图、存储过程、触发器、规则等等 数据库:是数据和数据库对象的集合 数据库管理系统:管理数据的计算机软件,提供了用户和数据库之间的软件界面,使用户更方便的操作数据库。用户能方便的定义和操纵数据,维护数据的安全性和完整性、进行多用户下的控制操作。 数据库系统:由数据库、数据库管理系统及用户等等组成的 关系模型:由实体和联系构成。关系模型以表的形式表现实体,表的一行表示实体的一个实例,一列描述实体的特征或属性;联系是实体之间的对应关系,有一对

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1