sql >> データベース >  >> RDS >> PostgreSQL

JDBC Postgres Driverには、データベースに接続するようにclient_encodingを設定する方法がありますか?

    Javaは内部でUNICODEエンコーディング(UTF-16)を使用するため、client_encodingを使用するのは不自然です。 UTF8とは異なります PostgreSQLJDBCドライバーで。

    その結果、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プログラムに読み込むときに、エンコード変換の問題が発生している可能性があります。そこで問題を解決してみてください。




    1. SqliteでLONGデータ型のフィールドを持つテーブルのルームエンティティを作成します

    2. Mysql:いいねで注文しますか?

    3. Jquery、PHP、Mysqlを使用したAjaxページ付け

    4. 同時にウェブインサート