MySQL外键应用

%ignore_a_1%,所有tables必须是InnoDB型,它们不能是临时表.因为在MySQL中只有InnoDB类型的表才支持外键.

mysql版本:5.5.28

系统平台:RHEL 5.8 32位

(1) 外键的使用:

外键的作用,主要有两个:
一个是让数据库自己通过外键来保证数据的完整性和一致性
一个就是能够增加ER图的可读性
有些人认为外键的建立会给开发时操作数据库带来很大的麻烦.因为数据库有时候会由于没有通过外键的检测而使得开发人员删除,插入操作失败.他们觉得这样很麻烦
其实这正式外键在强制你保证数据的完整性和一致性.这是好事儿.
例如:
有一个基础数据表,用来记录商品的所有信息。其他表都保存商品ID。查询时需要连表来查询商品的名称。单据1的商品表中有商品ID字段,单据2的商品表中也有商品ID字段。如果不使用外键的话,当单据1,2都使用了商品ID=3的商品时,,如果删除商品表中ID=3的对应记录后,再查看单据1,2的时候就会查不到商品的名称。
当表很少的时候,有人认为可以在程序实现的时候来通过写脚本来保证数据的完整性和一致性。也就是在删除商品的操作的时候去检测单据1,2中是否已经使用了商品ID为3的商品。但是当你写完脚本之后系统有增加了一个单据3 ,他也保存商品ID找个字段。如果不用外键,你还是会出现查不到商品名称的情况。你总不能每增加一个使用商品ID的字段的单据时就回去修改你检测商品是否被使用的脚本吧,同时,引入外键会使速度和性能下降。

(2) 添加外键的格式:

AppMall应用商店 AppMall应用商店

AI应用商店,提供即时交付、按需付费的人工智能应用服务

AppMall应用商店 56 查看详情 AppMall应用商店

说明:
on delete/on update,用于定义delete,update操作.以下是update,delete操作的各种约束类型:
CASCADE:
外键表中外键字段值会被更新,或所在的列会被删除.
RESTRICT:
RESTRICT也相当于no action,即不进行任何操作.即,拒绝父表update外键关联列,delete记录.
set null:
被父面的外键关联字段被update ,delete时,子表的外键列被设置为null.
而对于insert,子表的外键列输入的值,只能是父表外键关联列已有的值.否则出错.

外键定义服从下列情况:(前提条件)
1)
所有tables必须是InnoDB型,它们不能是临时表.因为在MySQL中只有InnoDB类型的表才支持外键.
2)
所有要建立外键的字段必须建立索引.
3)
对于非InnoDB表,FOREIGN KEY子句会被忽略掉。
注意:
创建外键时,定义外键名时,不能加引号.
如: constraint ‘fk_1’ 或 constraint “fk_1″是错误的

(3) 查看外键:

SHOW CREATE TABLE tb_name;

可以查看到新建的表的代码以及其存储引擎.也就可以看到外键的设置.
删除外键:

alter table tb_name drop foreign key ‘外键名’;

注意:
只有在定义外键时,用constraint 外键名 foreign key …. 方便进行外键的删除.
若不定义,则可以:
先输入:alter table tb_name drop foreign key –>会提示出错.此时出错信息中,会显示foreign key的系统默认外键名.—>
用它去删除外键.

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/566843.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月10日 03:49:36
下一篇 2025年11月10日 04:13:00

