iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL创建表时的条件有哪些
  • 801
分享到

MySQL创建表时的条件有哪些

2023-07-02 11:07:52 801人浏览 独家记忆
摘要

这篇“MySQL创建表时的条件有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mysql创建表时的条件有哪些”文章吧。由

这篇“MySQL创建表时的条件有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mysql创建表时的条件有哪些”文章吧。

由于增删改了emp表中的记录,因此这里重新创建了一个脚本并使用

create database bjpowernnode;use bjpowernode;source C:\Users\Administrator\Desktop\bjpowernode.sql;

约束

1.什么是约束?

  • 约束就是表中的限制条件

  • 约束的关键字是:constraint

2. 约束的分类

  • 非空约束     not null

  • 唯一性约束   unique

  • 主键约束     primary key

  • 外键约束     foreign key

  • 检查约束     mysql数据库不支持,oracle数据库支持

1. not null(非空约束)

not null约束的字段,不能为null值,必须给具体的数据

创建表,给字段添加 非空约束【用户的邮箱地址不能为空】

drop table if exists t_user;create table t_user(        id int(10),        name varchar(32) not null,        email varchar (32));

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

2. unique(唯一性约束)

创建表,保证邮箱地址唯一

create table t_user(id int(10),name varchar(32) not null,email varchar(128) unique);

MySQL创建表时的条件有哪些

unique约束的字段不能重复,但是可以为null

MySQL创建表时的条件有哪些

以上的约束属于列级约束

表级约束:

 create table t_user(     id int(10),     name varchar(32),     email varchar(128),     unique(email) );

 1.使用表级约束给多个字段添加约束

 create table t_user(     id int(10),     name varchar(32),     email varchar(128),     unique(name,email));

表级约束可以给约束起名,以后通过这个名字来删除约束

   create table t_user(       id int(10),       name varchar(32),       email varchar(128),       constraint t_user_email_unique unique(email) );

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

not null 和unique可以联合使用

MySQL创建表时的条件有哪些

3. primary key (主键约束)

1.主键涉及到的术语:

  • 主键约束

  • 主键字段

  • 主键值

2.以上三者之间的关系:

  • 表中的某个字段添加主键约束之后,该字段称为主键字段

  • 主键字段中出现的每一个数据都被称为主键值

3.给某个字段添加主键约束以后,该字段不能重复,也不能为空

  • 主键约束效果和''not null unique'' 相同,但是本质不同,

  • 主键约束除了可以做到''not null unique''之外

  • 主键字段还会默认添加''索引-index''

4. 一张表应给有主键字段,如果没有,表示这张表是无效的

  • 主键值是当前行数据的唯一标识

  • 主键值是当前行数据的身份证号码

  • 即使表中的两行记录数据是完全相同的,

  • 但是由于主键值不同,就认为这是两行完全不同的字段

5.无论是单一主键还是复合主键,一张表的主键约束只能有一个

  • 给一个字段添加主键约束,被称为单一主键约束

  • 给多个字段联合添加主键约束,被称为复合主键

6.主键根据性质分类:

  • 自然主键:主键值是一个自然数,这个主键和当前的业务没有关系

  • 业务主键:主键值和当前业务紧密相关

  • 当业务发生改变的时候,主键值通成会受到影响,所以业务主键之用很少。

单一主键,列级约束

create table t_user(    id int(10) primary key,    name varchar(32));

MySQL创建表时的条件有哪些

单一主键,表极约束

 create table t_user(     id int(10),     name varchar(32),     primary key(id));

MySQL创建表时的条件有哪些

复合主键:只能用表级约束

mysql> create table t_user(    -> id int(10),    -> name varchar(32),    -> primary key(id,name)    -> );

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

auto_increment:主键自增

MySQL数据管理系统中提供了一个自增的数字,专门用来自动生成主键值

主键值不需要用户维护,也不需要用户提供了,自动生成的,

这个自增的数字默认从1开始以1递增:1,2,3,4,....

mysql> create table t_user(    -> id int(10) primary key auto_increment,    -> name varchar(32)    -> );

MySQL创建表时的条件有哪些

4. foreign key(外键约束)

1.外键约束涉及到的术语:

  • 外键约束

  • 外键值

  • 外键字段

2.以上三者之间的关系:

  • 某个字段添加外键约束以后称为外键字段

  • 外键字段中的每一个数据称为外键值

