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

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

MySQL进阶主外讲解 1.什么是外: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外:是另一表的主键, 外可以有重复的, 可以是空值,用来和其他表建立联系用的...Id=Dept_id,而Dept_id就是员工表中的外:因为员工表中的员工需要知道自己属于哪个部门,就可以通过外Dept_id找到对应的部门,然后才能找到部门表里的各种字段信息,从而让二者相关联。...所以说,外一定是在从表中创建,从而找到与主表之间的联系;从表负责维护二者之间的关系。 2.外的使用需要满足下列的条件:(这里涉及到了InnoDB的概念) 1....MySQL常见引擎有两种:InnoDB和MyISAM,后者不支持外。 2. 建立外关系的对应列必须具有相似的InnoDB内部数据类型。 3....MyISAM:不支持外约束。不支持事务。对数据大批量导入时,它会边插入数据边建索引,所以为了提高执行效率,应该先禁用索引,在完全导入后再开启索引。 InnoDB:支持外约束,支持事务。

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

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

    Name是模型上显示的名称,Code是生成的实际的表名,后面的3个复选框P代办主键、F代表外,M代表不能为空。...3.切换到Keys选项卡中,在其中添加一行命名为PK_ClassRoom,然后单击工具栏的“属性”按钮,打开属性窗口,在该窗口中切换到Columns选项卡,单击添加列按钮,弹出列选择窗口,选中主键中应该包含的列...另外需要注意的是,在建立主键时,系统会在主键上建立索引,索引分为聚集索引和非聚集索引,在“属性”窗口的General选项卡中可以设置该主键上建立的索引是聚集索引还是非聚集索引,如图所示: 外 如果是由概念模型或者逻辑模型生成物理模型...,那么外是通过Relationship生成的,也可以通过工具栏中的Reference来实现两表之间的外关系。...”按钮,然后在设计面板中,课程表上按下鼠标左键,并拖拽到教师表中放开鼠标,这时如果课程表中没有RoomID列,系统会自动创建RoomID列并创建该列上的外引用,如果已经存在RoomID列,则只添加外引用

    2.1K10

    MySQL禁用自动连接学习--MySql

    如果mysql客户程序发送查询时断开与服务器的连接,它立即并自动尝试重新连接服务器并再次发送查询。...然而,即使mysql重新连接成功,你的第1个连接也已经结束,并且以前的会话对象和设定值被丢失:包括临时表、自动提交模式,以及用户和会话变量。...mysql> SET @a=1; Query OK, 0 rows affected (0.05 sec) mysql> INSERT INTO t VALUES(@a); ERROR 2006: MySQL...如果有必要在连接断开时终止mysql并提示错误,你可以用--skip-reconnect选项启动mysql客户程序。...分析原因: 之所以会出现这个异常,是因为Mysql在5以后针对超长时间DB连接做了一个处理,那就是如果一个DB连接在无任何操作情况下过了8个小时后,Mysql会自动把这个连接关闭。

    1.1K40

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

    操作过程分为以下几个步骤: 步骤1:从源数据库生成数据结构脚本【不包表含外关系】   在数据源188连接上,右键点击源数据库》【任务】》【生成脚本】 ? 弹出“生成和发布脚本” ?...将“编写外脚本”的值设置为false,意思是这一步骤生成的数据结构脚本中不包含表之间的外关系。其他选项根据实际情况设置。 点击【确定】按钮,生成脚本,入下图。 ?...设置 SET IDENTITY_INSERT dbo.T_ACL_User Off ; 步骤5:从源数据库生成仅包含表外关系的数据结构脚本   步骤与步骤1大致相同,最后一步设置相反 ?...红色框内,将“编写外脚本”设置为True,其他选项与步骤1中设置相反。点击"确定"按钮,生成脚本,另存为“OriginalDataStructureOnlyWithFK.sql”。...外已经成功创建。

    1.8K40

    常见的面试问题

    阅读量: 60 1、Mysql链表概述   因为表与表之间有关系,而且查询时需要两张表的某些数据。 链表的前提是:表与表之间必须设置主外吗?   ...不是的,其实表与表之间不需要设置主外关系,用数据库语句就可以实现链表查询,删除,修改,增加等操作。 为什么要设置主外呢?   通常我们看到表与表之间有关系,常常设置主外。为什么?...假设一个不了解你表结构的人,都能够任意的修改你的外。那这个表就不严谨了。 我们到底设不设主外呢?这就要分情况: 1、如果表结构简单,少量的表。逻辑不复杂。那么这个就不需要设置主外了。...那么自己不可能记住所有主外之间的关系,那么就需要设置主外。 链表查询又分为:左联表,右链表。等。 链表不仅可以进行查询,还可以链表查询,链表增加,链表删除,链表修改。...405 方法禁用 禁用请求中指定的方法。 406 不接受 无法使用请求的内容特性响应请求的网页。 407 需要代理授权 此状态代码与 401(未授权)类似,但指定请求者应当授权使用代理。

    74810

    mysql 分区_mysql分区

    对于已经过期或者不需要保存的数据,可以通过删除与这些数据有关的分区来快速删除数据 跨多个磁盘来分散数据查询,以获得更大的查询吞吐量 分区:partition key 查看是否支持分区: mysql>.../唯一字段之外的其他字段进行分区。...对于上百万条记录的表来说,删除分区要比运行一个delete 语句有效得多 经常运行包含分区的查询,mysql可以很快地确定只有某一个或某些分区需要扫描。...同时hash分区只支持整数分区,而key分区支持使用除blob,text以外的其他类型; 与hash分区不同,创建可以分区表的时候,可以不指定分区,默认会首先选择使用主键作为分区;没有主键时,会选择非空唯一作为分区...; 子分区 对分区表中每一个分区再次分割,又被称为复合分区;适合用于保存非常大量的数据记录; mysql分区处理null值的方式 mysql禁止分区键值使用null,分区可能是一个字段或者一个用户定义的表达式

    3.8K30

    存在外关联的主表truncate如何做

    主外是数据库提供的一种两表之间强制关联的方法,也可以从应用层实现。...优点 缺点 数据库实现的主外 由数据库层机制保证,无需应用额外实现 强关联,不易扩展变更 应用实现的主外 易扩展变更 完全由应用控制,要求较高 我认为需要根据实际情况进行取舍,例如表不复杂,可以由应用实现...存在主外关联的主表,由于存在外关联关系,因此有些操作就会禁止,例如truncate。 实验 1....禁用约束,删除后执行恢复操作 看到外约束名称:FK_TBL_B_A: SQL> select constraint_name, constraint_type, status from user_constraints...主外是数据库提供的强约束,可以帮助我们控制主子表之间的关系,但同时还是一把双刃剑,当然,我们认为既然定义了主外,就是需要这种强制关系,但有时可能就会有一些变更,因此,如何取舍,需要根据实际情况来决策

    82230

    mysql的外

    MySQL 3.23.44版本后,InnoDB引擎类型的表支持了外约束。...外的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外(据说以后的版本有可能支持,但至少目前不支持); 2.外列必须建立了索引,MySQL 4.1.2以后的版本在建立外时会自动创建索引...,但如果在较早的版本则需要显示建立; 3.外关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 外的好处:可以使得两张表关联...| SET NULL | NO ACTION | SET DEFAULT}] 该语法可以在 CREATE TABLE 和 ALTER TABLE 时使用,如果不指定CONSTRAINT symbol,MYSQL...ON DELETE、ON UPDATE表示事件触发限制,可设参数: RESTRICT(限制外表中的外改动) CASCADE(跟随外改动) SET NULL(设空值) SET DEFAULT(设默认值

    5.5K70

    MySQL约束

    关系是关系数据库的重要组成部分。关系是一个表中的一个或几个属性,用来标识该表的每一行或与另一个表产生联系。...其中就包括外 1 主键(primary key或unique key) 又称主码,数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。...而unique key只是为了保证域/域组的唯一性 2 外(foreign key) 又称外部。...注意 : 外不一定要与相应主键同名,只是在应用中为便于识别,当主键与相应外属于不同关系时,往往取同名 作用 保持数据一致性,完整性,主要目的是控制存储在外表中的数据。...使两张表形成关联,外只能引用外表中的列的值或使用空值。 案例 如果不使用外,表2的学号字段插了一个值(比如20140999999),但该值在表1中并没有。

    6.5K20

    Mysql约束

    如果表A的主关键字是表B中的字段,则该字段称为表B的外,表A称为主表,表B称为从表。...外是用来实现参照完整性的,不同的外约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。...外主要用来保证数据的完整性和一致性 两个表必须是InnoDB表,MyISAM表暂时不支持外列必须建立了索引,MySQL 4.1.2以后的版本在建立外时会自动创建索引,但如果在较早的版本则需要显示建立...; 外关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 创建外语法: 代码如下 复制代码 [CONSTRAINT...SET NULL: 从父表中删除或更新对应的行,同时将子表中的外列设为空。注意,这些在外列没有被设为NOT NULL时才有效。

    5.8K81
    领券