MySQL创建表时的条件有哪些

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

create database bjpowernnode;use bjpowernode;source C:UsersAdministratorDesktopbjpowernode.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));

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

   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创建表时的条件有哪些

v1.2.1云EC电商系统 v1.2.1云EC电商系统

云EC电商系统(简称云EC)是由佛山市云迈电子商务有限公司自主开发的一套免费、开源的基于PHP+MYSQL电商系统软件。云EC电商系统 1.2.1 更新日志:2018-08-101.修复部分环境下二维码不显示的问题;2.商品列表增加多属性筛选支持;3.修复更新优惠券状态时错将已使用的优惠券也更新为过期;4.修复文章发布远程图片下载失败;5.修复某些情况下运费计算出错导致

v1.2.1云EC电商系统 2595 查看详情 v1.2.1云EC电商系统

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(主键约束) sname classno(外键约束)

1jack1002lucy1003kk1004smith2005frank3006jhh300

班级表t_calss

cno(主键约束) cname

100高三1班200高三2班300高三3班

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

注意:

1.外键值可以为空

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

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

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

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

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

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

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

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创建表时的条件有哪些的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/756638.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 23:03:19
下一篇 2025年11月25日 23:08:55

相关推荐

  • 在 Go 中创建跨平台文件路径

    本文将介绍如何在 Go 语言中创建和处理跨平台的文件路径。Go 提供了 os 和 path/filepath 包,允许开发者以操作系统无关的方式构建文件路径。本文将深入探讨这两种方法,并提供示例代码,帮助您编写可在不同操作系统上运行的 Go 程序。 在 Go 语言中,处理文件路径时需要考虑不同操作系…

    好文分享 2025年12月15日
    000
  • Go语言中创建跨平台文件路径的最佳实践

    本文深入探讨了Go语言中处理跨平台文件路径的策略,旨在解决不同操作系统(如Windows的和Unix/Linux/macOS的/)间路径分隔符的差异。文章介绍了利用os.PathSeparator和path/filepath包进行直接操作系统路径操作的方法,以及一种更统一的策略:在程序内部始终使用/…

    2025年12月15日
    000
  • Linux系统下通过PID获取进程详细信息教程

    本文详细介绍了在Linux系统下,如何利用ps命令,通过进程ID(PID)获取指定进程的各项详细信息。文章涵盖了ps命令的基础用法、如何使用-o选项自定义输出内容,并提供了具体的命令示例,帮助读者高效地监控和管理系统进程。 在linux系统管理和故障排查中,经常需要根据已知的进程id(pid)来获取…

    2025年12月15日
    000
  • Go语言包独立性与成员可见性规则详解

    Go语言中,包是独立的组织单元,其可见性规则与文件系统路径无关。即使目录结构呈现父子关系,如foo和foo/utils,它们仍是完全独立的包。一个包无法访问另一个包的私有(未导出)成员。导入路径仅用于定位包,不代表层级可见性。 Go语言的包模型 在go语言中,包是代码组织和重用的基本单位。每个go源…

    2025年12月15日
    000
  • 解决 Go WebSocket EOF 错误:保持连接存活

    本文旨在解决在使用 Go 语言进行 WebSocket 开发时遇到的 EOF (End-of-File) 错误。通过分析问题根源,提供保持 WebSocket 连接存活的有效方法,并提供一个简单的客户端-服务器示例,展示如何正确处理 WebSocket 连接,避免因连接意外关闭导致的 EOF 错误。…

    2025年12月15日
    000
  • 深入理解Go语言中的new与make:内存分配与类型初始化

    Go语言提供了new和make两种内建函数用于内存分配和初始化,它们各自服务于不同的场景。new用于为任何类型分配零值内存并返回其指针,而make则专为切片、映射和通道这三种引用类型设计,用于分配并初始化其内部数据结构,返回的是已准备好使用的类型实例本身。理解两者的区别对于编写高效且正确的Go代码至…

    2025年12月15日
    000
  • Go WebSockets 长连接管理:解决 EOF 错误与实现持久化通信

    本文旨在解决Go语言WebSocket连接在首次请求后出现EOF错误并导致连接中断的问题。通过详细阐述WebSocket持久化连接的核心原理,即在独立的Goroutine中维护持续的读写循环,确保连接的生命周期与应用需求一致,从而实现稳定的双向通信,避免频繁重连。 理解WebSocket连接的生命周…

    2025年12月15日
    000
  • Go 语言内存分配:new 与 make 的选择

    Go 语言提供了多种内存分配和值初始化的方式,包括 &T{…}、&someLocalVar、new 和 make。此外,创建复合字面量时也会发生内存分配。理解 new 和 make 的区别对于编写高效的 Go 代码至关重要。 正如上述摘要所概括的,new 和 make 是…

    2025年12月15日
    000
  • Go语言内存分配:深入解析new与make的异同与应用场景

    在Go语言中,new和make是两种核心的内存分配与初始化机制。new用于为任意类型分配零值内存并返回其指针,而make则专为切片、映射和通道这三种引用类型设计,用于分配并初始化其内部数据结构,返回的是已初始化的值而非指针。理解两者的差异及其适用场景,对于编写高效且符合Go惯例的代码至关重要。 Go…

    2025年12月15日
    000
  • Go语言运行时内省:获取调用方包名与函数信息

    本文探讨在Go语言中如何通过运行时(runtime)机制,程序化地获取调用方(caller)的包名、函数名及其源文件位置。我们将重点介绍runtime.Caller和runtime.FuncForPC这两个核心函数,并提供示例代码,帮助开发者在构建如日志、配置管理等库时,实现基于调用上下文的灵活功能…

    2025年12月15日
    000
  • 使用部分字符串在 Go GAE Datastore 中搜索条目

    本文介绍了如何在 Google App Engine (GAE) 的 Datastore 中使用 Go 语言进行部分字符串匹配查询。由于 Datastore 本身不支持 LIKE 操作,我们将利用其提供的范围查询功能(> 和 在 Google App Engine (GAE) 的 Datast…

    2025年12月15日
    000
  • Go语言运行时自省:获取调用者包名与函数信息

    本文深入探讨了Go语言中通过runtime.Caller和runtime.FuncForPC进行运行时自省,以程序化方式获取调用者包名、文件路径、行号及函数名称的方法。文章提供了详细的代码示例,并分析了不同调用场景下的输出结果。同时,着重阐述了这些API在实际使用中可能遇到的局限性,如编译器内联的影…

    2025年12月15日
    000
  • 获取 Go 程序入口包名:使用 runtime 包进行自省

    在 Go 语言中,有时我们需要在运行时获取关于当前程序的一些信息,例如当前执行函数的包名。这在编写通用库或框架时尤其有用,可以根据调用者的上下文来执行不同的操作。runtime 包提供了一些函数,可以帮助我们实现这个目标。 runtime.Caller 函数可以获取调用栈的信息,包括程序计数器(PC…

    2025年12月15日
    000
  • 获取 Go 程序主包名:运行时自省技巧

    在 Go 语言中,有时我们需要在运行时获取关于当前代码执行环境的信息,例如调用者的包名、函数名等。这种自省能力在编写通用库或框架时尤其有用,它可以帮助我们根据调用者的上下文做出不同的处理。虽然 Go 语言不像 Python 那样拥有强大的 inspect 模块,但 runtime 包提供了一些函数,…

    2025年12月15日
    000
  • 获取 Go 程序主包名的方法

    在 Go 语言中,有时我们需要在运行时获取关于调用者的信息,例如调用者的文件名、行号以及函数名。这在编写库或者框架时尤为有用,可以帮助我们实现一些高级功能,比如自动化的配置加载、日志记录等。本文将介绍如何利用 runtime 包中的 runtime.Caller 和 runtime.FuncForP…

    2025年12月15日
    000
  • Go语言集成SQLite3数据库:使用go-sqlite3库的实践指南

    本文旨在为Go语言开发者提供一套完整的SQLite3数据库集成指南。我们将重点介绍如何使用广受欢迎的github.com/mattn/go-sqlite3库,涵盖其安装、数据库连接、表创建、数据插入、查询、更新及删除等核心操作,并提供实用的代码示例和注意事项,助您高效地在Go应用中实现SQLite3…

    2025年12月15日
    000
  • Go 语言中使用 SQLite3:库选择与实践指南

    本文旨在为 Go 语言开发者提供一份关于 SQLite3 数据库连接与操作的实用指南。我们将介绍如何选择合适的 SQLite3 驱动库,并提供简单的 INSERT 和 SELECT 操作示例代码,帮助你快速上手在 Go 项目中使用 SQLite3。 选择合适的 SQLite3 驱动库 在 Go 语言…

    2025年12月15日
    000
  • 将二进制字符串转换为整数:Go语言高效指南

    本文将介绍如何使用Go语言将表示二进制数的字符串转换为整数。正如摘要所述,我们将使用Go标准库strconv中的ParseInt函数,避免手动编写转换逻辑。 使用 strconv.ParseInt 函数 strconv.ParseInt 函数可以将给定基数的字符串转换为指定位数的整数。其函数签名如下…

    2025年12月15日
    000
  • Go语言包的可见性:子包与根包的成员访问

    Go语言的包管理机制与传统的面向对象编程语言存在显著差异。虽然目录结构上存在类似父子关系的组织形式,例如foo和foo/utils,但在Go语言中,它们被视为完全独立的包。这意味着,foo/utils并非foo的子包,它们之间的关系仅仅体现在导入路径上。 包的独立性 在Go语言中,每个目录对应一个独…

    2025年12月15日
    000
  • Go语言包可见性深度解析:理解“子包”的真相

    Go语言中,包的可见性规则严格遵循首字母大小写,而非文件系统路径层级。一个包(如foo)无法访问其子目录中其他包(如foo/utils)的私有成员。foo/utils仅是导入路径,不代表继承或特殊访问权限,所有包都是独立的可见性单元。深入理解这一机制对于编写清晰、可维护的Go代码至关重要。 Go语言…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信