- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
首先,这是我的代码结构和我想要实现的目标:
我有这 3 个表:
+----------------------+
| CONFIG_CAMPAIGN |
+----------------------+
| - id_config |
| // other fields |
+----------------------+
+----------------------+
| SLOT_CONFIG |
+----------------------+
| - id_slot_config |
| - id_config |
| - id_slot_pb |
+----------------------+
+----------------------+
| SLOT_PLACE_BOX |
+----------------------+
| - id_slot_pb |
| - id_place_box |
| - date |
| - hour |
| - slot_available |
+----------------------+
所以一个“slot_place_box”可以有多个“config”,一个“config”可以在多个“slot_place_box”上。我在“slot_config”上有一些触发器根据配置更新字段“slot_available”。
现在我有一个 PHP,我可以从中获取一些 FORM 数据并构建一个如下所示的 SQL 请求(当我遇到问题时):
INSERT INTO media.slot_place_box (id_place_box, date, hour)VALUES (32, '2017-12-10', NULL)ON DUPLICATE KEY UPDATE id_place_box = id_place_box;
SET @id = (SELECT SPB.id_slot_pb FROM media.slot_place_box as SPB WHERE SPB.id_place_box = 32 AND SPB.date = '2017-12-10' AND SPB.hour IS NULL);
INSERT INTO media.slot_config (id_config, id_slot_pb) VALUES (125, @id);
INSERT INTO media.slot_place_box (id_place_box, date, hour)VALUES (32, '2017-12-11', NULL)ON DUPLICATE KEY UPDATE id_place_box = id_place_box;
SET @id = (SELECT SPB.id_slot_pb FROM media.slot_place_box as SPB WHERE SPB.id_place_box = 32 AND SPB.date = '2017-12-11' AND SPB.hour IS NULL);
INSERT INTO media.slot_config (id_config, id_slot_pb) VALUES (125, @id);
INSERT INTO media.slot_place_box (id_place_box, date, hour)VALUES (32, '2017-12-12', NULL)ON DUPLICATE KEY UPDATE id_place_box = id_place_box;
SET @id = (SELECT SPB.id_slot_pb FROM media.slot_place_box as SPB WHERE SPB.id_place_box = 32 AND SPB.date = '2017-12-12' AND SPB.hour IS NULL);
INSERT INTO media.slot_config (id_config, id_slot_pb) VALUES (125, @id);
// and so on
我的想法是创建一个新的“slot_place_box”+“slot_config”,如果我没有根据我之前在代码中创建的新配置复制的话
或
如果我已经有一个具有相同“id_place_box + date + hour”的“slot_place_box”,我只插入一个新的“slot_config”,其中包含 new_config id + 我已有的“slot_place_box”。
我选择“INSERT...ON DUPLICATE KEY/do nothing/”因为我需要我插入的行的 ID/我已经有了。
我在“slot_place_box”中为字段“id_place_box + date + hour”有一个唯一索引键。我的问题开始是因为“小时”可以是一个小时(例如“12:00:00”)但也可以是 NULL(= 对我来说,当 NULL 时它意味着“日期”的“全天”)。当 hour 为 NULL 时,我的 UNIQUE 索引不起作用,因此 INSERT 发生并且我在数据库中有重复项。
那么我怎样才能使这个“INSERT...ON DUPLICATE KEY UPDATE”与具有 NULL 值的 UNIQUE 索引一起工作?
我不能使用此解决方案 (here),因为我使用 MySQl 5.6,所以我将尝试按照有人在我上一个问题 (here) 中建议的方式创建触发器。
我是 SQL 初学者,所以我需要一些帮助来实现这个触发器。如果我理解得很好,这个想法是用触发器创建一些“虚拟”列,如果“小时”为空,则在其中添加一些值 + 在我的 UNIQUE 索引中添加这个虚拟列,这样 ON DUPLICATE KEY 就可以工作了。
所以我的问题是:
最佳答案
我会自己回答,但如果你们有其他解决方案,我仍然很想听听。这个解决方案对我有用,因为我正在处理一个新项目,所以它不会真正影响我已经编写的代码。
为了解决这个问题,我在“slot_place_box”表中添加了一个新列:
+----------------------+
| SLOT_PLACE_BOX |
+----------------------+
| - id_slot_pb |
| - id_place_box |
| - date |
| - hour |
| - slot_available |
| - virtual_hour | <- new field
+----------------------+
这个新字段是一个 VARCHAR(10),如果不为 NULL(例如:“12:00:00”),则等于“hour”,或者默认情况下等于“1”,或者当“hour”为 NULL 时。
然后我将此表上的 UNIQUE 索引更改为“id_place_box + date + virtual_hour”,这样我就永远不会得到 NULL 值。然后我更新表中已有的数据:
UPDATE slot_place_box SET (virtual_hour = IF(hour is NULL, '1', hour);
// Without the safe UPDATE (I use MySQL WorkBench)
我更改我的 PHP 循环以使用新列构建我的请求:
foreach($SPB_data_array as $index => $SPB_data) {
$current_id_pb = $SPB_data['id_pb'];
$current_date = $SPB_data['date'];
if (!empty($SPB_data['hour'])) {
$current_hour = $SPB_data['hour'];
$sql_slot_pb .= 'INSERT INTO media.slot_place_box (id_place_box, date, hour, virtual_hour) VALUES ('. $current_id_pb .', \''. $current_date .'\', \''. $current_hour .'\', \''. $current_hour .'\')
ON DUPLICATE KEY UPDATE id_place_box=id_place_box;
SET @id = (SELECT SPB.id_slot_pb FROM media.slot_place_box as SPB
WHERE SPB.id_place_box = '. $current_id_pb .' AND SPB.date = \''. $current_date .'\' AND SPB.hour = \''. $current_hour .'\');
INSERT INTO media.slot_config (id_config, id_slot_pb) VALUES (:new_config_id, @id);
';
} else {
$sql_slot_pb .= 'INSERT INTO media.slot_place_box (id_place_box, date, hour) VALUES ('. $current_id_pb .', \''. $current_date .'\', NULL)
ON DUPLICATE KEY UPDATE id_place_box=id_place_box;
SET @id = (SELECT SPB.id_slot_pb FROM media.slot_place_box as SPB
WHERE SPB.id_place_box = '. $current_id_pb .' AND SPB.date = \''. $current_date .'\' AND SPB.hour IS NULL);
INSERT INTO media.slot_config (id_config, id_slot_pb) VALUES (:new_config_id, @id);
';
}
}
当“hour”不为 NULL 时,我刚刚添加了带有“hour”值的第四列,默认情况下“virtual_hour”为“1”,因此在这种情况下无需添加它。
我不知道这是否是具有大量数据的大型项目的最佳解决方案,但就我而言,这是解决我的问题的最简单方法。
关于php - 在唯一键上使用空值执行 "INSERT...ON DUPLICATE KEY UPDATE"的变通解决方案,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47676253/
我有一个内部表,里面有 108 个条目。从 9 到 9 个条目重复条目,我想删除这些重复项。由于它们完全相同,我使用了 delete adjacent duplicates from itab com
在 Team Foundation Server (TFS) 中链接两个工作项 (WI) 时,在什么情况下将“Duplicate”和“Duplicate Of”区分为“链接类型”是有意义的? 如何处理
ld: duplicate symbol _velocityX in \ /Users/Student/Library/Developer/Xcode/DerivedData/finalproject
我使用 PHP 和 Mysql。 此 SQL 有效: INSERT INTO products (id, title, description) VALUES (10, 'va
我有一个大数据框 (120000x40),我尝试在每一行中找到重复项并显示它们。这就是我的尝试: 创建数据框 import pandas as pd df = pd.DataFrame({'col1'
我是 mySQL 和 PHP 的新手,请多多包涵。 如果我的查询有重复字段,我该如何做到这一点,检索到的数据将具有重复查询字段的重复数据。 一个例子是这样的: 查询 id = 34, 54, 21,
我一直遇到这个错误,但我无法理解它,因为它提示一个值恰好出现一次。 Exception in thread "main" java.lang.IllegalStateException: Duplic
我有一个带有 Vuejs 和 Laravel 的 Web 应用程序 我想使用 CKEditor 5 我安装了依赖项 npm install --save @ckeditor/ckeditor5-vue
我有一个包含以下数据的 csv 文件: Id,Name,Type,date 1,name1,employee,25/04/2017 2,name2,contrator,26/04/2017 3,nam
import CKEditor from '@ckeditor/ckeditor5-react'; import ClassicEditor from '@ckeditor/ckeditor5-bui
表定义: CREATE TABLE PositionalDataNGS ( Date DATE, Time TIME(3) , X FLOAT(5), Y FLOAT(5), D FLOAT(5) ,
我目前正在做一个项目,我要处理数以千计的数据包。现在,我记录每个数据包的 IP 和 MAC 地址以及一些其他信息。为了存储所有这些,我使用 MySQL 并且我的脚本是用 Node.js 编写的。目前我
I am using MySQL 5.1.56, MyISAM. My table looks like this:我使用的是MySQL 5.1.56,MyISAM。我的桌子是这样的: CR
我是新来的,对 SQL 比较陌生。我有一个类似这样的表: [Pk], [Case_No], [Status], [Open_Date], [Close_Date], [Case_Age], [Repo
为什么会收到此警告? warning No duplicate props allowed react/jsx-no-duplicate-props# 它显示的是第28行,但没有使用 Prop 。 最
是否有任何函数或方法可以在 python 2.7 中递归实现此目的? Input : ['and', ['or', 'P', '-R', 'P'], ['or', '-Q', '-R', 'P']]
我正在分析 hadoop 中的数据。有一些重复条目,其中 A、B 列重复,而 C 列不同。我想要做的是仅识别 A、B 重复项,然后为每个重复项打印出 C 列的不同值。 示例数据: row, data
您好,感谢阅读并可能对我有所帮助 我的问题的简要说明: 我正在将数据从一个 Firebird 数据库复制到另一个(称为 V14),并且我正在使用 IBExpert 来执行此操作。这些表的名称相同并且具
我想制作一张很像下面的图片: 我想使用 seaborn 使图表看起来漂亮,并让我自己以后更容易使用 facetgrids(我有十个不同的数据集,我想在同一个图表中显示。) 我在 seaborn 中找到
我在两列“user_id”和“project_id”上有一个复合唯一键。 当我尝试对单行或多行运行 DELETE 查询时,出现错误。 ERROR 1062: 1062: Duplicate entry
我是一名优秀的程序员,十分优秀!