3.外键分为单一外键和复合外键

  • 单一外键:给一个字段添加外键约束

  • 复合外键:给多个字段添加外键约束

4.一张表中可以有多个外键字段

设计一个数据库表,用来存储学生和班级信息,给出两种解决方案:

学生信息和班级信息之间的关系:一个班级对应多个学生,这是典型的一对多的关系

在多的一方加外键

第一种设计方案:将学生信息和班级信息存储到一张表中

第二种设计方案:将学生信息和班级信息分开两张表存储,学生表+班级表

  • 学生表 t_student

sno(主键约束)snameclassno(外键约束)
1jack100
2lucy100
3kk100
4smith200
5frank300
6jhh300
  • 班级表t_calss

cno(主键约束)cname
100高三1班
200高三2班
300高三3班

为了保证t_student 表中的classno字段中的数据必须来自于t_class表中的cno字段中的数据,有必要给t_student表中的classno字段添加外键约束,classno称为外键字段,该字段中的值称为外键值。

注意:

外键值可以为空

外键字段必须得引用这张表中的主键吗?

  • 外键字段引用一张表的字段的时候,被引用的字段必须具备唯一性

  • 即具有unique约束,不一定非是主键

班级表为父表,学生表为子表

  • 应该先创建父表,再创建子表

  • 删除数据时,应该先删除子表中的数据,再删除父表中的数据

  • 插入数据时,应该先插入父表中的数据,再删除子表中的数据

MySQL创建表时的条件有哪些

DROP TABLE IF EXISTS t_student;DROP TABLE IF EXISTS t_class;  CREATE TABLE t_class( cno INT(3) PRIMARY KEY, cname VARCHAR(128) NOT NULL UNIQUE );  CREATE TABLE t_student( sno INT(3) PRIMARY KEY, sname VARCHAR(32) NOT NULL, classno INT(3),-- 外键 CONSTRAINT t_student_class_fk FOREIGN KEY(classno) REFERENCES t_class(cno) );  INSERT INTO t_class(cno,cname) VALUES(100,'高三1班'); INSERT INTO t_class(cno,cname) VALUES(200,'高三2班'); INSERT INTO t_class(cno,cname) VALUES(300,'高三3班');  INSERT INTO t_student(sno,sname,classno) VALUES(1,'jack',100); INSERT INTO t_student(sno,sname,classno) VALUES(2,'lucy',100); INSERT INTO t_student(sno,sname,classno) VALUES(3,'hh',100); INSERT INTO t_student(sno,sname,classno) VALUES(4,'frank',200);  INSERT INTO t_student(sno,sname,classno) VALUES(5,'smith',300); INSERT INTO t_student(sno,sname,classno) VALUES(6,'jhh',300);  SELECT * FROM t_student; SELECT * FROM t_class; -- 添加失败,因为有外键约束  INSERT INTO t_student(sno,sname,classno) VALUES(8,'kk',500);

重点:典型的一对多关系,设计时在多的一方加外键

5. 级联更新与级联删除

在删除父表中的数据的时候,级联删除子表中的数据

在更新父表中的数据的时候,级联更新子表中的数据

以上的级联更新和级联删除谨慎使用,

因为级联操作会使数据数据改变或删除,数据是无价的。

语法:

  • 级联更新:on update cascase

  • 级联删除:on delete cascase

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

MySQL中对于有些约束的修改比较麻烦,所以应该先删除约束,再添加约束

删除外键约束:

alter table t_student drop foreign key t_student_class_fk

添加外键约束并级联更新:

alter table t_student add constraint t_student_class_fk foreign key(classno)references t_class(no) on delete cascade;

添加外键约束并级联删除:

alter table t_student add constraint t_student_class_fk foreign key(classno)references t_class(no) on update cascade;

级联删除

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

级联更新

MySQL创建表时的条件有哪些

MySQL创建表时的条件有哪些

以上就是关于“MySQL创建表时的条件有哪些”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL创建表时的条件有哪些

