我正在我的服务器上运行一种论坛修改代码。在我的数据库中,我有一个名为 的巨大表core
,它基本上包括所有管理员可编辑的设置,其中有很多。我的问题是,我应该标准化吗?
我创建了一个小提琴来向您展示这张表有多大:http ://sqlfiddle.com/#!2/f4536/1
您会看到一些名为gear_notifications
、gear_bank
等的列gear_*
。这些表示某个系统是否已打开。例如,如果gear_bank=1
,则银行系统已打开。目前,在__construct
我的数据库文件中,我运行以下查询:
$settings = mysql_query("SELECT GROUP_CONCAT(d.domain) AS domains, GROUP_CONCAT(d.zb) AS zb_info, c.* FROM core c JOIN domains d ON d.cid = c.id WHERE c.id ='$cid' LIMIT 1");
忽略JOIN
你可以马上看到这里的问题;查询返回core
表中的每个字段,无论相应的系统是否打开。例如,如果gear_bank=0
,查询仍将返回bank_name
,bank_history_perpage
等bank_*
。虽然这不会对代码的运行方式造成任何物理问题(因为它可以忽略任何不需要的数据),但我更喜欢它没有不必加载该数据。
我会更好地创建一个名为的表core
,其中包含所有gear_*
值,然后为它们的相应值创建相应的表(core_bank
等core_*
)吗?
我一直在查询这个(糟糕的双关语,对不起!),我只是不知道这是否会为我的代码提供性能提升。请注意,上述查询将在每个页面上运行。
如果我要恢复到新系统,即多个表,我将如何获得我需要的所有信息?我不想运行一个查询来core
确定打开了哪些系统,然后在所有相应的表上运行一个额外的查询。我更喜欢一个查询,它JOIN
是基于gear_*
in值的所有必要表core
。那可能吗?
我还没有发布这个论坛修改,所以我可以在没有任何实际影响的情况下进行尽可能多的更改:)
。