根据提供的文件信息,我们可以归纳总结出SQL Server中的关键知识点,主要涵盖了数据库的创建与管理、表的操作、视图与索引的使用以及查询语句等多个方面。以下是对这些知识点的详细解析: ### 1. 数据库的基本操作 #### 创建数据库 - **语法**:`CREATE DATABASE database-name` - 示例:`CREATE DATABASE MyDatabase` #### 删除数据库 - **语法**:`DROP DATABASE dbname` - 示例:`DROP DATABASE MyDatabase` ### 2. 备份数据库 #### 添加备份设备 - **语法**:`USE master; EXEC sp_addumpdevice 'disk', 'device_name', 'path'` - 示例:`USE master; EXEC sp_addumpdevice 'disk', 'testBack', 'c:\mssql7backup\MyNwind_1.dat'` #### 执行备份 - **语法**:`BACKUP DATABASE db_name TO device_name` - 示例:`BACKUP DATABASE pubs TO testBack` ### 3. 表的操作 #### 创建表 - **语法**: - `CREATE TABLE table_name (column1 datatype [NOT NULL][PRIMARY KEY], column2 datatype [NOT NULL], ...)` - 示例:`CREATE TABLE Employees (ID INT NOT NULL PRIMARY KEY, Name VARCHAR(50) NOT NULL)` - 通过另一个表的结构来创建新表:`CREATE TABLE new_table LIKE old_table` - 根据选择语句创建新表:`CREATE TABLE new_table AS SELECT column1, column2 FROM old_table DEFINITION ONLY` #### 删除表 - **语法**:`DROP TABLE table_name` - 示例:`DROP TABLE Employees` #### 修改表 - **添加列**:`ALTER TABLE table_name ADD column_name datatype` - 示例:`ALTER TABLE Employees ADD Age INT` - **修改列**:在SQL Server中,可以修改列的数据类型或属性,但不能直接修改列名。 - **删除主键约束**:`ALTER TABLE table_name DROP CONSTRAINT PK_column_name` - 示例:`ALTER TABLE Employees DROP CONSTRAINT PK_ID` #### 创建与删除索引 - **创建索引**:`CREATE [UNIQUE] INDEX index_name ON table_name (column_name)` - 示例:`CREATE UNIQUE INDEX IX_Employees_Name ON Employees (Name)` - **删除索引**:`DROP INDEX index_name ON table_name` - 示例:`DROP INDEX IX_Employees_Name ON Employees` ### 4. 视图的创建与删除 #### 创建视图 - **语法**:`CREATE VIEW view_name AS SELECT statement` - 示例:`CREATE VIEW EmployeeView AS SELECT ID, Name FROM Employees` #### 删除视图 - **语法**:`DROP VIEW view_name` - 示例:`DROP VIEW EmployeeView` ### 5. 常用的SQL查询语句 #### 查询数据 - **基本查询**:`SELECT * FROM table_name WHERE condition` - 示例:`SELECT * FROM Employees WHERE Department = 'HR'` - **条件查询**:使用`WHERE`子句进行过滤 - **模糊查询**:使用`LIKE`操作符进行模糊匹配 - 示例:`SELECT * FROM Employees WHERE Name LIKE '%John%'` #### 插入数据 - **基本插入**:`INSERT INTO table_name (column1, column2) VALUES (value1, value2)` - 示例:`INSERT INTO Employees (ID, Name) VALUES (1, 'John Doe')` #### 更新数据 - **基本更新**:`UPDATE table_name SET column_name = value WHERE condition` - 示例:`UPDATE Employees SET Name = 'Jane Doe' WHERE ID = 1` #### 删除数据 - **基本删除**:`DELETE FROM table_name WHERE condition` - 示例:`DELETE FROM Employees WHERE ID = 1` #### 分组与聚合函数 - **分组**:使用`GROUP BY`子句对数据进行分组 - **聚合函数**:如`COUNT`, `SUM`, `AVG`, `MAX`, `MIN`等 - 示例:`SELECT COUNT(*) AS TotalEmployees FROM Employees GROUP BY Department` ### 6. 高级查询技巧 #### UNION - **基础用法**:`SELECT column_list FROM table1 UNION SELECT column_list FROM table2` - 示例:`SELECT Name FROM Employees UNION SELECT Name FROM Customers` - **UNION ALL**:包含所有结果,包括重复项 - **EXCEPT**:返回第一个查询结果集中不在第二个查询结果集中的行 - 示例:`SELECT Name FROM Employees EXCEPT SELECT Name FROM Customers` - **INTERSECT**:返回两个查询结果集中的公共行 - 示例:`SELECT Name FROM Employees INTERSECT SELECT Name FROM Customers` #### JOIN - **LEFT OUTER JOIN**:返回左表的所有行,即使右表中没有匹配的行 - 示例:`SELECT e.Name, o.OrderDate FROM Employees e LEFT OUTER JOIN Orders o ON e.ID = o.EmployeeID` - **RIGHT OUTER JOIN**:返回右表的所有行,即使左表中没有匹配的行 - **FULL OUTER JOIN**:返回左右表中所有行的组合 - 示例:`SELECT e.Name, o.OrderDate FROM Employees e FULL OUTER JOIN Orders o ON e.ID = o.EmployeeID` 以上是关于SQL Server简单操作的一些核心知识点,希望对你有所帮助。这些操作在实际数据库管理和开发中非常常见,熟练掌握它们能够大大提高工作效率。
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语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
- 粉丝: 3
- 资源: 1
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助