内容摘要

创建带主键和约束的表

创建带组合主键和外键的表

1. 创建带主键和约束的表

  • Student (学生表)

  • CREATE TABLE Student
    (
    sclass varchar() NOT NULL, --- 限制非空
    snumb varchar() PRIMARY KEY, --- 设置为主键
    sname varchar() NOT NULL, --- (下)设置默认值男,约束选项为男女
    sgender varchar() DEFAULT '男' CONSTRAINT consgender CHECK (sgender IN('男', '女')),
    sbirthday date,
    sage int CONSTRAINT consage CHECK (sage >= and sage <= )
    )
    CONSTRAINT 约束名 CHECK (条件)
  • SELECT INTO Student VALUES('电气51', '', '王涛', '男', '1993-2-1', )
    INSERT INTO Student(sclass, snumb, sname)
    VALUES('电气51', '', '王涛') ---> 产生默认性别男
    SELECT * FROM Student
    INSERT INTO Student(sclass, snumb)
    VALUES('电气51', '') ---- 出现错误: 不能将值 NULL 插入列 'sname'

    以上为,加了约束之后的效果

  • Course (课程)

CREATE TABLE Course
(
cnumb varchar() PRIMARY KEY, --- 设为主键
cname varchar() NOT NULL, --- 非空
chours int CONSTRAINT conshour CHECK(chours >= and chours <= ),
credit decimal(,) CONSTRAINT conscredit CHECK(credit >= and credit < ),
intro text --- text字段存放一段文字
)
INSERT INTO Course
VALUES('ENP09001', '理论力学', , , '研究物体机械运动的基本规律') SELECT * FROM Course

2. 创建带组合约束和外键的表

  • study (选课表)

CREATE TABLE Study
(
snumb varchar(),
cnumb varchar(),
score decimal(,),
PRIMARY KEY (snumb, cnumb), ---- 设为组合主键
FOREIGN KEY (snumb) REFERENCES Student(snumb), ---- (参照完整性)声明是什么表中的外键(即:插入数据时,必须要在Student和Course存在才可以)
FOREIGN KEY (cnumb) REFERENCES Course (cnumb)
)
INSERT INTO Study
VALUES('', 'ENP09001', ) --- snumb和cnumb必须要在Student和Course存在才可以 SELECT * FROM Student
SELECT * FROM Course
SELECT * FROM Study

3.总结:

//添加内容

四类数据完整性: 

     实体完整性,确保不出现完全相同的数据记录
区域完整性, 通过限制数据类型,检查约束,输入格式,外键约束,默认值,非空等体现
参考完整性,避免因一个数据表的记录改变而造成相关数据表内的数据变成无效值。
用户自定义完整性,用户自定义由用户根据实际应用中的需要自行定义。

SQL语句(二)创建带主键和约束的数据表的更多相关文章

  1. SQL语句添加,删除主键

    IF EXISTS (SELECT * FROM sys.all_objects  WHERE  type_desc= N'主键名')begin --删除主键 alter table 表名 drop ...

  2. Sql Server中的游标最好只用于有主键或唯一键的表

    游标cursor,我想大多数人都在sql server里面用过.当一个表数据量不太大的时候,游标还是可以用的,毕竟游标是循环一个表中每一行数据的最简便办法.但是如果你用一个游标去循环一个没有主键或唯一 ...

  3. SQL Server学习之路(二):主键和外键

    0.目录 1.定义 1.1 什么是主键和外键 1.2 主键和外键的作用 1.3 主键.外键和索引的区别 2.主键(primary key) 2.1 通过SSMS设置主键 2.2 通过SQL语句设置主键 ...

  4. SQL语句删除和添加外键、主键的方法

    --删除外键 语法:alter table 表名 drop constraint 外键约束名 如: alter table Stu_PkFk_Sc drop constraint FK_s alter ...

  5. 【转】SQL语句删除和添加外键、主键

    --删除外键 语法:alter table 表名 drop constraint 外键约束名 如: alter table Stu_PkFk_Sc drop constraint FK_s alter ...

  6. mysql创建,添加主键

    primary key 1.最简单的: CREATE TABLE t1( id int not null, name char(20)); 2.带主键的: a:CREATE TABLE t1( id ...

  7. (转)Mybatis高级映射、动态SQL及获得自增主键

    原文:http://www.cnblogs.com/edwinchen/p/4105278.html?utm_source=tuicool&utm_medium=referral 一.动态SQ ...

  8. Oracle中SQL查询表字段基本信息、主键、外键(转)

    select utc.column_name, utc.data_type, utc.data_length, utc.data_precision, utc.data_Scale, utc.null ...

  9. SQLServer 自增主键创建, 指定自增主键列值插入数据,插入主键

    http://blog.csdn.net/zh2qiang/article/details/5323981 SQLServer 中含自增主键的表,通常不能直接指定ID值插入,可以采用以下方法插入. 1 ...

随机推荐

  1. 自己写的browse.bat与perl写的url_handler.pl的比较

    以前自己也写过Windows下自动打开多个浏览器测试某个URI,提高浏览器兼容性测试效率. 但是写的browse.bat文件还是最基础简陋的 @echo off if '%1'=='-c' ( sta ...

  2. UBB编辑器

    http://ckeditor.com/ 这是老大哥 http://kindeditor.org/ 这是新秀 http://htmleditor.in/firefox-html-editor.html ...

  3. Web接口测试-HttpClient

    要实现Web接口测试的自动化有许多方式,比如利用Jmeter.Loadrunner等测试工具都能够实现接口的自动化测试,我们也可以利用一些开源的框架来实现接口的自动化测试,比如我们现在要说的这个Htt ...

  4. From 简书 转帖一下如何安装k8s1.10 改天做下实验. https://www.jianshu.com/p/9c7e1c957752

    centos7.3 kubernetes/k8s 1.10 离线安装 老菜_misa 关注 2018.04.25 23:57 字数 1243 阅读 266评论 1喜欢 3 本文介绍在centos7.3 ...

  5. SQLSERVER 备份数据库的注意事项

    1. SQLSERVER 有一个压缩备份集的功能,能够实现大概15%的压缩比(跟数据类型不同而不同) 之前竟然没发现...浪费了好多磁盘资源.. 多学习多思考..

  6. SAP字体调节大小

    登陆SAP 之后,菜单下面一行,最右边的那个彩色按钮(SAP GUI),点击“选项”-可视设计-字体设计-固定狂赌字体设计,点击:选择字体 即可.

  7. mysql理论结合实际篇(一)

    最近两天做需求,是要将退款和退货报表里使用的临时表改用固定表, 自己建表时,如(只是举例): CREATE TABLE tasks ( task_id INT UNSIGNED NOT NULL AU ...

  8. python 判断变量有没有定义

    ? 1 2 'varname' in locals().keys() 'varname' in  dir()

  9. 使用TortoiseSVN创建版本库

    1. 使用TortoiseSVN创建版本库 在SVN中,为了便于创建分支和标签,我们习惯于将Repository版本库的结构布置为:/branches,/tags,/trunk.分别代表分支,标签以及 ...

  10. HNOI2018滚粗记

    day 0 最近发现机房的人都有些焦虑(除了一些神犇)自己也被影响地紧张起来 唉,不知道是不是一种好的心态,紧张是必然的... 随便打了点板子(\(FFT,SA,LCT\)) 很棒一个都没考 day ...