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

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

MySQL进阶主外讲解 1.什么是外: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外:是另一表的主键, 外可以有重复的, 可以是空值,用来和其他表建立联系用的...Id=Dept_id,而Dept_id就是员工表中的外:因为员工表中的员工需要知道自己属于哪个部门,就可以通过外Dept_id找到对应的部门,然后才能找到部门表里的各种字段信息,从而让二者相关联。...所以说,外一定是在从表中创建,从而找到与主表之间的联系;从表负责维护二者之间的关系。 2.外的使用需要满足下列的条件:(这里涉及到了InnoDB的概念) 1....MySQL常见引擎有两种:InnoDB和MyISAM,后者不支持外。 2. 建立外关系的对应列必须具有相似的InnoDB内部数据类型。 3....SET NULL:将外设置为空。 NO ACTION:什么都不做。 注:一般是RESTRICT和CASCADE用的最多。

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

    mysql 设置约束(foreign key)

    建立外约束可以采用列级约束语法和表级约束语法,如果仅仅对单独的一个数据列建立外约束,则使用列级约束语法即可;如果需要对多个列组合创建外约束,或者需要为外约束指定名字则必须使用表级约束语法。...key, student_name varchar(255), java_teacher int references teacher_table(teacher_id) ); 虽然MySQL...支持使用列级约束的语法来建立外约束,但这种列级的约束语法建立的外约束不会生效,MySQL提供这种列级约束语法仅仅是和标准SQL保持良好的兼容性。...因此,如果需要MySQL中的外约束生效,应使用表级约束语法。...使用表级约束语法可以使用外的约束指定约束名,如果创建外约束没有指定约束名,则MySQL会为该外约束命名为table_name_ibfk_n,其中table_name是从表的表名,而n是从1开始的整数

    5.4K30

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

    添加的表是没有任何列的,如图所示: 单击工具栏的鼠标指针按钮,将鼠标切换回指针模式,然后双击一个表,系统将打开表属性窗口,在General选项卡中可以设置表的Name、Code等属性。...在为表设置主键时有以下几种办法: 1.在Columns选项卡中,直接选中主键列的P列复选框,这是最简单的方式。...另外需要注意的是,在建立主键时,系统会在主键上建立索引,索引分为聚集索引和非聚集索引,在“属性”窗口的General选项卡中可以设置该主键上建立的索引是聚集索引还是非聚集索引,如图所示: 外 如果是由概念模型或者逻辑模型生成物理模型...,那么外是通过Relationship生成的,也可以通过工具栏中的Reference来实现两表之间的外关系。...切换到鼠标指针模式,双击箭头,系统将弹出引用的属性窗口,在属性窗口中可以设置该引用的Name、Code、关联的列、约束名、更新策略和删除策略等。

    2.1K10

    mysql 设置约束SET FOREIGN_KEY_CHECKS=1

    1.问题描述:Mysql中如果表和表之间建立的外约束,则无法删除表及修改表结构 解决方法: 在Mysql中取消外约束: SET FOREIGN_KEY_CHECKS=0; 然后将原来表的数据导出到sql...语句,重新创建此表后,再把数据使用sql导入, 然后再设置约束: SET FOREIGN_KEY_CHECKS=1; 2....MySQL 5.1.48 导入 MySQL 5.7.18 时遇到 T FOREIGN_KEY_CHECKS = 0 错误的解决方法 #1064 – You have an error in your SQL...‘T FOREIGN_KEY_CHECKS = 0’ at line 1 经查询,这个是 mysql 启动和关闭外约束的方法,去掉即可。...: //您必须在CREATE TABLE中使用外键子句来指定MySQL中的外: DROP TABLE IF EXISTS cities; #删除原来创建的表 CREATE TABLE cities

    3.2K30

    设置

    关键词:外 | 索引 | InNoDB和MyISAM | 引用 | Mysql 设置的目的:保证数据的一致性!...外列必须建立了索引,MySQL 4.1.2以后的版本在建立外时会自动创建索引,但如果在较早的版本则需要显式建立; #创建索引 CREATE INDEX 字段1 ON test(字段1) #对...test2创建test的索引,在test2下执行,test2为从,test为主 这一步也是博主自己刚开始研究是碰到的最大的坑, 外引用一直选不了对应字段,可能是你没有设置索引 ③ 外关系的两个表的列必须是数据类型相似...,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 二、设置 1、SQL代码设置 ALTER TABLE test2 ADD xxx #约束名 自己起...; #父表更新子表更新方式 2、可视化界面设置 选中表—》关/系/外 | F10 ——》外部 约束名自动生成不用管,重点是后面的更新和删除关键字 三、相关关键字含义 外约束(表2)

    2.7K30

    idea的快捷设置_idea设置eclipse快捷

    File-setting-keymap下拉框选成eclipse 由于其中一些快捷和计算机快捷冲突,需要自行设置 查询快捷方式1: 查询快捷方式2: 设置过程:...Duplicate lines):ctr+alt+(MumPad) 2 向下移动一行(move statement down):alt+方向下键 向上移动一行(move statement up):alt+方向上...+shift+z;显示方法参数面板 alt+enter;可以进行lambda的表达时即可显示替换; Generate… //Alt+(NumPad)-0 alt+鼠标选择 //局部复制 idea浏览器设置...:setting-tools-Web Browsers(搜Web)::设置对应浏览器路径 html标签可以输入p在点击Tab就可自动生成标签 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

    1.3K20

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

    点击【下一步】按钮,弹出“设置脚本编写选项” ? 点击【高级】按钮,弹出具体设置窗口【此步骤非常重要】 ?...将“编写外脚本”的值设置为false,意思是这一步骤生成的数据结构脚本中不包含表之间的外关系。其他选项根据实际情况设置。 点击【确定】按钮,生成脚本,入下图。 ?...设置 SET IDENTITY_INSERT dbo.T_ACL_User Off ; 步骤5:从源数据库生成仅包含表外关系的数据结构脚本   步骤与步骤1大致相同,最后一步设置相反 ?...红色框内,将“编写外脚本”设置为True,其他选项与步骤1中设置相反。点击"确定"按钮,生成脚本,另存为“OriginalDataStructureOnlyWithFK.sql”。...外已经成功创建。

    1.8K40
    领券