首页 > 解决方案 > JDBC Postgres 驱动程序是否可以设置“client_encoding”以连接到数据库?

问题描述

JDBC Postgres 驱动程序是否可以设置client_encoding连接到数据库?

我正在使用 Spring(使用 JPA)并且连接信息在application.properties文件中:

spring.datasource.url=jdbc:postgresql://mypgserver.com:5432/mydb?user=myuser&password=mypass&characterEncoding=UTF-8

但是在https://jdbc.postgresql.org/documentation/head/connect.html阅读 JDBC 文档时,我没有找到名为characterEncoding.

实际上,文档中没有用于此目的的参数。

如何设置向PG服务器输入数据时使用的编码?

标签: javapostgresqljdbcspring-data-jpacharacter-encoding

解决方案


由于 Java 在内部使用 UNICODE 编码 (UTF-16),因此在 PostgreSQL JDBC 驱动程序中使用client_encoding不同的 from是不自然的。UTF8

因此,它强制client_encoding使用该值,请参阅org.postgresql.core.v3.ConnectionFactoryImpl.getParametersForStartup

private List<String[]> getParametersForStartup(String user, String database, Properties info) {
  List<String[]> paramList = new ArrayList<String[]>();
  paramList.add(new String[]{"user", user});
  paramList.add(new String[]{"database", database});
  paramList.add(new String[]{"client_encoding", "UTF8"});
  paramList.add(new String[]{"DateStyle", "ISO"});
  [...]

实际上,如果将客户端编码更改为其他任何内容, JDBC 驱动程序就会毫不含糊地表达其不满:

public void receiveParameterStatus() throws IOException, SQLException {
  // ParameterStatus
  pgStream.receiveInteger4(); // MESSAGE SIZE
  String name = pgStream.receiveString();
  String value = pgStream.receiveString();

  [...]

  if (name.equals("client_encoding")) {
    if (allowEncodingChanges) {
      if (!value.equalsIgnoreCase("UTF8") && !value.equalsIgnoreCase("UTF-8")) {
        LOGGER.log(Level.FINE,
            "pgjdbc expects client_encoding to be UTF8 for proper operation. Actual encoding is {0}",
            value);
      }
      pgStream.setEncoding(Encoding.getDatabaseEncoding(value));
    } else if (!value.equalsIgnoreCase("UTF8") && !value.equalsIgnoreCase("UTF-8")) {
      close(); // we're screwed now; we can't trust any subsequent string.
      throw new PSQLException(GT.tr(
          "The server''s client_encoding parameter was changed to {0}. The JDBC driver requires client_encoding to be UTF8 for correct operation.",
          value), PSQLState.CONNECTION_FAILURE);

    }
  }

当您将数据读入 Java 程序时,您可能会遇到编码转换问题;尝试解决那里的问题。


推荐阅读