- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在创建一个 PHP 脚本来比较两个数据库的架构。
我已经设法检查有关删除/添加的表、列、索引、引用的架构更改,但是当涉及到重命名的列时,我有点卡住了。
在以下示例中,源数据库包含最新的架构,而目标数据库包含类似的架构但可能已过时。
先决条件:
以目标数据库中的以下架构为例。
Field Type Null Key Default Extra
field1 int(11) NO NULL
field2 int(11) NO NULL
field3 int(11) NO NULL
然后在源数据库中假设以下架构。
Field Type Null Key Default Extra
field1 int(11) NO NULL
field4 int(11) NO NULL
field3 int(11) NO NULL
在不明确知道发生了什么的情况下,我无法确定 field2
是否通过 DROP、ADD AFTER
或更改列
。以下两个查询在表结构方面实现了相同的结果,但是使用前者会丢失数据。
(1) ALTER TABLE `demo` DROP `field2`
ALTER TABLE `demo` ADD `field4` INT( 11 ) NOT NULL AFTER `field1`
(2) ALTER TABLE `demo` CHANGE `field2` `field4` INT( 11 ) NOT NULL
我显然可以删除旧列名并创建一个新列名,但这样会丢失原始列中的所有数据。我需要使用 ALTER TABLE table CHANGE COLUMN field new_name structure;
查询而不是 DROP column FROM table
后跟 ALTER TABLE table
添加列定义;
我希望我可以使用 DDL 触发器来跟踪架构中的更改并将此类更改的记录插入到源数据库中的表中。稍后我可以查询此表以确定某个列是如何形成的。但是,据我所知,不可能在 MySQL 中的 DDL 查询上运行触发器,从而排除记录这些更改的可能性。我在 MySQL Forge(现在位于 MySQL 开发者专区)上阅读了这个工作日志 (WL#2418: DDL Triggers),但不幸的是,它似乎仍在等待实现。
有没有一种方法可以更新表以匹配关于重命名列的架构而不会丢失数据?
我看过 MySQLDiff 之类的东西但它需要内置到现有的代码中,所以我必须自己构建它。
为每一列添加一个注释,它是一个唯一的数字或字符串(为了参数,将其称为哈希)。查询 information_schema 表以检索此值并在每一列上进行比较。如果它是唯一的,那么它就是一个新列,或者如果它匹配一个哈希而不是一个名称或结构,那么它就被重命名/重新配置了。
比较架构,如果有新列 - 检查它相对于相邻列的位置。如果新列的名称与缺少的列的名称相同,则比较该列的结构。如果匹配,请考虑将其重命名。如果没有,请考虑将其删除然后添加。
最佳答案
没有办法检测到这一点,但如果您的本地机器需要这个,那么有办法做到这一点。
表
mysql.general_log
表中。SELECT * FROM mysql.general_log WHERE argument LIKE 'ALTER%'
的查询,为您提供与数据库修改相关的所有 SQL 语句,包括列重命名。希望对您有所帮助..
关于php - MySQL DDL 触发器,用于列重命名的差异表模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8519600/
我正在尝试使用谷歌浏览器的 Trace Event Profiling Tool分析我正在运行的 Node.js 应用程序。选择点样本后,我可以在三种 View 之间进行选择: 自上而下(树) 自上而
对于一个可能是菜鸟的问题,我们深表歉意,但尽管在 SO 上研究了大量教程和其他问题,但仍找不到答案。 我想做的很简单:显示一个包含大量数据库存储字符串的 Android ListView。我所说的“很
我已经开始了一个新元素的工作,并决定给 Foundation 5 一个 bash,看看它是什么样的。在创建带有水平字段的表单时,我在文档中注意到的第一件事是它们使用大量 div 来设置样式。所以我在下
我有一个 Windows 窗体用户控件,其中包含一个使用 BeginInvoke 委托(delegate)调用从单独线程更新的第 3 方图像显示控件。 在繁重的 CPU 负载下,UI 会锁定。当我附加
我有一堆严重依赖dom元素的JS代码。我目前使用的测试解决方案依赖于 Selenium ,但 AFAIK 无法正确评估 js 错误(addScript 错误不会导致您的测试失败,而 getEval 会
我正在制作一款基于滚动 2D map /图 block 的游戏。每个图 block (存储为图 block [21][11] - 每个 map 总共 231 个图 block )最多可以包含 21 个
考虑到以下情况,我是前端初学者: 某个 HTML 页面应该包含一个沉重的图像(例如 - 动画 gif),但我不想强制客户缓慢地等待它完全下载才能享受一个漂亮的页面,而是我更愿意给他看一个轻量级图像(例
我正在设计一个小软件,其中包括: 在互联网上获取资源, 一些用户交互(资源的快速编辑), 一些处理。 我想使用许多资源(它们都列在列表中)来这样做。每个都独立于其他。由于编辑部分很累,我想让用户(可能
我想比较两个理论场景。为了问题的目的,我简化了案例。但基本上它是您典型的生产者消费者场景。 (我关注的是消费者)。 我有一个很大的Queue dataQueue我必须将其传输给多个客户端。 那么让我们
我有一个二元分类问题,标签 0 和 1(少数)存在巨大不平衡。由于测试集带有标签 1 的行太少,因此我将训练测试设置为至少 70-30 或 60-40,因此仍然有重要的观察结果。由于我没有过多地衡量准
我是一名优秀的程序员,十分优秀!