根据给定文件的信息,我们可以将其中涉及的重要数据库语言知识点归纳整理如下: ### 一、数据库定义语言(DDL) #### 1. 创建数据库 用于创建一个新的数据库。 ```sql CREATE DATABASE database-name; ``` #### 2. 删除数据库 用于删除一个已存在的数据库。 ```sql DROP DATABASE dbname; ``` ### 二、数据操纵语言(DML) #### 1. 查询数据 用于从数据库表中检索数据。 ```sql SELECT * FROM table1 WHERE condition; ``` #### 2. 插入数据 用于向表中插入新行。 ```sql INSERT INTO table1 (field1, field2) VALUES (value1, value2); ``` #### 3. 删除数据 用于从表中删除行。 ```sql DELETE FROM table1 WHERE condition; ``` #### 4. 更新数据 用于更新表中的行。 ```sql UPDATE table1 SET field1 = value1 WHERE condition; ``` ### 三、数据定义语言(DDL)详解 #### 1. SQL Server备份与恢复 ##### 添加备份设备 ```sql USE master; EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'; ``` ##### 执行备份 ```sql BACKUP DATABASE pubs TO testBack; ``` #### 2. 创建表 用于定义新的表结构。 ```sql CREATE TABLE tabname ( col1 type1 [NOT NULL] [PRIMARY KEY], col2 type2 [NOT NULL], ... ); ``` ##### 快速复制表结构 方法 A: 使用 `LIKE` 关键字创建新表,保留原有表结构但不包含数据。 ```sql CREATE TABLE tab_new LIKE tab_old; ``` 方法 B: 使用 `AS SELECT` 结合 `DEFINITION ONLY` 创建新表,同样仅保留表结构。 ```sql CREATE TABLE tab_new AS SELECT col1, col2 FROM tab_old DEFINITION ONLY; ``` #### 3. 删除表 用于移除一个表及其所有关联的数据。 ```sql DROP TABLE tabname; ``` #### 4. 修改表 用于在现有表上添加或修改列。 ```sql ALTER TABLE tabname ADD COLUMN col type; ``` 注意:某些数据库系统如 DB2 支持直接修改列类型,但对某些类型如 VARCHAR 的修改有特定限制。 #### 5. 添加主键 用于指定表中的一个或多个列作为主键。 ```sql ALTER TABLE tabname ADD PRIMARY KEY (col); ``` #### 6. 删除主键 用于移除表中的主键约束。 ```sql ALTER TABLE tabname DROP PRIMARY KEY (col); ``` #### 7. 创建索引 用于提高查询效率。 ```sql CREATE [UNIQUE] INDEX idxname ON tabname (col); ``` #### 8. 删除索引 用于移除表上的索引。 ```sql DROP INDEX idxname; ``` **注意**: 索引的创建与删除会影响查询性能,请谨慎操作。 #### 9. 创建视图 用于封装一个查询结果集,方便重复使用。 ```sql CREATE VIEW viewname AS SELECT statement; ``` #### 10. 删除视图 用于移除一个视图。 ```sql DROP VIEW viewname; ``` ### 四、高级查询 #### 1. UNION 用于合并两个或多个 SELECT 语句的结果集,去重并返回唯一记录。 ```sql SELECT column_name(s) FROM table1 UNION SELECT column_name(s) FROM table2; ``` **UNION ALL**: 返回所有记录,包括重复项。 #### 2. EXCEPT 用于获取第一个 SELECT 语句结果集中存在而第二个 SELECT 语句结果集中不存在的记录。 ```sql SELECT column_name(s) FROM table1 EXCEPT SELECT column_name(s) FROM table2; ``` **EXCEPT ALL**: 返回所有记录,包括重复项。 #### 3. INTERSECT 用于获取两个 SELECT 语句结果集中的共同记录。 ```sql SELECT column_name(s) FROM table1 INTERSECT SELECT column_name(s) FROM table2; ``` **INTERSECT ALL**: 返回所有记录,包括重复项。 ### 五、连接操作 #### 1. LEFT OUTER JOIN 用于从左表(表 A)选取所有记录,并从右表(表 B)选取匹配的记录。 ```sql SELECT a.a, a.b, a.c, b.c, b.d, b.f FROM a LEFT OUTER JOIN b ON a.a = b.c; ``` #### 2. RIGHT OUTER JOIN 用于从右表(表 B)选取所有记录,并从左表(表 A)选取匹配的记录。 #### 3. FULL OUTER JOIN 用于从两个表中选取所有记录,包括没有匹配记录的情况。 ### 六、其他高级操作 #### 1. 数据导出/导入 用于将数据从一个表移动到另一个表中。 ```sql -- 导出数据到新表 SELECT * INTO new_table FROM old_table WHERE condition; -- 导入数据到现有表 INSERT INTO existing_table (column1, column2, ...) SELECT data1, data2, ... FROM source_table WHERE condition; ``` #### 2. 多表查询优化 用于提高多表查询的性能。 ```sql SELECT a.title, a.username, b.add_date FROM table_a INNER JOIN (SELECT MAX(add_date) add_date FROM table_b WHERE table_b.title = a.title) b ON a.title = b.title; ``` 以上是对给定文件中提到的各种数据库语言知识点的详细总结与解释。通过掌握这些核心概念和技术,可以帮助你在实际工作中更高效地管理和操作数据。
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:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
剩余6页未读,继续阅读
- 粉丝: 0
- 资源: 3
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助