sql - 是为不同的商店创建不同的表更好,还是有一个带有列的表来指定哪个站点?
问题描述
我正在为不同城市的商店开发一个 mssql 数据库。是每个城市都有一张桌子更好,还是全部放在一张桌子上。我也不希望来自不同城市的用户访问不属于他们的城市的数据
解决方案
SQL 旨在处理大型表,非常大的表。它不是为处理无数小桌子而设计的。您的问题的明确答案是特定实体的所有示例都应该放在一个表中。这有很多很好的理由:
- 您希望能够编写一个查询,该查询将返回有关任何城市或所有城市的数据。如果数据在一个表中,这很容易;如果数据在多个表中,则很难。
- 您希望通过选择正确的索引和数据类型以及收集统计信息和整理索引等来优化您的查询。为什么要通过乘以表的数量来乘以工作?
- 应正确声明外键关系。如果外键可以指向多个表,则不能这样做。
- 大量小表会导致大量部分填充的数据页,这只会使数据库变大并减慢速度。
我可以继续。但是您现在可能已经知道每个实体一个表是正确的方法(至少在大多数情况下)。
您可以通过多种方式处理限制用户仅在一个城市查看数据的问题。最常见的可能就是简单地使用视图。
推荐阅读
- php - 表单特殊字符验证
- r - 如何修改 R 代码以使用 Nadaraya-Watson 估计器而不是普通的最小二乘估计器来解决回归问题?
- c++ - 无法识别的 getline
- google-cloud-platform - 使用 Google Cloud IPSec VPN 的别名子网
- angular - Angular Material - 添加后选择新选项卡 - 事先没有选项卡时出现问题
- javascript - 使用 pycparser 从 C 解析到 Javascript
- python - 熊猫重新采样 .ffill()
- constructor - 模块或名称空间未定义错误 FS0039
- python - 将 pandas 列从字符串 Quarters 和 Years 数组转换为 datetime 列
- python - 路径查找算法练习和使用 .txt 文件