sql >> Databáze >  >> RDS >> PostgreSQL

Má ovladač JDBC Postgres způsob, jak nastavit kódování client_encoding pro připojení k databázi?

Protože Java používá interně kódování UNICODE (UTF-16), bylo by nepřirozené používat client_encoding odlišné od UTF8 v ovladači PostgreSQL JDBC.

V důsledku toho vynutí client_encoding k těmto hodnotám viz 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"});
  [...]

Ve skutečnosti, pokud se kódování klienta změní na cokoli jiného, ​​ovladač JDBC vyjadřuje své neštěstí v žádném případě:

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);

    }
  }

Pravděpodobně máte problém s převodem kódování, když čtete data do vašeho programu Java; zkuste problém vyřešit tam.




  1. Jaká je výchozí přesnost a měřítko pro číslo v Oracle?

  2. MariaDB CURRENT_TIMESTAMP() Vysvětleno

  3. Má smysl používat MySQL LIMIT 1 při dotazování na indexované/unikátní pole?

  4. Pomoc s dotazem MySql – Řádky obsahující maximum určitého sloupce z hlediska skupiny