V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
MySQL 5.5 Community Server
MySQL 5.6 Community Server
Percona Configuration Wizard
XtraBackup 搭建主从复制
Great Sites on MySQL
Percona
MySQL Performance Blog
Severalnines
推荐管理工具
Sequel Pro
phpMyAdmin
推荐书目
MySQL Cookbook
MySQL 相关项目
MariaDB
Drizzle
参考文档
http://mysql-python.sourceforge.net/MySQLdb.html
darasion
V2EX  ›  MySQL

要不要使用外键?

  •  
  •   darasion · 2013-03-13 10:27:05 +08:00 · 7728 次点击
    这是一个创建于 4277 天前的主题,其中的信息可能已经有所发展或是发生改变。
    1. 要:
    保证数据完整性

    2. 不要:
    容易开发和维护
    16 条回复    2016-04-15 12:15:20 +08:00
    workaholic
        1
    workaholic  
       2013-03-13 10:59:39 +08:00
    看应用规模了,数据量太大就要考虑性能了
    pythonee
        2
    pythonee  
       2013-03-13 17:07:17 +08:00
    我司没有用,完全拿数据库当NoSQL使,奶奶的
    zhuf
        3
    zhuf  
       2013-03-13 17:56:01 +08:00
    不要
    zenwong
        4
    zenwong  
       2013-03-13 18:00:21 +08:00   ❤️ 1
    个人认为外键这种东西是理想化情况下的东西,在实际开发中你可能遇到需求上的一些问题,使你无法理想化
    zerox
        5
    zerox  
       2013-03-13 21:36:43 +08:00
    反正我司是不使用外键的,从头到尾没人提过这事,总的来说是有性能影响的,不用的话也没觉得有什么问题。ls说的好,外键是理想化情况下的东西
    zer4tul
        6
    zer4tul  
       2013-03-16 04:45:06 +08:00
    数据规模小,要求开发效率的话,可以用。
    数据规模大的话就不要用了,对执行效率的影响挺大。另外就是dump出来source的时候麻烦。
    hilyjiang
        7
    hilyjiang  
       2013-03-16 08:57:16 +08:00   ❤️ 1
    1. 要
    开发及测试环境使用,有助于保证生产环境中的数据完整性

    2. 不要
    生产环境中,考虑性能问题,可以删除外键约束
    zer4tul
        8
    zer4tul  
       2013-03-16 10:25:01 +08:00
    @hilyjiang 开发和测试环境使用外键,但是生产环境不使用,怎样保证生产环境中的数据完整性?没看明白,求解释。
    atom
        9
    atom  
       2013-03-16 10:39:57 +08:00
    我司也是从来不用外键,我司更看重事务。
    binjoo
        10
    binjoo  
       2013-03-17 09:09:47 +08:00
    总感觉外键很麻烦。。
    saharabear
        11
    saharabear  
       2013-03-17 09:20:36 +08:00
    咱们这里讨论问题不加前提条件的吗?

    银行,金融业务能不加外键吗?

    个别时候银行金融业务是开发过程用外键,运行环境部署删除外键。不过大部分都会强制主外键约束。

    互联网产品,就几个文章的东西,就算再复杂的文章,基本上为了性能,用冗余,不用外键。但有一些强约束的地方,就必须用外键。
    saharabear
        12
    saharabear  
       2013-03-17 09:21:23 +08:00
    补充一下,银行和金融也不只是用DB2的,也有Oracle和MySQL。
    wd
        13
    wd  
       2013-03-17 12:41:42 +08:00
    外键是用来限制数据完整性的(包括插入和删除的时候),如果你对这个要求没那么高,那么可以不要,还能节省一些性能。
    daweiba
        14
    daweiba  
       2013-03-17 15:38:11 +08:00
    i36lib
        15
    i36lib  
       2016-04-15 12:14:17 +08:00
    从 Oracle 企业实施套件( Oracle EBS )学来的经验,不用,只是在代码罗就里面保证这种约束。
    i36lib
        16
    i36lib  
       2016-04-15 12:15:20 +08:00
    但是要求文档或者注释要及时跟上,不然难以维护。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   4137 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 10:18 · PVG 18:18 · LAX 02:18 · JFK 05:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.