首页
学习
活动
专区
工具
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列,则只添加外引用

2K10

双向链表的增删改

就因为新增了这个指向上一个节点指针的特性,它解决了单向循环链表的诸多问题,如下: 单链表的结点都只有一个指向下一个结点的指针 单链表的数据元素无法直接访问其前驱元素 逆序访问单链表中的元素是极其耗时的操作...(如图) 双向链表图形表示: 【实现代码】 因为插入和删除节点的步骤跟单向循环链表差不多,只是多了一个前驱指针,我们这里值给出代码,具体的插入和删除操作的示例图就不一一列举了。...#ifndef _DLINK_LIST_H #define _DLINK_LIST_H //自定义双向链表数据类型 typedef void DLinkList; //自定义双向链表节点数据类型 typedef...DLinkList* DLinkList_Create(); //销毁链表 void DLinkList_Destroy(DLinkList* list); //清空链表 void DLinkList_Clear...但代码的复杂度相对要比单向链表高出不止一个层级。

12010

MySQL 数据库 增删改、克隆、外 等操作

,保证数据的完整性和一致性 MySQL 六种约束 ---- 数据库中有数据表,数据表中有一条一条的记录。...查看数据库信息语句 首先登陆MySQL,也可以用SQL工具如 Navicat 远程连接,前提是要在Linux Mysql 中用 grant 进行授权,允许远程登录。...Linux 中登录Mysql mysql -u root -p密码 1.查看当前服务器中的数据库 SHOW DATABASES; 2.查看数据库中包含的表 USE 数据库名 #注意:数据库名区分大小写...如果在退出连接之前,也可以可执行增删改等操作,比如使用 DROP TABLE 语句手动直接删除临时表。...DROP TABLES HOBBY_DETAIL ; DROP TABLES HOBBY ; MySQL 六种约束 主键约束(primary key) 外约束(foreign key) 非空约束

5.8K20

常见的面试问题

阅读量: 60 1、Mysql链表概述   因为表与表之间有关系,而且查询时需要两张表的某些数据。 链表的前提是:表与表之间必须设置主外吗?   ...不是的,其实表与表之间不需要设置主外关系,用数据库语句就可以实现链表查询,删除,修改,增加等操作。 为什么要设置主外呢?   通常我们看到表与表之间有关系,常常设置主外。为什么?...假设一个不了解你表结构的人,都能够任意的修改你的外。那这个表就不严谨了。 我们到底设不设主外呢?这就要分情况: 1、如果表结构简单,少量的表。逻辑不复杂。那么这个就不需要设置主外了。...那么自己不可能记住所有主外之间的关系,那么就需要设置主外链表查询又分为:左联表,右链表。等。 链表不仅可以进行查询,还可以链表查询,链表增加,链表删除,链表修改。...在MySQL5.1和更新的版本中,InnoDB可以在服务器端过滤掉行后就释放锁,但在早期的MySQL版本中,InnoDB直到事务提交时才会解锁。对不需要的元组的加锁,会增加锁的开销,降低并发性。

74010

循环链表的增删改

循环链表与单向链表十分相似,两者唯一不同之处就是,循环链表的尾节点的next属性指向了链表的首节点(非头节点,头节点是没有数据的,头节点的下一个有数据的节点我们称为首节点)。...在循环链表中,我们增加了一个新的功能“游标”,在循环链表中可以定义一个“当前”指针,这个指针通常称为游标,可以通过这个游标来遍历链表中的所有元素,而我们不需要去动头节点的指针指向。...以下为循环链表的增删改操作,同样,我们使用了数据类型与算法分离的思路编写了代码(以下代码出自 传智播客 教师课件) #ifndef _CIRCLE_LIST_H #define _CIRCLE_LIST_H...typedef struct tag_CircleList { //循环链表头结点 CircleListNodeheader; //循环链表游标 CircleListNode*slider; //循环链表长度...1、普通插入元素(和单链表是一样的) 2、尾插法(和单链表是一样的,单链表的写法支持尾插法; 分析:辅助指针向后跳length次,指向最后面那个元素(length-1位置),因为是循环 链表,所以

11720

单向链表增删改排序操作

