根据给定的文件信息,以下是对SQL Server语句适用性的详细解析,涵盖了数据库管理语言(DDL)、数据操作语言(DML)、数据控制语言(DCL)等关键知识点: ### 数据库管理语言(DDL) #### 创建数据库 - `CREATE DATABASE database-name`:用于创建一个新的数据库,其中`database-name`是新数据库的名称。 #### 删除数据库 - `DROP DATABASE dbname`:用来删除一个已存在的数据库,`dbname`为要删除的数据库名称。 #### 设备管理 - **添加备份设备**: ```sql USE master EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat' ``` 这条语句用于在SQL Server中添加一个磁盘备份设备,以便后续进行数据库备份。 - **执行备份**: ```sql BACKUP DATABASE pubs TO testBack ``` 上述语句将`pubs`数据库的数据备份到之前定义的备份设备`testBack`上。 #### 表结构管理 ##### 创建表 - 基础语法: ```sql CREATE TABLE tabname (col1 type1 [NOT NULL] [PRIMARY KEY], col2 type2 [NOT NULL], ...) ``` 此语句用于创建一个新表,并定义其列名、类型及是否允许空值或作为主键。 - 使用旧表结构创建新表: - `CREATE TABLE tab_new LIKE tab_old`:利用已有表`tab_old`的结构来创建新表`tab_new`。 - `CREATE TABLE tab_new AS SELECT col1, col2 FROM tab_old DEFINITION ONLY`:仅复制`tab_old`表的列定义至`tab_new`,不包含数据。 ##### 删除表 - `DROP TABLE tabname`:删除指定的表`tabname`。 ##### 修改表结构 - 添加列: ```sql ALTER TABLE tabname ADD COLUMN col type ``` 在`tabname`表中添加一列`col`,并指定其类型`type`。 - 修改主键: - 添加主键: ```sql ALTER TABLE tabname ADD PRIMARY KEY (col) ``` - 删除主键: ```sql ALTER TABLE tabname DROP PRIMARY KEY (col) ``` ##### 索引管理 - 创建索引: ```sql CREATE [UNIQUE] INDEX idxname ON tabname (col) ``` 创建名为`idxname`的索引,在`tabname`表的`col`列上,可选`UNIQUE`关键字表示唯一性。 - 删除索引: ```sql DROP INDEX idxname ``` 删除名为`idxname`的索引。 ##### 视图管理 - 创建视图: ```sql CREATE VIEW viewname AS SELECT statement ``` 通过`SELECT statement`创建一个名为`viewname`的视图。 - 删除视图: ```sql DROP VIEW viewname ``` 删除名为`viewname`的视图。 ### 数据操作语言(DML) #### 基本操作 - 查询: ```sql SELECT * FROM table1 WHERE 条件 ``` - 插入: ```sql INSERT INTO table1 (field1, field2) VALUES (value1, value2) ``` - 删除: ```sql DELETE FROM table1 WHERE 条件 ``` - 更新: ```sql UPDATE table1 SET field1 = value1 WHERE 条件 ``` #### 高级查询 - 模糊查询: ```sql SELECT * FROM table1 WHERE field1 LIKE '%value1%' ``` - 排序: ```sql SELECT * FROM table1 ORDER BY field1, field2 [DESC] ``` - 聚合函数: - 计数: ```sql SELECT COUNT(*) AS total_count FROM table1 ``` - 求和: ```sql SELECT SUM(field1) AS sum_value FROM table1 ``` - 平均值: ```sql SELECT AVG(field1) AS avg_value FROM table1 ``` - 最大值: ```sql SELECT MAX(field1) AS max_value FROM table1 ``` - 最小值: ```sql SELECT MIN(field1) AS min_value FROM table1 ``` ### 数据控制语言(DCL) - 授予权限: ```sql GRANT permission TO user ``` - 撤销权限: ```sql REVOKE permission FROM user ``` - 提交事务: ```sql COMMIT ``` - 回滚事务: ```sql ROLLBACK ``` ### 集合操作 - UNION:用于合并两个或多个SELECT语句的结果集,自动去除重复行。 - EXCEPT:返回在第一个SELECT语句结果集中存在但在第二个SELECT语句结果集中不存在的行。 - INTERSECT:返回两个SELECT语句结果集中的公共行。 ### JOIN操作 - LEFT OUTER JOIN:左外连接,返回左表的所有记录和右表中匹配的记录,如果右表没有匹配,则结果集中相应的列为空。 - RIGHT OUTER JOIN:右外连接,返回右表的所有记录和左表中匹配的记录,如果左表没有匹配,则结果集中相应的列为空。 - FULL OUTER JOIN:全外连接,返回左表和右表中所有记录,如果任意一边没有匹配,则结果集中相应的列为空。 ### 其他操作 - 子查询:可以在一个查询中嵌套另一个查询,以获取更复杂的数据筛选或处理能力。 以上总结了SQL Server中常用的DDL、DML和DCL语句,以及集合操作和JOIN操作的基础用法,适用于各种数据库管理任务,包括数据库创建与维护、数据操作、权限控制和复杂数据检索等场景。
SQL分类:
DDL―数据定义语言(CREATE,ALTER,DROP,DECLARE)
DML―数据操纵语言(SELECT,DELETE,UPDATE,INSERT)
DCL―数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
首先,简要介绍基础语句:
1、说明:创建数据库
CREATE DATABASE database-name
2、说明:删除数据库
drop database dbname
3、说明:备份sql server
--- 创建 备份数据的 device
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack
4、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
5、说明:删除新表drop table tabname
6、说明:增加一个列
Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:添加主键: Alter table tabname add primary key(col)
说明:删除主键: Alter table tabname drop primary key(col)
8、说明:创建索引:create [unique] index idxname on tabname(col….)
注:索引是不可更改的,想更改必须删除重新建。
9、说明:创建视图:create view viewname as select statement
删除视图:drop view viewname
10、说明:几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
11、说明:几个高级查询运算词
A: UNION 运算符
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
12、说明:使用外连接
A、left outer join:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right outer join:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
剩余7页未读,继续阅读
- 粉丝: 0
- 资源: 1
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 【岗位说明】装修公司各部门岗位职责.docx
- 【岗位说明】装修公司行政室岗位职责.docx
- 【岗位说明】保洁部岗位职责.doc
- 【岗位说明】保洁公司岗位职责.doc
- 【岗位说明】保洁员岗位职责.doc
- 【岗位说明】保洁员岗位职责说明书.doc
- 【岗位说明】清洁工岗位职责说明.doc
- 【岗位说明】厨师厨工岗位职责02.doc
- 【岗位说明】绿化工岗位职责及考核标准.doc
- 【岗位说明】绿化岗位职责.doc
- 【岗位说明】绿化工岗位标准.doc
- 【岗位说明】绿化工岗位职责.doc
- 【岗位说明】物业小区保安岗位职责.doc
- 【岗位说明】物业保安岗位职责.doc
- 【岗位说明】物业保洁员岗位职责绿化员岗位职责.doc
- 【岗位说明】物业综合主管岗位职责说明书.doc