一文掌握MySQL表的创建和约束

目录
  • 一、数据库的建立和销毁
  • 二、表的建立和销毁
    • 1、表的建立
    • 2、表约束概念
    • 3、表约束具体使用
    • 4、表的销毁

一、数据库的建立和销毁

建立数据库:

create database [if not exists] 数据库名 [default charset 字符集]

tips: 中括号[]里面的内容可以省略不写

加上if not exists的含义是:如果不存在此数据库就会创建

default charset 字符集是创建数据库的时候设置字符集

销毁数据库:

drop database [if exists] 数据库名

tips: 可省略部分的含义同上

二、表的建立和销毁

1、表的建立

语法:

create table [if not exists] 表名(
    字段名  数据类型  [约束],
    字段名  数据类型  [约束],
    ...(最后一个字段不能加逗号)
)

1.1、命名规则

表名通常以t_开头

关键字段通常以表名缩写_开头

MySQL不区分大小写,不能使用关键字命名,多个部分之间用下划线连接

1.2、数据类型

需要掌握的数据类型:

1.整数:int、integer、bigint

2.小数:decimal

3.字符串:varchar

4.枚举:enum

5.日期:datatime

使用建议:

当字段数字一定大于0并且不会进行减运算时可以使用无符号数unsigned,通常不建议

float和double存在精度问题,后续mysql将不再支持

char和verchar在保存多个字符时底层实现是一致的,只是占用空间的模式不同,不建议使用char,因为有可能浪费空间

timestamp上限太低,date和time不实用,所以日期建议使用datetime

2、表约束概念

2.1、约束预览

约束 解释 说明
primary key 主键 用来标志一列为主键列
not null 非空 约束该列值不允许为空
unique 唯一 约束该列值不允许重复
default 默认 给该列设置默认值
foreign key 外键 标志一列为外键值
check 检查约束 MySQL不支持

2.2、特点及作用

主键

作用:可以作为唯一标识具体锁定某行数据

特点:非空且唯一

一张表至多有一个主键列

非空

特点:值不能为null,必须设定

唯一

特点:值可以为null,并且可以存在多个null,该约束只对已经存在的值有效

非空约束+唯一约束 不等同于 主键约束

默认

特点:如果该列未显式赋值,则使用默认值存放

语法: default(值)

外键的使用放在下面具体讲解

3、表约束具体使用

3.1、列级约束

直接将约束定义到在列的声明里

使用示例:

-- id、姓名、年龄、性别、身高、生日
create table if not exists t_person(
        p_id int primary key,-- 主键
        p_name varchar(50) unique not null,-- 唯一+非空
        age tinyint unsigned not null,-- 非空 无符号数  0-255
        sex enum('男','女','奥特曼') default '奥特曼',-- 默认
        height decimal(4,1), -- 总共有4位,小数点占1位:000.0
        birthday datetime
)

3.2、表级约束

将约束单独定义在所有列的下方,not null和default没有表级约束

语法:[constraint 自定义约束名] 约束类型(字段名)

使用示例:

create table if not exists t_person(
        p_id int,-- 主键
        p_name varchar(50) not null,-- 唯一+非空
        age tinyint unsigned not null,-- 非空 无符号数  0-255
        sex enum('男','女','奥特曼') default '奥特曼',-- 默认
        height decimal(4,1), -- 总共有4位,小数点占1位:000.0
        birthday datetime,
        -- 表级约束
        primary key(p_id),-- 给p_id添加主键约束
        constraint un_name unique(p_name)-- 给p_name添加唯一约束
)

3.3、外键约束

作用:用来表示两张表之间的联系,必须结合另一张表使用

特点:

  • 连接的必须是另一张表的主键或者唯一列
  • 外键列的值不可自定义,必须来自另一张表与之关联的列中已经存在的值
  • 值可以为null,不唯一
  • 必须用表级约束创建

语法:

foreign key(字段名) references 其他表名(其他表的连接字段名)

使用:

  • 建表顺序:先建没有外键的表,再建有外键的表
  • 删表顺序:先删有外键的,再删没外键的
  • 外键列的数据类型必须与所连接的列一致

使用示例:

