PostgreSQL e encoding "UTF8" has no equivalent in "LATIN1"

5 respostas
R

Senhores, tenho uma rotina que em base de “desenvolvimento” está OK, mas quando a executo em “produção” o seguinte erro é apresentado. A rotina nada mais é do que um INSERT.

Abaixo segue o encoding de cada servidor.

ENCODING = ‘WIN1252’ “BASE DE DESENVOLVIMENTO”
ENCODING = ‘LATIN1’ “BASE DE PRODUÇÃO”

ERROR: character 0xefbfbd of encoding "UTF8" has no equivalent in "LATIN1"
PrintStackTrace: 
org.postgresql.util.PSQLException: ERROR: character 0xefbfbd of encoding "UTF8" has no equivalent in "LATIN1"
	at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:1512)
	at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1297)
	at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:188)
	at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:437)
	at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:353)
	at org.postgresql.jdbc2.AbstractJdbc2Statement.executeUpdate(AbstractJdbc2Statement.java:307)
	at org.apache.commons.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedStatement.java:101)
	at br.com.undertaker.model.dao.ImportComissaoDAO.insert(ImportComissaoDAO.java:198)
	at br.com.undertaker.model.bdo.ImportBDO.processFileComissao(ImportBDO.java:129)
	at br.com.undertaker.model.bdo.ImportBDO.processFile(ImportBDO.java:51)
	at br.com.undertaker.model.bdo.ImportBDO.readFile(ImportBDO.java:40)
	at br.com.undertaker.model.bdo.ImportBDO.insert(ImportBDO.java:31)
	at br.com.undertaker.controller.action.ImportAction.upload(ImportAction.java:57)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:269)
	at org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:170)
	at org.apache.struts.chain.commands.servlet.ExecuteAction.execute(ExecuteAction.java:58)
	at org.apache.struts.chain.commands.AbstractExecuteAction.execute(AbstractExecuteAction.java:67)
	at org.apache.struts.chain.commands.ActionCommandBase.execute(ActionCommandBase.java:51)
	at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
	at org.apache.commons.chain.generic.LookupCommand.execute(LookupCommand.java:304)
	at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
	at org.apache.struts.chain.ComposableRequestProcessor.process(ComposableRequestProcessor.java:283)
	at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
	at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
	at br.com.locaweb.tomcat.LocaWebValve.invoke(LocaWebValve.java:134)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261)
	at org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:190)
	at org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:283)
	at org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:767)
	at org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:697)
	at org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:889)
	at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:686)
	at java.lang.Thread.run(Thread.java:619)

5 Respostas

M
robinsonbsilva:
Senhores, tenho uma rotina que em base de "desenvolvimento" está OK, mas quando a executo em "produção" o seguinte erro é apresentado. A rotina nada mais é do que um INSERT.

Abaixo segue o encoding de cada servidor.

ENCODING = 'WIN1252' "BASE DE DESENVOLVIMENTO"
ENCODING = 'LATIN1' "BASE DE PRODUÇÃO"

ERROR: character 0xefbfbd of encoding "UTF8" has no equivalent in "LATIN1"
PrintStackTrace: 
org.postgresql.util.PSQLException: ERROR: character 0xefbfbd of encoding "UTF8" has no equivalent in "LATIN1"
	at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:1512)
	at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:1297)
	at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:188)
	at org.postgresql.jdbc2.AbstractJdbc2Statement.execute(AbstractJdbc2Statement.java:437)
	at org.postgresql.jdbc2.AbstractJdbc2Statement.executeWithFlags(AbstractJdbc2Statement.java:353)
	at org.postgresql.jdbc2.AbstractJdbc2Statement.executeUpdate(AbstractJdbc2Statement.java:307)
	at org.apache.commons.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedStatement.java:101)
	at br.com.undertaker.model.dao.ImportComissaoDAO.insert(ImportComissaoDAO.java:198)
	at br.com.undertaker.model.bdo.ImportBDO.processFileComissao(ImportBDO.java:129)
	at br.com.undertaker.model.bdo.ImportBDO.processFile(ImportBDO.java:51)
	at br.com.undertaker.model.bdo.ImportBDO.readFile(ImportBDO.java:40)
	at br.com.undertaker.model.bdo.ImportBDO.insert(ImportBDO.java:31)
	at br.com.undertaker.controller.action.ImportAction.upload(ImportAction.java:57)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:269)
	at org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:170)
	at org.apache.struts.chain.commands.servlet.ExecuteAction.execute(ExecuteAction.java:58)
	at org.apache.struts.chain.commands.AbstractExecuteAction.execute(AbstractExecuteAction.java:67)
	at org.apache.struts.chain.commands.ActionCommandBase.execute(ActionCommandBase.java:51)
	at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
	at org.apache.commons.chain.generic.LookupCommand.execute(LookupCommand.java:304)
	at org.apache.commons.chain.impl.ChainBase.execute(ChainBase.java:190)
	at org.apache.struts.chain.ComposableRequestProcessor.process(ComposableRequestProcessor.java:283)
	at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1913)
	at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:462)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:710)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
	at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
	at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
	at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:230)
	at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
	at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
	at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:104)
	at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
	at br.com.locaweb.tomcat.LocaWebValve.invoke(LocaWebValve.java:134)
	at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261)
	at org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:190)
	at org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:283)
	at org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:767)
	at org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:697)
	at org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:889)
	at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:686)
	at java.lang.Thread.run(Thread.java:619)

