Sqlserver 学习笔记

by:授客 QQ1033553122

-----------------------接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的更多相关文章

  1. SQLServer 学习笔记之超详细基础SQL语句 Part 3

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 2------------------- 13. 使用compute对查 ...

  2. SQLServer 学习笔记之超详细基础SQL语句 Part 12(The End)

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 11------------------- 现在,我们希望从 " ...

  3. SQLServer 学习笔记之超详细基础SQL语句 Part 11

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 10------------------- DECLARE @myavg ...

  4. SQLServer 学习笔记之超详细基础SQL语句 Part 10

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 9------------------- 删除约束的语法 ALTER T ...

  5. SQLServer 学习笔记之超详细基础SQL语句 Part 8

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 7------------------- --触发器str_trigge ...

  6. SQLServer 学习笔记之超详细基础SQL语句 Part 7

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 6------------------- 29 存储过程和触发器 存储过 ...

  7. SQLServer 学习笔记之超详细基础SQL语句 Part 6

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 5------------------- 28 聚合函数 --求平均分 ...

  8. SQLServer 学习笔记之超详细基础SQL语句 Part 5

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 4------------------- 21使用默认 默认(也称默认值 ...

  9. SQLServer 学习笔记之超详细基础SQL语句 Part 4

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 3------------------- 17 带比较运算符的嵌套查询 ...

随机推荐

  1. 02-01 Java关键字、标识符、注释、常量和进制问题、变量和数据类型

    1:关键字 (1)被Java语言赋予特定含义的单词 (2)特点: 全部小写. (3)注意事项: A:goto和const作为保留字存在. B:类似于Notepad++这样的高级记事本会对关键字有特殊颜 ...

  2. Python 模块 和 包

    模块 os模块 路径拼接 os.path.join

  3. 剑指offer十五之反转链表

    一.题目 输入一个链表,反转链表后,输出链表的所有元素. 二.思路 详细分析见代码注释 三.代码 public class Solution {     public ListNode Reverse ...

  4. Android _关于fragment切换重新加载的解决分享给大家

    在项目中需要进行Fragment的切换,一直都是用replace()方法来替换Fragment但是,这样会有一个问题 ,应该很多朋友都遇到过:每次切换的时候,Fragment都会重新实例化,也就是运行 ...

  5. vue实现短信验证码登录

    无论是移动端还是pc端登录或者注册界面都会见到手机验证码登录这个功能,输入手机号,得到验证码,最后先服务器发送请求,保存登录的信息,一个必不可少的功能 思路 1,先判断手机号和验证是否为空, 2,点击 ...

  6. Linux信号和trap命令的使用

    目录 信号介绍 信号列表 控制信号 Ctrl+c显示指定内容 使Ctrl+c无任何操作 处理多个信号 处理所有信号 恢复信号 实现跳板机(实例) 信号介绍 运行Shell脚本时,如果按下快捷键Ctrl ...

  7. 异常处理:net.sf.cglib.beans.BulkBeanException

    今天下午由于各种开会,断断续续写得代码,单元测试的时候,老是报如题的错误,后来查阅资料,发现原来是从数据库查询的值如果为空,则对应实体类执行set方法会赋值null给对应属性值,但是我当时的几个值偏偏 ...

  8. Maven3路程(一)环境搭建

    好长时间不用Java,今天看了下,Maven集成成主流了,在技术水平与日俱进的同时,感叹下IT行业必须有活到老学到老的精神. 先说下环境: Maven:Maven 3.0.5 解压后路径:F:\Mav ...

  9. http缓存详解,http缓存推荐方案

    前言 通过本文,你将了解到http缓存机制是怎样的,no-cache到底有没有缓存,地址栏回车,F5,ctrl+F5的区别,以及当下较为推荐的缓存方案等. 自从和前端组的同事一起整了个前端扫盲计划,想 ...

  10. springboot redis 缓存跨域丢失问题

    对于前后端分离的项目,在开发阶段经常会遇到跨域的问题. 1.首先,对于后台的处理方式,第一种是用 @CrossOrigin 注解,@crossorigin是后端SpringMVC框架(需4.2版本以上 ...