-- 班级表:id,班级名
create table t_class(
    c_id  int PRIMARY KEY,
    c_name varchar(20) not null
)
-- 学生表:id,姓名,所属班级id
create table t_student(
    s_id int PRIMARY KEY,
    s_name varchar(20) not null,
    c_id int not null ,
    -- 表级约束
    FOREIGN KEY(c_id) REFERENCES t_class(c_id)
)

4、表的销毁

语法:

drop table [if exists] 表名

注意事项:

在3.3外键约束具体使用中对于有外键的表,要先删除有外键的表,再删除没有外键的表

drop table t_student – 先删学生表

drop table t_class – 才能删班级表

到此这篇关于一文掌握MySQL表的创建和约束的文章就介绍到这了,更多相关MySQL表 创建 约束内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MySQL创建表操作命令分享

    目录 一.表命令 1.查看所有表 2.创建表 3.创建一个用户表 二.MySQL支持的常用数据类型 1.数字型 2.字符串 3.日期 三.MySQL支持的常用约束 四.存储引擎 五.表命令(crud) 1.查看表结构 2.查看表的创建语句 3.更改表名称 4.修改表 5.删除表 六.更新约束 1.先创建一个表,除了主键,不加其他约束. 2.给手机号添加唯一约束 3.删除唯一约束 4.给名字添加非空约束 5.删除非空约束 6.给生日添加默认约束 7.删除默认约束 一.表命令 1.查看所有表 sho

  • MySQL约束(创建表时的各种条件说明)

    目录 约束 1. not null(非空约束) 2. unique(唯一性约束) 3. primary key (主键约束) 4. foreign key(外键约束) 5. 级联更新与级联删除 由于增删改了emp表中的记录,因此这里重新创建了一个脚本并使用 create database bjpowernnode; use bjpowernode; source C:\Users\Administrator\Desktop\bjpowernode.sql; 约束 1.什么是约束? 约束就是表中的

  • MySQL数据库表约束讲解

    目录 MySQL数据库表约束 一.主键约束 二.外键约束 三.非空约束 四.唯一约束 五.默认约束 六.自增约束 数据库建表的约束条件 常用约束条件及简单介绍 MySQL数据库表约束 为了防止往数据表中插入错误的数据,在MySQL中,定义了一些维护数据库完整性的规则,即表的约束. 常见的表的约束: 上表中列举的约束条件都是针对表中字段进行限制, 从而保证数据表中数据的正确性和唯一性. 一.主键约束 在MySQL中,为了快速查找表中的某条信息,可以通过设置主键来实现.主键约束是通过PRIMARY

  • mysql数据库入门第一步之创建表

    创建数据库 右键-新建数据库 输入库名.选择字符集和排序规则,点确定 创建数据库成功 新建表 my-表-右键-新建表 如上图所示,在第一个标签页"栏位"中 名:字段的名字 类型:字段的类型,有几十种,常用的有以下几种 char,可以存定长的字符串 varchar,可以存变长的字符串(定长和变长的区别在长度中介绍) int,可以存-2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 之间的数字 datetime,可以存日期类型的数据 长度:数

  • MySQL 创建三张关系表实操

    目录 1.创建学生表 2.创建科目表 3.创建分数表 4.插入数据 5.查询全部分数 6.查询学生的平均分 7.总分排行榜 1.创建学生表 create table tbl_stu ( id int not null primary key auto_increment, name varchar(45) not null )engine=innodb default charset=utf8; 2.创建科目表 create table tbl_sub ( id int not null pri

  • 一文掌握MySQL表的创建和约束

    目录 一.数据库的建立和销毁 二.表的建立和销毁 1.表的建立 2.表约束概念 3.表约束具体使用 4.表的销毁 一.数据库的建立和销毁 建立数据库: create database [if not exists] 数据库名 [default charset 字符集] tips: 中括号[]里面的内容可以省略不写 加上if not exists的含义是:如果不存在此数据库就会创建 default charset 字符集是创建数据库的时候设置字符集 销毁数据库: drop database [if

  • 创建mysql表分区的方法

    表分区是最近才知道的哦 ,以前自己做都是分表来实现上亿级别的数据了,下面我来给大家介绍一下mysql表分区创建与使用吧,希望对各位同学会有所帮助.表分区的测试使用,主要内容来自于其他博客文章以及mysql5.1的参考手册mysql测试版本:mysql5.5.28mysql物理存储文件(有mysql配置的datadir决定存储路径)格式简介数据库engine为MYISAM frm表结构文件,myd表数据文件,myi表索引文件.INNODB engine对应的表物理存储文件innodb的数据库的物理

  • MySQL中外键的创建、约束以及删除

    前言 在MySQL 3.23.44版本后,InnoDB引擎类型的表支持了外键约束. 外键的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支持,但至少目前不支持): 2.外键列必须建立了索引,MySQL 4.1.2以后的版本在建立外键时会自动创建索引,但如果在较早的版本则需要显示建立: 3.外键关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以: 外键的好处:可以使得两张表关联,

  • 一文读懂MySQL 表分区

    目录 1. 什么是表分区 2. 分区的两种方式 2.1 水平切分 2.2 垂直切分 3. 为什么需要表分区 4. 分区实践 4.1 RANGE 分区 4.2 LIST 分区 4.3 HASH 分区 4.4 KEY 分区 4.5 COLUMNS 分区 5. 常见分区命令 6. 小结 松哥之前写过文章跟大家介绍过用 MyCat 实现 MySQL 的分库分表,不知道有没有小伙伴研究过,MySQL 其实也自带了分区功能,我们可以创建一个带有分区的表,而且不需要借助任何外部工具,今天我们就一起来看看. 1

  • 一文理解MySQL数据库的约束与表的设计

    目录 1.数据库约束 1.1 约束类型 1.2 null 约束 1.3 unique 唯一的约束 1.4 default 默认值约束 1.5 primary key 主键约束 1.6 primary key auto_increment 自增主键 1.7 foreign key 外键约束 2.表的设计 2.1 一对一 2.2 一对多 2.3 多对多 总结 1.数据库约束 约束是关系型数据库提供的一种校验数据合法性的机制. 1.1 约束类型 约束类型 说明 示例 null 使用not null 指

  • MySQL Cluster如何创建磁盘表方法解读

    一.概念 MySQL Cluster采用一系列的Disk Data objects来实现磁盘表. Tablespaces:作用是作为其他Disk Data objects的容器. Undo log files:存储事务进行回滚需要的信息,一个或者多个undo log files组成一个log files group,最后,该log file group关联到一个tablespaces. Data files:作用是存储表中的数据,data file直接关联到tablespaces. 在每一个数据

  • MySQL入门教程(五)之表的创建、修改和删除

    MySQL 为关系型数据库(Relational Database Management System), 这种所谓的"关系型"可以理解为"表格"的概念, 一个关系型数据库由一个或数个表格组成. 表是DB存储数据的基本单位,一个表包含若干个字段或记录.表的操作包括创建.修改和删除. 1.创建表 创建表即在已存在的数据库中创立新表.在使用USE语句选择具体数据库后,可以使用它SQL语句创建表 其中,属性名指表中字段的名称,数据类型即对应字段的数据类型,完整性约束条件指

  • python3.6连接MySQL和表的创建与删除实例代码

    python3.6不支持importMySQLdb改用为importpymysql模块,需要自行安装模块pymysql. 1:python3.6安装模块pymysql 命令行安装pipinstallpymysql 2:python3.6连接mysql数据库 #!/bin/env Python # -*- coding:utf-8 -*- import pymysql conn = pymysql.connect( user="root", password="root@123

  • MySQL在多表上创建视图方法

    MySQL中,在两个或者以上的基本表上创建视图 在student表和stu_info表上,创建stu_class视图,查询出s_id号.姓名和班级 首先,创建stu_info表,并向表中插入数据 查看表中的数据 创建stu_class视图 查看视图 可以看出,创建的视图包含id.name和class字段 其中,id字段对应student表中的s_id字段,name字段对应student表中的name字段,class字段对应stu_info表中的class字段

  • Mysql学习之创建和操作数据库及表DDL大全小白篇

    目录 1.操作数据库 1.1创建数据库 1.2查询数据库 1.3修改数据库 1.4删除数据库 1.5使用数据库 2.操作表 2.1MySQL数据类型 2.2创建表 2.3查询表 2.4删除表 2.5修改表 1.操作数据库 1.1创建数据库 create + database + 数据库名称 当然如果我们不知道数据库是否存在,如果存在就不创建,不存在就创建可以用以下语句 create + database + if not exists + 数据库名称 我们还可以在创建数据库的时候指定字符集 cr

随机推荐