SQLServer 学习笔记之超详细基础SQL语句 Part 9
Sqlserver 学习笔记
-----------------------接Part 8-------------------
3
范式的概念
第一范式的目标是确保每列的原子性。
如果每列都是不可再分的最小单元(也称为最小的原子单位。),则满足第一范式(1NF)
第二范式要求每个表只描述一件事情。
如果一个关系满足1NF,并且除了主键以外的其它列,都依赖该主键,则满足第二范式。(2NF)
第三范式
如果一个关系满足2NF,并且除了主键以外的其它列都不传递依赖于主键,则满足第三范式(3NF)。
第一范式(1NF)的目标:确保每列的原子性。
第二范式(2NF)的目标:确保表中的每列,都和主键相关,即不存在部分依赖
第三范式(3NF)的目标:确保每列都和主键列直接相关,而不是间接相关,即不存在传递函数依赖
4 T-SQL创建数据库的语法:
CREATE DATABASE
数据库名
ON [PRIMARY]
(
<</span>数据文件参数>
[,…n]
[<</span>文件组参数>]
)
[LOG ON]
(
<</span>日志文件参数>
[,…n]
)
示例
--创建学生数据库:一个数据文件,一个日志文件
CREATE
DATABASE studentDB
ON
PRIMARY--默认就是属于PRIMARY主文件,可以省略
(
NAME='stdDB_data',--主数据文件的逻辑名
FILENAME='E:\SQL\stuDB.mdf',--主数据文件的物理名
SIZE=3mb,--主数据文件的初始大小
MAXSIZE=10mb,--主数据文件的增长的最大值
FILEGROWTH=10%--主数据文件的增长率
)
LOG
ON
(
NAME='stuDB_log',
FILENAME='E:\SQL\stuDB_log.ldf',
SIZE=3mb,
MAXSIZE=10mb,
FILEGROWTH=1mb
)
GO
注意:这里的两个name参数不能一样的逻辑名,否则会提示逻辑文件名xxx已被使用,请选择另一个名称
--创建学生数据库:多个数据文件,多个日志文件
CREATE
DATABASE employeeDB
ON
PRIMARY--默认就是属于PRIMARY主文件,可以省略
(
NAME='employee1_data',--主数据文件的逻辑名
FILENAME='E:\SQL\employee1.mdf',--主数据文件的物理名
SIZE=3mb,--主数据文件的初始大小
MAXSIZE=10mb,--主数据文件的增长的最大值
FILEGROWTH=10%--主数据文件的增长率
),
(
NAME='employee2_data',--主数据文件的逻辑名
FILENAME='E:\SQL\employee2.mdf',--主数据文件的物理名
SIZE=3mb,--主数据文件的初始大小
MAXSIZE=10mb,--主数据文件的增长的最大值
FILEGROWTH=10%--主数据文件的增长率
)
LOG
ON
(
NAME='employee1_log',
FILENAME='E:\SQL\employee1_log.ldf',
SIZE=3mb,
MAXSIZE=10mb,
FILEGROWTH=1mb
),
(
NAME='employee2_log',
FILENAME='E:\SQL\employee2_log.ldf',
SIZE=3mb,
MAXSIZE=10mb,
FILEGROWTH=1mb
)
GO
USE
master --设置当前数据库为master,以便访问sysdatabase表
GO
IF
EXISTS(SELECT *
FROM sysdatabases WHERE name='stuDB')
DROP DATABASE stuDB
CREATE
DATABASE stuDB
ON
PRIMARY
(
NAME='stdDB2_data',--主数据文件的逻辑名
FILENAME='E:\SQL\stuDB2.mdf',--主数据文件的物理名
SIZE=3mb,--主数据文件的初始大小
MAXSIZE=10mb,--主数据文件的增长的最大值
FILEGROWTH=10%--主数据文件的增长率
)
LOG
ON
(
NAME='stuDB_log',
FILENAME='E:\SQL\stuDB2_log.ldf',
SIZE=3mb,
MAXSIZE=10mb,
FILEGROWTH=1mb
)
GO
说明:EXISTS()语句:检测是否存在stuDB数据库如果存在stuDB数据库,则删除
--创建表
USE
stuDB--将当前数据库设置为stuDB
GO
CREATE
TABLE stuInfo
(
stuName VARCHAR(20)
NOT NULL, --姓名,非空(必填)
stuNo CHAR(6)
NOT NULL, --学号,非空(必填)
stuID NUMERIC(18,0),
stuSeat SMALLINT IDENTITY(1,1),
--座位号,自动编号
stuAddress TEXT --住址,允许为空,即可选输入
)
GO
说明:NUMERIC
(18,0)
代表18位数字,小数位数为0
IDENTITY(起始值,递增量)
5
约束
目的:确保表中数据的完整型
常用的约束类型:
1)
主键约束(Primary Key
Constraint):要求主键列数据唯一,并且不允许为空
2)
唯一约束(Unique
Constraint):要求该列唯一,允许为空,但只能出现一个空值。
3)
检查约束(Check
Constraint):某列取值范围限制、格式限制等,如有关年龄的约束
4)
默认约束(Default
Constraint):某列的默认值,如我们的男性学员较多,性别默认为“男”
5)
外键约束(Foreign Key
Constraint):用于两表间建立关系,需要指定引用主表的那列
添加约束的语法:
ALTER TABLE
表名
ADD CONSTRAINT
约束名
约束类型
具体的约束说明
其中,约束名的取名规则推荐采用:约束类型_约束字段
a)
主键(Primary
Key)约束:如
PK_stuNo
b)
唯一(Unique
Key)约束:如
UQ_stuID
c)
默认(Default
Key)约束:如
DF_stuAddress
d)
检查(Check
Key)约束:如
CK_stuAge
e)
外键(Foreign
Key)约束:如
FK_stuNo
示例
--给stuInfo表添加约束
ALTER
TABLE stuInfo
ADD
CONSTRAINT PK_stuNo PRIMARY KEY
(stuNo)
ALTER
TABLE stuInfo
ADD
CONSTRAINT UQ_stuID UNIQUE(stuID)
ALTER
TABLE stuInfo
ADD
CONSTRAINT DF_stuAddress
DEFAULT
('地址不详')
FOR stuAddress
ALTER
TABLE stuInfo
ADD
CONSTRAINT CK_stuAge
CHECK(stuNo
BETWEEN 1 AND 60)
ALTER
TABLE stuInfo
ADD
CONSTRAINT FK_stuNo
FOREIGN
KEY(stuNo)
REFERENCES stuInfo(stuNo)
GO
SQLServer 学习笔记之超详细基础SQL语句 Part 9的更多相关文章
- SQLServer 学习笔记之超详细基础SQL语句 Part 3
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 2------------------- 13. 使用compute对查 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 12(The End)
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 11------------------- 现在,我们希望从 " ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 11
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 10------------------- DECLARE @myavg ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 10
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 9------------------- 删除约束的语法 ALTER T ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 8
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 7------------------- --触发器str_trigge ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 7
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 6------------------- 29 存储过程和触发器 存储过 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 6
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 5------------------- 28 聚合函数 --求平均分 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 5
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 4------------------- 21使用默认 默认(也称默认值 ...
- SQLServer 学习笔记之超详细基础SQL语句 Part 4
Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 3------------------- 17 带比较运算符的嵌套查询 ...
随机推荐
- android自定义控件 几种方式总结
方式1:不继承任何组件 , 直接在代码里面调用实例化.public class ProgressDialog { private Dialog dialog; public ProgressDialo ...
- python使用(三)
1.function_option.py2.function_code_option.py3.thread_option.py4.class_option.py5.threading_option.p ...
- ubuntu图形化配置
安装图形界面 apt-get install ubuntu-desktop 配置用户目录 udo useradd -s /bin/bash -d /home/wykeinstein -m wykein ...
- 全网最详细的大数据集群环境下多个不同版本的Cloudera Hue之间的界面对比(图文详解)
不多说,直接上干货! 为什么要写这么一篇博文呢? 是因为啊,对于Hue不同版本之间,其实,差异还是相对来说有点大的,具体,大家在使用的时候亲身体会就知道了,比如一些提示和界面. 安装Hue后的一些功能 ...
- 全网最详细的HBase启动以后,HMaster进程启动了,几秒钟以后自动关闭问题的解决办法(图文详解)
不多说,直接上干货! 问题详情 情况描述如题所示,hbase启动以后,HMaster进程启动了,几秒钟以后自动关闭,但是HRegionServer进程正常运行: 解决办法: 1.检查下每台机器的时间是 ...
- Linux宝塔软件安装
yum install -y wget && wget -O install.sh http://download.bt.cn/install/install.sh && ...
- Docker快速入门(一)
Docker是Go语言开发实现的容器.2013年发布至今,备受推崇.相关文档.学习资料十分详尽.近期公司docker项目要推进,得重新学习一下.博客以笔记. 1 容器诞生背景及优势 (1)软件开发和运 ...
- 软件架构设计学习总结(3):QQ空间技术架构之详解
QQ空间作为腾讯海量互联网服务产品,经过近七年的发展,实现了从十万级到亿级同时在线的飞跃.在这个过程中,QQ空间团队遇到了哪些技术挑战?其站点前后台架构随着业务规模的变化又进行了怎样的演进与变迁?成长 ...
- Java 集合并交补
示例 package com.example; import java.util.ArrayList; import java.util.Arrays; import java.util.Collec ...
- 第一次项目上Linux服务器(六:Nginx安装及相关命令(转))
1.下载nginx 方法一 wget http://nginx.org/download/nginx-1.11.6.tar.gz 方法二 http://nginx.org/en/download.ht ...