相关推荐

  • html5导出excel表格_使用前端库生成Excel文件【方法】

    可在%ignore_a_1%中用前端库直接生成Excel:一、SheetJS适合快速导出JSON/HTML为.xlsx;二、exceljs支持样式和公式但体积大;三、HTML表格转.xls为轻量兼容方案。 如果您希望在浏览器中直接生成并导出 Excel 文件,而无需后端参与,则可以借助轻量级前端 J…

    2025年12月23日
    200
  • html 如何弹窗_使用HTML与JavaScript实现弹窗【实现】

    需结合HTML与JavaScript实现弹窗:一、用alert/confirm/prompt;二、自定义模态框(HTML结构+CSS样式+JS控制);三、data属性传参复用;四、禁滚动并聚焦;五、Esc键关闭。 如果您希望在网页中显示一个临时的提示窗口,用于展示信息、确认操作或收集用户输入,则需要…

    2025年12月23日
    200
  • 使用CSS实现可滚动、自适应边界的Flex Wrap容器

    本教程详细阐述了如何纯粹使用CSS,创建一个可滚动且不超出父容器边界的Flex Wrap布局。核心解决方案在于结合父容器的position: relative与子容器的position: absolute、height: 100%、width: 100%及overflow: scroll属性。文章将…

    2025年12月23日
    000
  • java怎么编译运行.html_java编译运行.html方法【教程】

    Java程序的编译运行与HTML无关,需使用JDK。1. 编写HelloWorld.java文件;2. 命令行执行javac HelloWorld.java生成.class文件;3. 执行java HelloWorld运行程序。注意:HTML是网页标记语言,不能直接运行Java代码,勿将二者混淆。确…

    2025年12月23日
    000
  • html文档中含有java怎么运行_html含java运行方法【教程】

    现代浏览器不支持Java Applet,推荐通过JavaScript调用Java后端服务或使用WebAssembly运行Java代码。 如果您在HTML文档中嵌入了Java代码,但发现无法正常运行,这通常是因为现代浏览器不再支持Java小程序(Applet)或相关插件。以下是几种实现HTML中Jav…

    2025年12月23日
    000
  • 怎么运行html的applet小程序_运行html applet小程序步骤【指南】

    现代浏览器已不再默认支持Java Applet,需通过安装JRE、启用插件、使用支持NPAPI的旧版浏览器(如Firefox 52.9 ESR)、调整Java安全级别至中,并将网站添加到例外站点列表方可运行。 如果您在尝试运行HTML中的Applet小程序时遇到问题,可能是因为现代浏览器已不再默认支…

    2025年12月23日
    000
  • 解决HTML表格行间距问题的CSS技巧

    本文旨在解决%ignore_a_1%表格中因元素默认外边距导致的意外行间距问题。通过深入分析,我们发现即使应用`border-collapse: collapse;`,内部块级元素的默认外边距仍可能制造间隙。教程提供了两种有效的css解决方案:一是使用递归选择器统一清除容器内所有子元素的默认外边距;…

    2025年12月23日
    000
  • CSS多行文本截断:无省略号的实现方法

    本文将详细介绍如何在%ignore_a_1%中实现多行文本截断,同时避免显示传统的省略号。通过精确计算文本行高并设置固定容器高度,结合`overflow: hidden`属性,开发者可以实现对溢出文本的干净截断,适用于需要保持页面布局整洁的场景,尤其是在需要避免默认省略号行为时。 在网页设计中,处理…

    2025年12月23日
    000
  • 响应式图片上的标记定位:img-fluid与绝对定位的实践指南

    本教程详细阐述如何在应用了 `img-fluid` 类的响应式图片上精确叠加标记。通过引入一个相对定位的父容器,巧妙地将响应式行为作用于容器而非图片本身,并利用%ignore_a_1%的绝对定位和 `calc()` 函数,实现灵活且精准的坐标定位,尤其解决了标记尖端对齐的挑战,确保在不同屏幕尺寸下标…

    2025年12月23日 好文分享
    000
  • 纯CSS替换标签文本内容的教程

    本教程详细介绍了如何利用纯%ignore_a_1%技术替换html ` `标签的文本内容。我们将探讨两种主要方法:通过`text-indent`将原始文本移出视口,或通过`font-size`将其隐藏,然后结合`::before`伪元素插入新的可见文本。文章将提供具体的css代码示例,并强调这种纯c…

    2025年12月23日
    000
  • CSS实现动态高度内容平滑展开的技巧:使用max-height进行过渡动画

    本文探讨了在web开发中实现动态高度内容平滑展开的常见挑战。由于%ignore_a_1%无法直接对`height: auto`进行过渡动画,导致内容在显示时出现突兀的“跳跃”效果或不必要的间距。文章详细介绍了如何通过巧妙地利用`max-height`属性结合css `transition`来克服这一…

    2025年12月23日
    000
  • 使用CSS :has() 彻底自定义无原生单选按钮的表单元素

    本文详细介绍了如何利用%ignore_a_1%的`:has()`选择器,实现彻底隐藏html原生单选按钮(radio input)并对其父级标签进行完全自定义样式。核心方法是通过将原生单选按钮设置为透明并绝对定位,同时使用`:has()`选择器根据其选中状态来控制父级“元素的背景色等样式,从而在不…

    2025年12月23日
    000
  • JavaScript手风琴组件:实现单面板展开模式

    本教程详细阐述如何优化JavaScript手风琴(Accordion)组件,使其在任何时候都只允许一个面板展开。通过采用事件委托机制,并结合遍历关闭其他面板的逻辑,我们能够有效避免多个面板同时打开的问题,从而提升用户界面的清晰度和交互体验。文章将提供具体的JavaScript代码实现、相关的HTML…

    2025年12月23日
    000
  • 掌握CSS scroll-snap:解决嵌套结构下的滚动吸附问题

    本文详细介绍了%ignore_a_1% `scroll-snap`属性在多层嵌套容器中的应用方法。针对滚动容器内部存在中间层包裹子元素导致吸附失效的问题,文章阐述了如何正确配置`scroll-snap-type`于滚动容器,以及`scroll-snap-align`于吸附目标元素。通过具体代码示例,…

    2025年12月23日
    000
  • 如何解决HTML元素因滚动条导致水平对齐不一致的问题

    本教程旨在解决%ignore_a_1%在水平居中时,因其中一个元素存在滚动条而导致对齐偏差的问题。核心方案是通过精确控制滚动条的出现位置,将其限制在需要滚动的元素内部,并结合css的`box-sizing`属性,确保元素宽度计算的准确性,从而实现不同父级元素间的完美水平对齐。 在网页布局中,我们经常…

    2025年12月23日
    000
  • JavaScript 实现水平滚动菜单的初始居中定位

    本教程详细介绍了如何使用%ignore_a_1%和css构建一个基础的水平滚动菜单,并利用javascript实现菜单内容在页面加载时自动居中显示。通过精确计算滚动容器的宽度和内容宽度,我们可以动态调整`scrollleft`属性,确保用户首次访问时,菜单的中间部分能够呈现在可视区域的中心,从而提升…

    2025年12月23日
    100
  • 使用BeautifulSoup和JSON有效抓取动态加载的网页表格数据

    本教程旨在解决使用BeautifulSoup抓取网页表格时,因数据动态加载导致部分内容缺失的问题。通过分析网页背后的API请求,直接获取并解析JSON数据源,再结合BeautifulSoup提取的HTML结构信息,最终实现完整且准确的数据抓取。文章将提供详细的代码示例和实现步骤。 理解网页动态内容与…

    2025年12月23日
    400
  • 解决BeautifulSoup爬取网页表格中动态内容缺失问题

    本文旨在解决使用BeautifulSoup爬取网页表格时,因部分数据通过JavaScript动态加载导致内容缺失的问题。通过详细分析Oracle云定价页面的案例,教程将指导读者如何识别并获取隐藏在JSON API中的动态数据,并将其与BeautifulSoup解析的静态HTML内容有效整合,最终构建…

    2025年12月23日
    000
  • HTML5怎么实现进度条_HTML5进度条组件开发

    使用HTML5的标签可快速实现进度条,结合CSS和JavaScript能动态更新和美化样式;若需更高灵活性,可用div模拟进度条组件,通过JS控制宽度和文本实现自定义效果。 用HTML5实现进度条其实很简单,主要依赖 标签和少量CSS样式,再结合JavaScript动态控制值即可。如果你需要更灵活的…

    2025年12月23日
    000
  • HTML数据如何存储到数据库 HTML数据存储的技术方案比较

    直接存储原始HTML字符串最常见,适用于富文本编辑器输出等内容,实现简单、读取快,但需防范XSS和SQL注入;结构化JSON存储适合需程序化处理的场景,支持条件查询但渲染开销大;专用格式如Delta适用于协同编辑;分离存储则提升大型系统的查询性能与管理灵活性。 将HTML数据存储到数据库时,核心目标…

    2025年12月23日
    000

发表回复

登录后才能评论
关注微信