首页
学习
活动
专区
圈层
工具
发布

A关联B表派生C表 C随着A,B 的更新而更新

2这个标题比较接地气,因为老板就是这样给我提需求的 先说需求: A关联B表派生C表 C随着A,B 的更新而更新 走的弯路: 关联更新,所以我的重点找到关联上去了,然后就找到了外键,看了一大波外键的文章博客...,当我成功设置好外键时候,测试删除没问题,插入不会更新,所以我一开始以为是我外键设置的问题 直到我继续找资料看到一句话: sql里的外键和主键的定义是一样的,都是代表了索引 (这句话看了好多次,第一次是设置外键时候没法设置...解决办法:——触发器 在百度大佬的帮助下我终于回归正途,触发器,插入时候触发更新 DELIMITER // CREATE TRIGGER test_tri AFTER INSERT ON test FOR...如果不设置外键约束的话,我对test操作删除时,我触发器的主体还需要添加一个delete语句(带select条件的),所以外键可以帮我约束我就很省心了!...再加一句,标题是三个表,我只写了两个表,其实原理都是一样的!会一个后面的就自由发散吧!哈哈

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

    这个可以动态更新的课程表,我用数据透视表做的!

    一直想要做一个可以动态更新的课程表。 点击左边的班级,就显示出这个班级的一周课表,而且还统计出班级学科和教师信息。...点击左边的教师,就显示出这位教师的一周课表,而且教师教的学科和班级信息也统计出来了。 前几天看了大海老师的《月历型报表》,一下子有了灵感,决定上手试一下。...- 分析 - 左边的切片器,控制中间和右边的表格,数据动态更新。 右边的表格,就是普通的数据透视表,这一步很好解决。...中间的表格,有两个问题: 一是在数据透视表的值区域显示文本,内容随切片器动态更新; 一是有一个标准的格式,“午间休息”把表格上下拆开了。...最后,右边插入数据透视表,设置切片器的”报表连接“。 实验成功,成就满满。 哈哈,以后各种文字也可以在表格任意摆放,动态更新了。

    4.3K20

    plsql 触发器教程-当表1的某条数据更新时,表2的某些数据也自动更新

    触发器-update 需求:一张表的某个字段跟随另一张表的某个字段的值更新而更新 2张表 test001表 ? test002表: ?...新建触发器,当更新test001中的D为某个值x时,test002中的D(不一定是D,也可以是C)也变成x 例如:update test001 t1 set D='7'where t1.A='1';...当我手动更新test001表中 a字段为1的那条记录 ,把d更新为7时,那么要使test002表中a字段也为1的那条记录,自动更新为7, 那么触发器可以这样写: create or replace...:new.字段表示的是在执行完某个更新操作后的那条数据记录,如果这里没有使用:new.字段而是使用 test001的话,则会报错: ?...test001 t1where t1.a =t2.a); end test02Tr; 最后,测试: update test001 t1 set D='7'where t1.A='1'; 执行完之后,2张表的

    1.6K10

    MYSQL 表的手动更新统计分析记录

    从MYSQL 5.6 开始,统计分析的信息会固化在系统的存储中,通过下面的语句可以查看我们相隔的开关是否打开。...但通常一般都是通过自动触发的方式来完成这样的工作。 而我们可以进行一个测试,关于MYSQL的索引和真是的表信息之间是否有差距。...其实我们已经操作了analyze table 但是我们依然没有得到准确的数字,在平时这可能不会有什么问题,但如果是较大的表例如上千万的表,如果这方面错的比较错,会对执行计划产生问题,这时候可能就需要我们通过手动的方式来更新某些表的记录...innodb_index_stats表里面的数据 以上方法仅仅使用于统计分析的不准确严重影响到了执行计划,一般我们还是不要动系统中的统计分析表,另外这样做的另一个问题就是, 你的表不会频繁更新的操作,...并且你要找好自己更新数值的时间点。

    4.2K30

    跨表更新,看到自己写的SQL像个憨憨

    有点 SQL 基础的朋友肯定听过 「跨表查询」,那啥是跨表更新啊?...要求将 t_dept_members 中有变化的信息更新到 t_user 表中,这个需求就是「跨表更新」啦 憨B SQL 直接被秒杀 不带脑子出门的就写出了下面的 SQL 看到身后 DBA 小段总在修仙...,于是发给了他,然后甩手回来就是这个样子: 看到这个 SQL 语句我都惊呆了,还能这样写,在无情的嘲笑下,一声 KO 我直接倒下。...死也得死的明白,咱得查查这是咋回事啊 Mysql Update Join 我们经常使用 join 查询表中具有(在 INNER JOIN 情况下)或可能没有(在 LEFT JOIN 情况下)另一个表中匹配行的表中的行...同样,在 MySQL 中, 我们也可以在 UPDATE 语句中使用 JOIN 子句执行跨表更新,语法就是这样: UPDATE T1, T2, [INNER JOIN | LEFT JOIN] T1 ON

    87110
    领券