要不要使用外键? - 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 Mar 13, 2013 8640 views
    This topic created in 4808 days ago, the information mentioned may be changed or developed.
    1. 要:
    保证数据完整性

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

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

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

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

    互联网产品,就几个文章的东西,就算再复杂的文章,基本上为了性能,用冗余,不用外键。但有一些强约束的地方,就必须用外键。
    saharabear
        12
    saharabear  
       Mar 17, 2013
    补充一下,银行和金融也不只是用DB2的,也有Oracle和MySQL。
    wd
        13
    wd  
       Mar 17, 2013
    外键是用来限制数据完整性的(包括插入和删除的时候),如果你对这个要求没那么高,那么可以不要,还能节省一些性能。
    daweiba
        14
    daweiba  
       Mar 17, 2013
    i36lib
        15
    i36lib  
       Apr 15, 2016
    从 Oracle 企业实施套件( Oracle EBS )学来的经验,不用,只是在代码罗就里面保证这种约束。
    i36lib
        16
    i36lib  
       Apr 15, 2016
    但是要求文档或者注释要及时跟上,不然难以维护。
    About     Help     Advertise     Blog     API     FAQ     Solana     1789 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 56ms UTC 16:18 PVG 00:18 LAX 09:18 JFK 12:18
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86