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