本文链接: https://www.lsjlt.com/news/341570.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL创建表时的条件有哪些
    这篇“MySQL创建表时的条件有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“MySQL创建表时的条件有哪些”文章吧。由...
    99+
    2023-07-02
  • mysql创建临时表报错的原因有哪些
    创建临时表报错的原因可能有以下几种: 临时表已存在:如果同名的临时表已经存在于当前数据库中,尝试再次创建同名的临时表将会报错。 表...
    99+
    2024-04-09
    mysql
  • MySQL中创建表的方法有哪些
    在MySQL中创建表的方法有以下几种: 使用CREATE TABLE语句:利用CREATE TABLE语句可以直接在MySQL中创...
    99+
    2024-04-09
    MySQL
  • mysql创建表结构的命令有哪些
    答案:使用 create table 语句创建表结构。详细描述:create table 语句用于创建一个新表,其中包含列名、数据类型和约束条件。数据类型包括:数值类型、字符类型、日期和...
    99+
    2024-04-22
    mysql
  • MySQL创建临时表要注意哪些事项
    在MySQL中创建临时表时,需要注意以下事项: 临时表的命名必须以"#"开头,且只在当前会话中存在,会话结束后...
    99+
    2024-04-09
    MySQL
  • mysql创建一个表的基本步骤有哪些
    创建一个 mysql 表的基本步骤包括:连接到数据库并指定数据库名称。使用 create table 语句创建表,指定表名、列定义和主键。指定列定义,包括列名、数据类型和约束。指定主键,...
    99+
    2024-04-22
    mysql
  • mongodb创建表的方法有哪些
    在MongoDB中,不同于传统关系型数据库,MongoDB使用集合(Collection)来存储数据,而不是表。因此,并不需要像关系...
    99+
    2024-04-10
    mongodb
  • 创建jQuery插件的建议有哪些
    创建jQuery插件的建议有哪些,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。在开发过很多 jQuery 插件以后,我慢慢的摸索出了一套开...
    99+
    2024-04-02
  • mysql中死锁的条件有哪些
    这期内容当中小编将会给大家带来有关mysql中死锁的条件有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、四个条件互斥条件:一个资源每次只能被一个进程使用。请求与保持条件:一个进程因请求资源而阻塞时...
    99+
    2023-06-15
  • sqlite创建表格的方法有哪些
    在SQLite中,可以使用SQL语句来创建表格,常见的方法包括: 使用CREATE TABLE语句来创建表格,语法如下: CRE...
    99+
    2024-04-09
    sqlite
  • python创建列表的方法有哪些
    本篇内容主要讲解“python创建列表的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python创建列表的方法有哪些”吧!1、使用[]包裹列表中,每一个元素都是通过逗号、分割的。元素...
    99+
    2023-06-20
  • MySQL数据库创建内存表有哪些限制
    这篇文章主要讲解了“MySQL数据库创建内存表有哪些限制”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库创建内存表有哪些限制”吧!  当内存表...
    99+
    2024-04-02
  • MySQL中有哪些查询条件
    今天就跟大家聊聊有关MySQL中有哪些查询条件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。条件使用where子句对表中的数据筛选,结果为...
    99+
    2024-04-02
  • mysql什么时候创建临时表
    MySQL中临时表在以下情况下被创建:1、当执行包含“CREATE TEMPORARY TABLE”语句时,会创建一个临时表,只在当前的数据库连接中存在,并且在连接关闭后会自动删除;2、当执行一些复杂的查询或排序操作时,MySQL可能会在内...
    99+
    2023-07-28
  • MySQL建表需求有哪些
    这篇文章主要介绍“MySQL建表需求有哪些”,在日常操作中,相信很多人在MySQL建表需求有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL建表需求有哪些”的疑惑...
    99+
    2024-04-02
  • MySQL建表规范有哪些
    本篇文章给大家分享的是有关MySQL建表规范有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、MySQL建表规范1.1、准入规范级别必须...
    99+
    2024-04-02
  • mysql临时表的问题有哪些
    这篇文章主要为大家展示了“mysql临时表的问题有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql临时表的问题有哪些”这篇文章吧。 ...
    99+
    2024-04-02
  • mysql创建主键的方法有哪些
    在MySQL中创建主键的方法有以下几种: 在创建表时指定主键约束: CREATE TABLE table_name ( id...
    99+
    2024-04-09
    mysql
  • mysql创建索引的方式有哪些
    在MySQL中,有以下几种方式可以创建索引:1. CREATE INDEX语句:可以使用CREATE INDEX语句来创建索引。语法...
    99+
    2023-09-26
    mysql
  • jdbc不能创建表的原因有哪些
    JDBC无法创建表的原因可能有以下几个: 数据库连接失败:如果JDBC无法成功连接到数据库,就无法执行任何数据库操作,包括创建表...
    99+
    2024-02-29
    jdbc
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作