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

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

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

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

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

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

    2.1K10

    MySQL】外约束的删除和更新总结

    约束的删除/更新行为 行为 说明 NO ACTION 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外,如果有则不允许删除/更新。...(与RESTRICT一致) RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外,如果有则不允许删除/更新。...(与NOT ACTION一致) CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外,如果有,则也删除/更新外在子表总的记录。...SET NULL 当在父表中删除对应记录时,首先检查该记录是否有对应外,如果有则设置该子表中该外键值为null(这就要求该外允许取null)。...id为6,我们可以看到子表emp中存在外关联的数据也会被删除

    41910

    Redis 过期删除策略

    先来介绍一下各种方案: ---- 定时删除: 在设置的过期时间的同时,创建一个定时器(timer),让定时器在的过期时间来临时,立即执行对删除操作.即从设置key的Expire开始,就启动一个定时器...,到时间就删除该key;这样会对内存比较友好,但浪费CPU资源 ---- 惰性删除:放任过期不管,但是每次从空间中获取时,都检查取得的是否过期,如果过期的话,就删除;如果没有过期,就返回该...至于要删除多少过期,以及要检查多少个数据库,则由算法决定。...如果输入已经过期,那么expireIfNeeded函数将输入从数据库中删除。...当不存在或者因为过期而被expireIfNeeded函数删除时,命令按照不存在的情况执行。

    1.1K10

    iOS 键盘删除响应

    iOS 键盘删除响应 背景 背景是,实现一个分享到微信,多选加输入框,点击键盘删除删除多选选中对象的东西。...实现 由于UITextField没有删除的代理,所以笔者最开始的想法是,通过textField:shouldChangeCharactersInRange:replacementString:来实现监听...self.deleteBackwardBlock } } return YES; } 验证后发现:第三方输入法用此逻辑没有问题,但是系统原生输入法,当textField为空时,点击删除是不会走这个代理方法的...测试后可以发现点击键盘删除时,代理方法确实响应了,代码如下: @interface TargetView () @property (nonatomic, strong...,字符和多选一同被删除了,而我们需要的时,在最后一个字符删除后,再次点击删除才应该操作多选。

    27220

    Oracle 级联删除

    所谓的级联删除是指当主表中的一条记录被删除,那么子表中所关联的记录也相应的自动删除。本教程将教大家如何在Oracle中使用级联删除。...此外,我们也可以创建一个具有多个字段的外(带级联删除),如下例所示: CREATE TABLE supplier ( supplier_id numeric(10) not null, supplier_name...根据supplier_id和supplier_name删除supplier表中的记录时,外fk_foreign_comp上的级联删除会导致products表中的所有对应记录也会被级联删除。...带级联删除),该外基于supplier_id字段引用supplier表。...此外,我们也可以创建一个具有多个字段的外(带级联删除),如下例所示: ALTER TABLE products ADD CONSTRAINT fk_supplier FOREIGN KEY (supplier_id

    1.2K30

    Redis 过期删除策略

    Redis 中数据库的过期时间都保存在过期字典中,当一个过期了,Redis 存在三种不同的删除策略:定时删除、惰性删除和定期删除 定时删除 定义 在设置的过期时间的同时创建一个计时器,让定时器在过期时间来临时...,立即执行对删除操作。...定时删除策略对内存是最友好的:通过使用定时器,定时删除策略可以保证过期会尽快被删除,并且释放过期所占用的内存。...惰性删除 定义 放任过期不管,但是每次从空间中获取时都检查取得的是否过期,如果过期的话,就删除;如果没有过期则返回该。...定期删除 定义 每隔一段时间,程序都会对数据库进行一次检查,删除里面的过期。至于要删除多少过期,以及要检查多少个数据库,则由算法决定。

    69610

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

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

    1.8K40

    Redis过期删除策略

    注:对于散列表这种容器,只能为整个设置过期时间(整个散列表),而不能为里面的单个元素设置过期时间。 如果一个是过期的,那它到了过期时间之后是不是马上就从内存中被被删除呢?...如果不是,那过期后到底什么时候被删除呢? 其实有三种不同的删除策略: (1):立即删除。在设置的过期时间时,创建一个回调事件,当过期时间达到时,由时间处理器自动执行删除操作。...(2):惰性删除过期了就过期了,不管。每次从dict字典中按key取值时,先检查此key是否已经过期,如果过期了就删除它,并返回nil,如果没过期,就返回键值。 (3):定时删除。...每隔一段时间,对expires字典进行检查,删除里面的过期。 可以看到,第二种为被动删除,第一种和第三种为主动删除,且第一种实时性更高。下面对这三种删除策略进行具体分析。...定时删除是:每隔一段时间执行一次删除操作,并通过限制删除操作执行的时长和频率,来减少删除操作对cpu的影响。另一方面定时删除也有效的减少了因惰性删除带来的内存浪费。

    83610
    领券