Olá.
Poderia postar a rotina por favor?

[]'s
JL

R

É um INSERT simples.

public void insert(ImportComissao dto) throws DAOException {

		StringBuffer sql = new StringBuffer("");
		sql.append("INSERT INTO a3_importComissao(idBaixa, idVendedor, operadora, numeroProposta, cliente, dataAdesao, parcela, dataPagto, valorPago, porcComissao, valorComissao, porcDesconto, valorDesconto, valorLiquido)VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)");

		PreparedStatement stmt = null;

		try {
			int i = 1;
			dto.setId(getNextId());
			stmt = ConnectionPool.getConnection(getRequest()).prepareStatement(sql.toString());
			stmt.setObject(i++, dto.getId());
			stmt.setObject(i++, dto.getIdVendedor());
			stmt.setObject(i++, dto.getOperadora());
			stmt.setObject(i++, dto.getNumeroProposta());
			stmt.setObject(i++, dto.getCliente());

			if(dto.getDataAdesao().equals("")){
				stmt.setObject(i++, null, java.sql.Types.DATE);
			}else{
				stmt.setObject(i++, util.parseDataBra(dto.getDataAdesao()), java.sql.Types.DATE);
			}

			stmt.setObject(i++, dto.getParcela());

			if(dto.getDataPagto().equals("")){
				stmt.setObject(i++, null, java.sql.Types.DATE);
			}else{
				stmt.setObject(i++, util.parseDataBra(dto.getDataPagto()), java.sql.Types.DATE);
			}

			stmt.setObject(i++, dto.getValorPago());
			stmt.setObject(i++, dto.getPorcComissao());
			stmt.setObject(i++, dto.getValorComissao());
			stmt.setObject(i++, dto.getPorcDesconto());
			stmt.setObject(i++, dto.getValorDesconto());
			stmt.setObject(i++, dto.getValorLiquido());
			stmt.executeUpdate();
			ConnectionPool.getConnection(getRequest()).commit();
		} catch (SQLException e) {
			try {
				ConnectionPool.getConnection(getRequest()).rollback();
			} catch (SQLException e1) {
				throw new DAOException(e1.getMessage(), e);
			}
			throw new DAOException(e.getMessage(), e);
		} catch (ParseException e) {
			throw new DAOException(e.getMessage(), e);
		} finally {
			ConnectionPool.closeAll(null, stmt);
			stmt = null;
			sql = null;

		}

	}
M

Certamente nesse insert deve ter algum nome acentuado, ou com algums caracter especial.
Na URL de conexão com o banco, você passa que enconder?

[]'s
JL

R

então o encoding do banco de dados, tanto em desenvolvimento, com em produção estão idênticos:
CREATE DATABASE nome_banco ENCODING = ‘WIN1252’;

Essa rotina de inserção lê linha a linha de um arquivo.txt e insere em uma tabela. Em minha base de desenvolvimento, (Windows XP, PostgreSQL) tudo funciona bem, mas quando faço um deploy da aplicação para nosso servidor Locaweb (Linux, PostgreSQL) dá o erro!!

R

Bom dia senhores, a resolução do problema relatado foi mais simples do que imaginei. Apenas especifiquei o encoding ao ler o arquivo texto.

Reader r = new BufferedReader(new InputStreamReader(new FileInputStream("c:\\xxx.txt"), "Cp1252"));
Criado 15 de junho de 2009
Ultima resposta 17 de jun. de 2009
Respostas 5
Participantes 2