在 PHP 7.4 、MySQL 5.7 中,插入 json 类型的字段,成功插入值 string(4) “null” 的分析(与 json_encode(null) 有关)
1、在 MySQL 表,字段类型为 json,允许为 NULL。如图12、由于在程序中仅判断了 is_null(),如果不为 NULL,则默认为 json 格式。当其值为 string(4) “null” 时,程序抛出 500 异常。显示为 null,表示其值为 string(4) “null”,不符合预期。显示为 (Null),表示其值为 NULL,符合预期。如图23、从日志中查看生成的 SQL,确认在更改表中记录中,赋值为 ‘null’。如图34、打印生成 SQL 处的相关变量的变化情况。结果如下。如图45、由此得出结论,当 json_encode(null) 时,会返回 ‘null’,并且最终会 SQL 更新为值 ‘null’。决定调整如下,添加判断,当不为 NULL 时,才执行 json_encode,否则返回 NULL
CREATE TABLE `table` (
`schema` json DEFAULT NULL COMMENT '主题的Schema,包括页面、主题级别、组件级别',
);
update
`table`
set
`schema` = 'null',
`checksum` = '0821db9eefeab3d74bbbac6f58cd68e4c8f1b9e2',
`table`.`updated_at` = '2023-04-21 03:41:48'
where
`id` = 432070
$schema1 = $themeAsset->schema;
$schema2 = $this->themeSettingMigration->migrateJsonTemplate($filename, $schema, $themeInstallationTask, $availableVersions);
$themeAsset->schema = json_encode($schema2);
Log::info(
$themeAsset->id,
[
'schema1' => $schema1,
'schema2' => $schema2,
'schema3' => $themeAsset->schema,
]
);
[2023-04-21 11:41:48] local.INFO: 432062 {
"schema1": null,
"schema2": null,
"schema3": "null"
}
$schema = $this->themeSettingMigration->migrateJsonSettingsData($configSettingsDataSchema, $themeInstallationTask, $availableVersions);
$configSettingsData->schema = $schema ? json_encode($schema) : null;



