我想使用Log4j 2通过JDBC存储一个JSON字段。这是我的配置,我无法存储到PostgreSQL JSON类型列中:
<Configuration status="WARN">
<Appenders>
<JDBC name="databaseAppender" tableName="logs.logs">
<ConnectionFactory
class="eu.dedalus.phaedra.log.appender.ConnectionFactory"
method="getDatabaseConnection" />
<Column name="id" literal="nextval('logs.logs_id_seq')" />
<Column name="date" isEventTimestamp="true" />
<Column name="level" pattern="%level" isUnicode="false" />
...
<Column name="data" ??? />
</JDBC>
</Appenders>
<Loggers>
<Root level="info">
<AppenderRef ref="databaseAppender" />
</Root>
</Loggers>
</Configuration>这是我在PostgreSQL中的元表定义:
CREATE TABLE logs (
id int4 NOT NULL,
message varchar NULL,
fullinfo varchar NULL,
"level" varchar NULL,
...
"data" json NULL,
CONSTRAINT id_logs PRIMARY KEY (id)
);我的MapMessage代码填充了一个ExtendedLogger,然后调用了ExtendedLogger的info方法:
final LoggerContext ctx = (LoggerContext) LogManager.getContext(false);
ExtendedLogger log = ctx.getLogger(clazz.getName());
MapMessage map = new MapMessage();
... // put all other data into MapMessage
map.put("data", new JSONObject()) // or JsonNode, String or whatever else
log.info(map);如何使用JDBC的PostgreSQL ConnectionFactory将“数据”字段存储到JDBC列中?是否可以使用Log4j 2?
发布于 2022-01-27 13:32:04
您可以使用"columnMapping“标记,而不是支持”参数“属性的”列“,在该属性中,可以使用'?‘插入表达式。作为标记并向json添加一个强制转换。就你而言:
<ColumnMapping name="data" pattern="%K{data}" parameter="?::json" />或者,如果数据可以是空的,它可以使用合并来检查它。它必须组合到NULLIF,因为默认情况下,未定义键的K返回一个空字符串。
<ColumnMapping name="data" pattern="%K{data}" parameter="COALESCE(NULLIF(?,''),'[]')::json" />https://stackoverflow.com/questions/70868018
复制相似问题