sql server建库、表和约束
在SQL Server中,数据库是存储数据的容器,而表则是数据的结构化组织形式。约束则是确保表中数据完整性的一种规则。以下将详细介绍如何在SQL Server中创建数据库、表格以及添加约束。 我们来讨论如何创建数据库。在SQL Server中,我们可以使用`CREATE DATABASE`语句来创建一个新的数据库。例如,如果我们想要创建一个名为`MyDatabase`的数据库,我们可以执行以下SQL命令: ```sql CREATE DATABASE MyDatabase; ``` 创建完数据库后,我们需要在其中创建表。表是由列(字段)和行(记录)组成的,每个列都有特定的数据类型,如整数、字符串或日期等。创建表的`CREATE TABLE`语句通常如下所示: ```sql CREATE TABLE TableName ( Column1 datatype constraint, Column2 datatype constraint, Column3 datatype constraint, ... ); ``` 例如,创建一个名为`Employees`的表,包含`ID`(整数)、`Name`(字符串)和`HireDate`(日期)三个字段,我们可以写成: ```sql CREATE TABLE Employees ( ID INT PRIMARY KEY, Name VARCHAR(50) NOT NULL, HireDate DATE ); ``` 这里的`PRIMARY KEY`约束定义了`ID`为表的主键,确保每一行都有唯一标识。`NOT NULL`约束表示`Name`字段不允许为空值。 接下来,我们讨论各种类型的约束: 1. **主键约束(PRIMARY KEY)**:确保一列或一组列的值唯一,且不能为NULL。在上面的例子中,`ID`字段被设为主键。 2. **外键约束(FOREIGN KEY)**:用于建立两个表之间的关系,确保参照完整性的规则。例如,如果有一个`Departments`表,我们可以定义`Employees`表中的`DepartmentID`字段为外键: ```sql CREATE TABLE Departments ( DepartmentID INT PRIMARY KEY, DepartmentName VARCHAR(50) ); ALTER TABLE Employees ADD FOREIGN KEY (DepartmentID) REFERENCES Departments(DepartmentID); ``` 3. **唯一约束(UNIQUE)**:与主键类似,但不要求必须有值。例如,可以设置`Email`字段为唯一: ```sql CREATE TABLE Employees ( ID INT PRIMARY KEY, Name VARCHAR(50), Email VARCHAR(100) UNIQUE ); ``` 4. **非空约束(NOT NULL)**:不允许字段值为空。在创建`Employees`表时,`Name`字段就设置了`NOT NULL`约束。 5. **检查约束(CHECK)**:限制字段的值必须符合特定条件。例如,限制`Age`字段的值在18至65之间: ```sql CREATE TABLE Employees ( ID INT PRIMARY KEY, Name VARCHAR(50), Age INT CHECK (Age BETWEEN 18 AND 65) ); ``` 6. **默认约束(DEFAULT)**:如果没有提供值,字段将使用默认值。例如,`JoinDate`字段默认值为当前日期: ```sql CREATE TABLE Employees ( ID INT PRIMARY KEY, Name VARCHAR(50), JoinDate DATE DEFAULT GETDATE() ); ``` 通过熟练掌握这些SQL语句和约束,你可以有效地设计和管理SQL Server中的数据库结构,确保数据的准确性和一致性。这只是一个基础的介绍,SQL Server还有更高级的功能,如索引、视图、存储过程等,都是数据库管理和优化的重要工具。
- 1
- 粉丝: 1
- 资源: 3
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助