在讨论链表这个概念之前,我觉得有必要说一下为什么会有链表?作为一个新手如果不明白这个问题上来就盲目的写链表的代码没有任何意义,就算你现在背下来了,早晚也会忘掉。...我们上面谈到的是单向链表链表也可以做成循环的,也就是最后一个数据指向第一个数据的位置,这样整个链表中的数据就练成一个环形状了。只要找到其中一个数据,就能找到整个链表中的所有数据。...而这样带来的问题就是,分不清哪里是链表头了,所以一般情况下程序开发人员都会创建一个空的链表节点,表示这个节点是链表头。...除了单向链表、环形链表,还有双向链表,也就是一个链表中的节点不仅仅包含存储的数据和下一个数据的位置指针,还包含了上一个数据的位置指针。...下面我们就来看一下链表的实现。 单向链表非常详细的增删改操作方法,每一步都有非常详细的文字提示。特别要记录的是链表的排序,其中包含交换数据和交换指针的方法。

14320

双向链表的增,删,改,

由于单向链表只能从头遍历,那么在做增删改操作时,必须从头结点开始遍历。特别是在尾节点做追加操作时,需要将所有节点全部遍历一遍。在时间上花费较多。...但是双向链表就不存在这个问题,在对双向链表做追加操作时只需要对头结点的先序节点进行一次遍历就到达了链表的尾部。这样就大大的减少了时间上的开销。...以下是双向链表的结构示意图: 可以看出,每个节点都有两个指针,一个指向前面,一个指向后面。指向前面的叫先序节点,指向后面的叫后继结点。 我们通过这两个指针来访问所有节点,并通过他们来对链表进行操作。...双链表删除节点 以下是对应代码: voidDeleteNode(Node *head,intnum)//删除一个节点{inti =0;Node *temp =NULL;for(i=0;inext;}temp...s=45051 单链表 http://www.makeru.com.cn/live/5413_1924.html?

66030

链表】双向循环带头链表-增-删-(C语言)

---- ---- 单链表存在的缺陷: 不能从后往前走, 找不到他的前驱, 指定位置 删除 增加 尾删 都要找前一个,时间复杂度都是O(n) ---- 针对上面的这些缺陷的解决方案——双向链表。...---- 实际中要实现的链表的结构非常多样,以下情况组合起来就有8种链表结构: 单向、双向 带头、不带头——带哨兵位的头结点,这个结点不存储有效数据,好处是什么?...带头双向循环链表:结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都是带头循环双向链表,另外,这个结构虽然复杂,但是使用代码代码实现的以后会发现结构带来许多优势,实现反而简单了。...---- 带头双向循环链表 结构体创建 typedef int LSTNodeData; typedef struct ListNode { LSTNodeData data; struct ListNode...---- 打印 void DBLSTPrint(DBLSTNode* phead) { //如果链表是空的会发生错误吗? //不会。因为phead->next还是自己。

26500

MySQL日志

本文先来讲讲慢日志。 1. 是什么? MySQL日志是一种记录执行很慢的sql的日志。...MySQL中可以通过long_query_time来设置一个阀值,如果执行时间超过这个阀值,就会被认为是慢sql,就会记录到慢日志中。该阀值默认是10s,即执行超过10s的sql就会被记录。 2....开启方法: MySQL默认是没有开启慢日志的,如果不是调优需要的话,不建议开启,因为这个也会带来性能的影响。...也就是超过3s的sql到底有没有被记录到慢日志中呢?...执行结果 日志分析工具:mysqldumpslow 生产环境可能会出现很多的慢日志,如果都要手工分析,也是比较费时的,MySQL提供了慢日志分析工具,mysqldumpslow。

90310

MySQL漏补缺

漏补缺 目录 MySQL漏补缺 唯一索引比普通索引快吗, 为什么 MySQL由哪些部分组成, 分别用来做什么 MySQL查询缓存有什么弊端, 应该什么情况下使用, 8.0版本对查询缓存有什么变更....MyISAM和InnoDB的区别有哪些 MySQL怎么恢复半个月前的数据 MySQL事务的隔离级别, 分别有什么特点 做过哪些MySQL索引相关优化 简要说一下数据库范式 一千万条数据的表, 如何分页查询...订单表数据量越来越大导致查询缓慢, 如何处理 欢迎关注公众号(代码如诗) 推荐阅读 十个MySQL知识点(面试题), 漏补缺, 共同学习, 欢迎交流....InnoDB支持外, MyISAM不支持. MyISAM支持全文索引, InnoDB不支持(但可以使用Sphinx插件) MySQL怎么恢复半个月前的数据 通过整库备份+binlog进行恢复....做过哪些MySQL索引相关优化 尽量使用主键查询: 聚簇索引上存储了全部数据, 相比普通索引查询, 减少了回表的消耗.

2.3K20
领券