- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在开发一个系统,以前的开发人员喜欢在单个单元格中保存多个值。请参阅下面的 DDL:
create table visits (id int, values varchar(100))
INSERT INTO visits values (1, '01/01/2000, 1')
INSERT INTO visits values (2, '01/01/2000, 2')
INSERT INTO visits values (3, '01/01/2000, 3')
第 1 行表示客户 1 在 01/01/2000 访问了商店。第 2 行表示在 01/01/2000,客户 2 访问了商店等......
我知道这很糟糕。我想不出一个合理的方法来解决这个问题,因为应用程序有很多拆分“值”内容的数组。我想这样做:
create table visits (id int, visitdate datetime, customerid int)
但是,这样做会导致错误,因为拆分值列的数组只包含一个值而不是两个。我相信我必须重构整个代码库来解决这个问题,即删除数组。但是,还有其他解决方法吗?
最佳答案
您可以使用插入、更新和删除触发器创建 SQL View 。 View Select 语句连接重构表以提供单个“值”列。重构后的表可以使用原子值列进行适当的规范化。
View 的 Insert 和 Update 语句具有将旧的单值列转换为个别专栏。删除 View 会删除底层基表行。
因此,SQL View 为您提供了一层隔离和封装,因此您无需重构遗留代码。重构可以根据需要以增量方式进行。使用 View 的性能应该是可比较的。 SQL 优化器会处理这个问题。可能的开销是连接和取消连接值的函数。
对于重构表,具有原子值的列允许您创建更具选择性的索引。它们可用于加速一些关键查询。
关于sql - 糟糕的数据库设计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17284488/
我想在这里说的是我在从之前离开的相同状态重新启动我的应用程序时遇到的问题。我在这方面做了很多研发,并且已经解决了 stackoverflow 中发布的问题。所以请不要说它是重复的。 我试过设置这些选项
当我在我的类中实现 __cmp__ 函数时,python 是否会在内部重载“==”,我们在 C++ 中是如何做到的? 只是好奇。我是 python 的新手。 :) 最佳答案 ==的含义当您定义 __c
我在 Raspberry Pi2 上安装了 Gitlab,几个月来它运行良好。但自从关闭了RPi的电源后,它就不再起作用了。网页返回502错误。 502 Whoops, GitLab is takin
有人知道用户登陆带有Webfonts的页面时为什么Google Chrome浏览器崩溃吗 它并不会一直发生,而是经常发生 我刚得到一个蓝屏页面,却不知道为什么:该页面不是来自重定向时就很好了。 这是我
当我登录时,Skype始终会给出此错误。 糟糕,Skype存在问题。尝试注销然后重新登录。 STARTUP_LOAD_ERROR MACBOOK 最佳答案 Macbook 用户 退出Skype 回家
我正在尝试从 flutter 开始,首先我在 cmd 上运行 flutter doctor 它有效。在我安装了 ANDROID SDK 之后,同样的命令 flutter doctor 给了我异常:
从 android studio 终端运行 flutter attach 不工作。显示错误flutter 意外退出。 终端输出: flutter attach Checking for adverti
当使用 TinyMCE 4 测试所有浏览器时,Chrome 非常慢。 (我尝试从 TinyMCE 中删除所有插件,但没有任何区别。) Chrome 需要大约 20-25 秒在 TinyMCE 中呈现一
我试图让下面的脚本工作,以便从远程服务器(服务器 1)读取特定目录中的 CSV 文件列表,并将数据移植到另一台服务器的 PostgreSQL 数据库中。 我已经创建了一个 rsa SSH key 并将
在嵌入式 linux 环境中(在 PowerPC 上定制的 2.4.25)几个小时后我得到以下内核 panic : Oops: kernel access of bad area, sig: 11 N
在将现有 Node.js (Hapi.js) + RethinkDB 从 OVH VPS(最小 vps)迁移到 AWS Lambda( Node )+ DynamoDB 的过程中,我最近遇到了一个非常
我是一名优秀的程序员,十分优秀!