微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决JDBC Postgres驱动程序是否可以设置“ client_encoding”以连接到数据库?

JDBC Postgres驱动程序是否可以设置=(A2-B2)*C2 来连接数据库

我使用的是Spring(带有JPA),并且连接信息位于client_encoding文件中:

application.properties

但是在https://jdbc.postgresql.org/documentation/head/connect.html阅读JDBC文档时,我没有找到名为spring.datasource.url=jdbc:postgresql://mypgserver.com:5432/mydb?user=myuser&password=mypass&characterEncoding=UTF-8 的参数。

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

在将数据输入到PG服务器时,如何设置要使用的编码?

解决方法

由于Java在内部使用UNICODE编码(UCS-2),因此在PostgreSQL JDBC驱动程序中使用与client_encoding不同的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"});
  [...]

实际上,如果将客户端编码更改为其他任何内容,则the JDBC driver expresses its unhappiness的含义不确定:

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程序时,您可能会遇到编码转换问题。尝试在那里解决问题。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。