根据提供的文件信息,我们可以归纳总结出一系列SQL中最精妙且常用的基本操作命令,这些命令对于初学者来说至关重要,能够帮助他们快速掌握SQL Server的核心技能。接下来将详细介绍这些知识点: ### 1. 创建数据库 (Create Database) ```sql CREATE DATABASE database-name; ``` 此命令用于创建一个新的数据库。`database-name`是你想要创建的数据库的名字。 ### 2. 删除数据库 (Drop Database) ```sql DROP DATABASE dbname; ``` 这条命令用于删除指定名称的数据库。请注意,在执行此操作前确保已经备份好所有重要的数据,因为删除操作是不可逆的。 ### 3. SQL Server备份设备管理 - **添加备份设备**: ```sql USE master; EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'; ``` 这行命令用于向`master`数据库添加一个名为`testBack`的备份设备,并指定了其存储路径。 - **执行备份**: ```sql BACKUP DATABASE pubs TO testBack; ``` 该命令用于备份名为`pubs`的数据库到前面定义的`testBack`备份设备中。 ### 4. 创建表 (Create Table) ```sql CREATE TABLE tabname (col1 type1 [NOT NULL] [PRIMARY KEY], col2 type2 [NOT NULL], ...); ``` 这条命令用于创建一个新表`tabname`,其中`col1`、`col2`等为列名,`type1`、`type2`等为各自的数据类型。`NOT NULL`表示该列为必填项,`PRIMARY KEY`表示该列为表的主键。 #### 衍生操作 - **使用现有表结构创建新表**: ```sql CREATE TABLE tab_new LIKE tab_old; ``` 这行命令可以复制`tab_old`表的结构(不包括数据)来创建新表`tab_new`。 - **基于查询结果创建新表**: ```sql CREATE TABLE tab_new AS SELECT col1, col2 FROM tab_old DEFINITION ONLY; ``` 这行命令根据`tab_old`表中的`col1`和`col2`列创建新表`tab_new`,但不包含实际数据。 ### 5. 删除表 (Drop Table) ```sql DROP TABLE tabname; ``` 这条命令用于删除名为`tabname`的表。 ### 6. 修改表结构 (Alter Table) - **添加列**: ```sql ALTER TABLE tabname ADD COLUMN col type; ``` 这行命令用于在表`tabname`中添加一列`col`,并指定其数据类型`type`。 - **修改列**: ```sql ALTER TABLE tabname MODIFY COLUMN col new_type; ``` 这条命令用于更改`tabname`表中`col`列的数据类型为`new_type`。 - **删除列**: ```sql ALTER TABLE tabname DROP COLUMN col; ``` 这条命令用于从表`tabname`中删除列`col`。 ### 7. 添加/删除主键 - **添加主键**: ```sql ALTER TABLE tabname ADD PRIMARY KEY (col); ``` 这行命令用于在表`tabname`中添加主键,主键列名为`col`。 - **删除主键**: ```sql ALTER TABLE tabname DROP PRIMARY KEY (col); ``` 这条命令用于从表`tabname`中删除指定为主键的列`col`。 ### 8. 索引管理 - **创建索引**: ```sql CREATE [UNIQUE] INDEX idxname ON tabname (col); ``` 这行命令用于在表`tabname`上创建名为`idxname`的索引,索引列名为`col`。`UNIQUE`关键字可选,用于创建唯一性索引。 - **删除索引**: ```sql DROP INDEX idxname; ``` 这条命令用于删除名为`idxname`的索引。 ### 9. 视图管理 - **创建视图**: ```sql CREATE VIEW viewname AS SELECT statement; ``` 这行命令用于根据`SELECT`语句创建名为`viewname`的视图。 - **删除视图**: ```sql DROP VIEW viewname; ``` 这条命令用于删除名为`viewname`的视图。 ### 10. 基本SQL操作 - **查询数据**: ```sql SELECT * FROM table1 WHERE condition; ``` 这行命令用于从`table1`表中查询满足条件`condition`的所有记录。 - **插入数据**: ```sql INSERT INTO table1 (field1, field2) VALUES (value1, value2); ``` 这条命令用于向`table1`表中插入一条新记录,字段`field1`和`field2`的值分别为`value1`和`value2`。 - **删除数据**: ```sql DELETE FROM table1 WHERE condition; ``` 这条命令用于从`table1`表中删除满足条件`condition`的所有记录。 - **更新数据**: ```sql UPDATE table1 SET field1 = value1 WHERE condition; ``` 这条命令用于更新`table1`表中满足条件`condition`的记录,将字段`field1`的值设置为`value1`。 - **高级查询** - **模糊查询**: ```sql SELECT * FROM table1 WHERE field1 LIKE '%value1%'; ``` - **排序查询**: ```sql SELECT * FROM table1 ORDER BY field1, field2 [DESC]; ``` - **统计查询**: ```sql 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. 集合操作 - **UNION**: ```sql (SELECT col1, col2 FROM table1) UNION (SELECT col1, col2 FROM table2); ``` 这行命令用于从`table1`和`table2`表中选择相同的列,然后返回所有唯一的记录。 - **UNION ALL**: ```sql (SELECT col1, col2 FROM table1) UNION ALL (SELECT col1, col2 FROM table2); ``` 这条命令与`UNION`类似,但会保留重复记录。 - **EXCEPT**: ```sql (SELECT col1, col2 FROM table1) EXCEPT (SELECT col1, col2 FROM table2); ``` 这行命令用于返回在`table1`中存在而在`table2`中不存在的记录。 - **EXCEPT ALL**: ```sql (SELECT col1, col2 FROM table1) EXCEPT ALL (SELECT col1, col2 FROM table2); ``` 这条命令与`EXCEPT`类似,但会保留`table1`中的重复记录。 - **INTERSECT**: ```sql (SELECT col1, col2 FROM table1) INTERSECT (SELECT col1, col2 FROM table2); ``` 这行命令用于返回在`table1`和`table2`中都存在的记录。 - **INTERSECT ALL**: ```sql (SELECT col1, col2 FROM table1) INTERSECT ALL (SELECT col1, col2 FROM table2); ``` 这条命令与`INTERSECT`类似,但会保留重复记录。 ### 12. 连接操作 - **LEFT OUTER JOIN**: ```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; ``` 这条命令用于从`a`表中选择所有记录,以及`b`表中与`a`表匹配的记录。如果`b`表中没有匹配,则显示NULL。 - **RIGHT OUTER JOIN**: ```sql SELECT a.a, a.b, a.c, b.c, b.d, b.f FROM a RIGHT OUTER JOIN b ON a.a = b.c; ``` 这条命令与`LEFT OUTER JOIN`相反,它从`b`表中选择所有记录,以及`a`表中与`b`表匹配的记录。 - **FULL OUTER JOIN**: ```sql SELECT a.a, a.b, a.c, b.c, b.d, b.f FROM a FULL OUTER JOIN b ON a.a = b.c; ``` 这条命令用于从两个表中选择所有记录,无论是否有匹配,如果没有匹配则显示NULL。 ### 13. 其他操作 - **跨库操作**: ```sql -- 插入数据 INSERT INTO b (a, b, c) SELECT d, e, f FROM b IN DATABASE_NAME WHERE ...; -- 查询数据 SELECT ... FROM b IN DATABASE_NAME WHERE ...; ``` 这些命令用于在不同的数据库之间进行数据操作。 - **子查询**: ```sql SELECT * FROM a WHERE a IN (SELECT d FROM b); ``` 这条命令用于从表`a`中选择满足子查询结果的记录。 - **分组查询**: ```sql SELECT a.title, a.username, b.addDate FROM tablea, (SELECT MAX(addDate) addDate FROM table WHERE table.title = a.title) b; ``` 这条命令用于从`tablea`表中选择数据,并根据`title`对`table`表中的数据进行分组。 以上就是从给定文件中整理出来的SQL中最精妙且常用的基本操作命令及其详细解释。这些知识点涵盖了SQL Server中最基础但也非常重要的操作,对于初学者来说是不可或缺的学习资源。
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….)
移除索引:drop index idxname
注:索引是不可更改的,想更改必须移除重新增。
9、说明:新增视图:create view viewname as select statement
移除视图:drop view viewname
10、说明:几个简单的基本的sql语句
插入: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:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full outer join:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
二、提升
剩余9页未读,继续阅读
- 粉丝: 0
- 资源: 2
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助