MySQL 查看数据库中有主外键关系的表信息

MySQL
SQL:
     SELECT C.TABLE_SCHEMA            拥有者,
           C.REFERENCED_TABLE_NAME  父表名称 ,
           C.REFERENCED_COLUMN_NAME 父表字段 ,
           C.TABLE_NAME             子表名称,
           C.COLUMN_NAME            子表字段,
           C.CONSTRAINT_NAME        约束名,
           T.TABLE_COMMENT          表注释,
           R.UPDATE_RULE            约束更新规则,
           R.DELETE_RULE            约束删除规则
      FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGE C
      JOIN INFORMATION_SCHEMA. TABLES T
        ON T.TABLE_NAME = C.TABLE_NAME
      JOIN INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS R
        ON R.TABLE_NAME = C.TABLE_NAME
       AND R.CONSTRAINT_NAME = C.CONSTRAINT_NAME
       AND R.REFERENCED_TABLE_NAME = C.REFERENCED_TABLE_NAME
      WHERE C.REFERENCED_TABLE_NAME IS NOT NULL ;     

UPDATE/DELETE_RULE 类型:
 1. CASCADE: 从父表中删除或更新对应的行 同时自动的删除或更新自表中匹配的行 ON DELETE CANSCADE和ON UPDATE CANSCADE都被InnoDB所支持 
 2. SET NULL: 从父表中删除或更新对应的行 同时将子表中的外键列设为空 注意 这些在外键列没有被设为NOT NULL时才有效 ON DELETE SET NULL和ON UPDATE SET SET NULL都被InnoDB所支持 
  3. NO ACTION: InnoDB拒绝删除或者更新父表 
  4. RESTRICT: 拒绝删除或者更新父表 指定RESTRICT 或者NO ACTION 和忽略ON DELETE或者ON UPDATE选项的效果是一样的 
 5. SET DEFAULT: InnoDB目前不支持 

表信息参考列表:
  • 发表于 2017-11-13 16:47
  • 阅读 ( 1536 )
  • 分类:mysql

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
不写代码的码农
- Nightmare

33 篇文章

作家榜 »

  1. 威猛的小站长 124 文章
  2. Jonny 65 文章
  3. 江南烟雨 36 文章
  4. - Nightmare 33 文章
  5. doublechina 31 文章
  6. HJ社区-肖峰 29 文章
  7. 伪摄影 22 文章
  8. Alan 14 文章