首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据库MySQL进阶一、主外讲解

MySQL进阶主外讲解 1.什么是外: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外:是另一表的主键, 外可以有重复的, 可以是空值,用来和其他表建立联系用的...Id=Dept_id,而Dept_id就是员工表的外:因为员工表的员工需要知道自己属于哪个部门,就可以通过外Dept_id找到对应的部门,然后才能找到部门表里的各种字段信息,从而让二者相关联。...注:InnoDB是数据库的引擎。MySQL常见引擎有两种:InnoDB和MyISAM,后者不支持外。 2. 建立外关系的对应列必须具有相似的InnoDB内部数据类型。...建立外关系的对应列必须建立了索引。 4. 假如显式的给出了CONSTRAINT symbol,那symbol在数据库必须是唯一的。假如没有显式的给出,InnoDB会自动的创建。...面试题:你的数据库用什么存储引擎?区别是? 答案:常见的有MyISAM和InnoDB。 MyISAM:不支持外约束。不支持事务。

2K70
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    在PowerDesigner设计物理模型1——表和主外

    使用逆向工程的方法,连接到现有的数据库,由数据库生成物理模型。 物理模型能够直观的反应出当前数据库的结构。在数据库的表、视图、存储过程等数据库对象都可以在物理模型中进行设计。...Name是在模型显示的名称,Code是生成数据库表的时候的实际表名。另外Name的内容还会作为SQL Server的表备注。 单击Columns切换到列选项卡,在下面的列表可以添加表的列。...另外需要注意的是,在建立主键时,系统会在主键上建立索引,索引分为聚集索引和非聚集索引,在“属性”窗口的General选项卡可以设置该主键上建立的索引是聚集索引还是非聚集索引,如图所示: 外 如果是由概念模型或者逻辑模型生成物理模型...,那么外是通过Relationship生成的,也可以通过工具栏的Reference来实现两表之间的外关系。...”按钮,然后在设计面板,课程表上按下鼠标左键,并拖拽到教师表中放开鼠标,这时如果课程表没有RoomID列,系统会自动创建RoomID列并创建该列上的外引用,如果已经存在RoomID列,则只添加外引用

    2.1K10

    SQL Server数据库中导入导出数据及结构时主外关系的处理

    将“编写外脚本”的值设置为false,意思是这一步骤生成的数据结构脚本不包含表之间的外关系。其他选项根据实际情况设置。 点击【确定】按钮,生成脚本,入下图。 ?...选中新建的数据库,打开步骤一保存的”OriginalDataStructureWithoutFK.sql“脚本文件,运行该文件,运行成功后,目标数据库成功创建了表、视图、存储过程、自定义函数,如下图...红色框内,将“编写外脚本”设置为True,其他选项与步骤1设置相反。点击"确定"按钮,生成脚本,另存为“OriginalDataStructureOnlyWithFK.sql”。...步骤6:导入外结构关系脚本至目标数据库   选中目标数据库,打开步骤5保存的“OriginalDataStructureOnlyWithFK.sql”脚本文件,运行之,运行成功后,查看表结构 ?...外已经成功创建。

    1.8K40

    数据库主外建适用场景

    主键和索引是不可少的,合理使用可以优化数据检索速度 焦点:数据库设计是否需要外。这里有两个问题: 一、如何保证数据库数据的完整性和一致性; 二、创建外对性能的影响。...2,有主外数据库设计可以增加ER图的可读性,这点在数据库设计时非常重要。 3,外在一定程度上说明的业务逻辑,会使设计周到具体全面。...update,   delete   数据的时候更快) eg: 在海量的数据库想都不要去想外,试想,一个程序每天要insert数百万条记录,当存在外约束的时候,每次要去扫描此记录是否合格,一般还不...结论: 1,在大型系统(性能要求不高,安全要求高),使用外;在大型系统(性能要求高,安全自己控制),不用外;小系统随便,最好用外。...2,用外要适当,不能过分追求 3,不用外而用程序控制数据一致性和完整性时,应该写一层来保证,然后个个应用通过这个层来访问数据库

    77650

    通过sql命令建表 和 主外约束以及其他约束

    emp_sex nchar(1), 11 dept_id int constraint fk_dept_id_b foreign key references dept(dept_id) --外约束...SQL Server里最后一行)的逗号可有可无,但是Oracle数据库不能加逗号,但是建议SQL最后一个字段不要写逗号,方便移植 4. nvarchar表示国际化编码长度可变的字符型变量 5....主键外可以命名,不然就是默认的名字 7....写完后,鼠标左键选中整个代码,分析、执行,最后生成表 什么是约束constraint: 对一个表的属性操作的限制 分类: 主键约束:不允许重复元素,避免数据的冗余 外约束:通过外约束,从语法上保证了本事物所关联的其他事物一定是存在的...事物和事物之间的关系是通过外来体现的 check约束:保证事物属性的取值在合法的范围之内 1 create table student 2 ( 3 stu_id int primary key

    95920

    MySQL操作之数据查询语言:(DQL)(四-2)(多表查询)

    (DC)(五) 7 MySQL MySQL操作之数据库函数 8 MySQL MySQL管理之数据类型 9 MySQL MySQL管理之索引 10 MySQL MySQL管理之事务管理 11 MySQL...主表的主键和从表的外形成主外关系 从表外的值是对主表主键的引用。...从表外类型,必须与主表主键类型一致。 建立外的表必须是InnDB型,不能是临时表。 外键名不能用引号。FK_ID错误。应为FK_ID。、 添加数据时:从表的外,只能添加主表主键存在的数据。...ALTER TABLE 表名 DROP FOREIGN KEY 外键名; 具体: ALTER TABLE student DROP FOREIGN KEY FK_ID; 二、一对多操作 1.添加主外约束...1、创建中间表,给中间表添加两个外约束 2、创建表、添加数据 订单表和订单项表的主外关系 alter table `orderitem` add constraint orderitem_orders_fk

    26330

    day05_MySQL学习笔记_02

    SQL Server数据库软件(identity:身份、特性)       Oracle数据库软件(sequence:序列)       MySQL数据库软件(auto_increment:自动递增)...如果两张表的查询,那么至少有一个主外条件,三张表连接至少有两个主外条件。     ...特别注意:我自己测试过,两张表的主外关系可以alter修改表的主次表关系,使这两张表有了主外关系;          两种表也可以不有主外关系,只要他们对应的字段和字段类型相同就行。     ...2、执行SQL脚本 恢复数据     前提:必须先创建数据库名     执行SQL脚本需要先登录mysql,然后进入指定数据库,才可以执行SQL脚本!!!     ...注意:在执行脚本时需要先行核查当前数据库的表是否与脚本文件的语句有冲突!   例如在脚本文件存在create table a的语句,而当前数据库已经存在了a表,那么就会出错!

    2.1K20

    mysql(入门基础了解部分,数据库的基本概念)

    今天终于在mysql的基础看完了,开始总结一波 为什么要使用数据库??? 持久化(persistence):把数据保存到可掉电式存储设备以供之后使用。...持久化的主要作用是将内存的数据存储在关系型数据库,当然也可以存储在磁盘文件、XML数据文件。...MySQL是一种关联数据库管理系统,将数据保存在不同的表,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL是开源的,所以你不需要支付额外的费用。...基础信息表(常用信息):学号、姓名、手机号码、班级、系别档案信息表(不常用信息):学号、身份证号码、家庭住址、籍贯、紧急联系人、...两种建表原则:外唯一:主表的主键和从表的外(唯一),形成主外关系...外是主键:主表的主键和从表的主键,形成主外关系。  一对多关系(one-to-many) 常见实例场景:客户表和订单表,分类表和商品表,部门表和员工表。 举例:员工表:编号、姓名、...

    84530

    MySQL全部知识点(2)

    5 外 主外是构成表与表关联的唯一途径! 外是另一张表的主键!例如员工表与部门表之间就存在关联关系,其中员工表的部门编号字段就是外,是相对部门表的外。...MySQL数据库备份与还原 备份和恢复数据 1 生成SQL脚本 在控制台使用mysqldump命令可以用来生成指定数据库的脚本文本,但要注意,脚本文本只包含数据库的内容,而不会存在创建数据库的语句!...这个条件大多数情况下都是使用主外关系去除。...两张表的连接查询一定有一个主外关系,三张表的连接查询就一定有两个主外关系,所以在大家不是很熟悉连接查询时,首先要学会去除无用笛卡尔积,那么就是用主外关系作为条件来处理。...如果两张表的查询,那么至少有一个主外条件,三张表连接至少有两个主外条件。 3 自然连接 大家也都知道,连接查询会产生无用笛卡尔积,我们通常使用主外关系等式来去除它。

    1.9K70

    【Redis】Redis 数据库操作 ③ ( Redis 操作 | 连接数据库 | 向数据库添加值 | 查询所有 | 查询存在 | 查询类型 | 删除 | 设置过期时间 )

    文章目录 一、Redis Key 操作 1、连接数据库 2、向数据库添加值 3、查询数据库中所有的 4、查询数据库中指定是否存在 5、查询类型 6、删除 7、设置过期时间 一、Redis...redis-cli 127.0.0.1:6379> auth 000000 OK 2、向数据库添加值 执行 set name1 Tom set name2 Jerry 命令 , 向数据库插入上面两个键值对...执行 keys * 命令 , 可以查看当前数据库 , 有哪些 key ; 脚本示例 : 127.0.0.1:6379> keys * 1) "name1" 2) "name" 3) "name2..." 4、查询数据库中指定是否存在 执行 exists name1 命令 , 查看当前 数据库是否 存在 name1 , 如果存在 返回 (integer) 1 , 如果不存在 , 返回 (integer...) 0 ; 脚本示例 : 在下面的代码 , 查询 name1 , 返回 1 说明该存在 , 查询 name3 , 返回 0 说明该不存在 ; 127.0.0.1:6379> exists name1

    1.6K10

    ​基于MybatisPlus代码生成器(2.0新版本)

    对于百余张表的数据库,使用代码生成器让开发事半功倍。多表连接查询。多表连接查询默认不开启,需要在全局文件手动配置。...开启多表连接查询后,代码生成器会自动读取数据库元数据信息主外关系,分别生成一对一、一对多、多对多风格的源代码。生成的代码接口可通过Swagger暴露。...2、运行依赖服务代码生成器运行依赖Mysql数据库,版本不限。Mysql数据库Mysql数据库库表结构为用户自定义的库表,代码生成将会读取。项目SQL脚本提供5张测试表,方便用于测试使用。...2、配置数据库连接数据库连接配置对应的数据库应包含带生成代码的库表结构。...2、多表连接当在全局配置ucode.code.joinQuery = true时,则手动开启主外查询,系统会自动读取表的主外关系,并将其转化为连接查询的源代码。

    1.1K40

    表与表之间关系

    可以在数据库图表的表之间创建关系,以显示一个表的列与另一个表的列是如何相链接的。 在一个关系型数据库,利用关系可以避免多余的数据。...一、表与表之间关系概述 1.1、什么是表与表之间关系 在关系型数据库,为了避免数据冗余,我们的一些表与表之间肯定是有一定的关系。 如:学生表与老师表,部门表与员工表,用户表与权限表等。...注意: 一对多的创建原则: 主外关连 1.2.2、一对一关系 在一对一关系,A 表的一行最多只能匹配于 B 表的一行,反之亦然。如果相关列都是主键或都具有唯一约束,则可以创建一对一关系。...注意: 一对一的创建原则: 外唯一:主表的主键和从表的外(唯一),形成主外关系,外唯一 UNIQUE 外是主键:主表的主键和从表的主键,形成主外关系 1.2.3、多对多关系 在多对多关系,...2、一对多应用 创建一对多关系:主外关连 新华出版社(Python爬虫、Linux) 海燕出版社(操作系统、数学) 摆渡出版社(英语、网页设计) 大众出版社() 案例: 这是一个书和出版社的一个例子

    1.4K30

    基于SSM源代码风格Java代码生成器 Maven版开箱即用 摸鱼神器

    对于百余张表的数据库,使用代码生成器让开发事半功倍。 多表连接查询。多表连接查询默认不开启,需要在全局文件手动配置。...开启后代码生成器会自动读取数据库元数据信息主外关系,分别生成一对一、一对多、多对多风格的源代码。 生成的代码接口可通过Swagger暴露。...二、运行依赖服务 代码生成器运行依赖Mysql数据库、Redis服务,版本不限。...Mysql数据库 Mysql数据库库表结构分为两部分,一是系统运行必要的系统表(跟代码生成业务无关),二是用户自定义的库表,代码生成将会读取。...多表连接 当在全局配置ucode.code.joinQuery = true时,则手动开启主外查询,系统会自动读取表的主外关系,并将其转化为连接查询的源代码。

    79761

    mysql 分区_mysql分区

    分区 就访问数据库的应用而言,逻辑上只有一个表或一个索引,但是实际上这个表可能由数10个物理分区对象组成,每个分区都是一个独立的对象,可以独自处理,可以作为表的一部分进行处理。...对于上百万条记录的表来说,删除分区要比运行一个delete 语句有效得多 经常运行包含分区的查询,mysql可以很快地确定只有某一个或某些分区需要扫描。...例如,上述例子检索store_id ,大于10的记录,mysql只需要扫描p1 ; 可以使用explain 来检测,查询使用的是哪个分区; List分区: list 分区是建立离散的值列表告诉数据库特定的值属于哪个分区...; 在执行hash分区时,mysql会对分区应用一个散列函数,以此确定数据应当放在N个分区的哪个分区。...; 子分区 对分区表每一个分区再次分割,又被称为复合分区;适合用于保存非常大量的数据记录; mysql分区处理null值的方式 mysql禁止分区键值使用null,分区可能是一个字段或者一个用户定义的表达式

    3.8K30

    数据库基础

    持久化操作:保存到数据库 主键:用户表里的id,唯一标识 外:另一个表里引用的用户id,外 下载mysql 配置环境 更改密码:a12345678 Navicat Premium for Mac的破解教程...-p 数据库操作 ;是结束符 1.创建数据库 create database mysql_0219; 2.查看所有数据库 show databases; 3.使用数据库 use mysql..._0219; 4.删除数据库 drop database mysql_0219; 5.查看数据库状态 status (注意编码:utf-8) 表的创建与管理: 1.创建表 create table...' where id=1; 4.删除数据 delete from t_user1 where id =2; delete from t_user1;(清空表) 约束条件 非空约束 唯一约束 主键约束 主外约束...email) VALUES(23,'110@email.com'); INSERT INTO t_user3(name,email) VALUES(2223,'112220@email.com'); 主外约束

    65530
    领券