我有一个 postgres 9.2 数据库,它的编码是 UTF-8。我有一个应用程序(用 java 编写)来更新这个数据库,读取 .sql 文件并在数据库中执行它们。但我发现了一个问题:在其中一个 .sql 文件中,我有以下说明:
insert into usuario(nome)
values('Usuário Padrão');
执行此操作后,当我转到表数据时,插入的是这样的:"Usuário Padrão"
如果我直接从 pgAdmin 执行此命令,它会正确创建。所以我不知道这是数据库中的问题,还是执行脚本的程序中的问题。
- -编辑 - -
这是我如何获得 JDBC 连接:
public static Connection getConnection() throws SQLException{
Connection connection;
String url="jdbc:postgresql://"+servidor+":"+porta+"/"+nomeBanco;
Properties props = new Properties();
props.put("user", usuario);
props.put("password", senha);
connection=DriverManager.getConnection(url,props);
connection.setAutoCommit(false);
return connection;
}
这是我用来读取文件的代码,但这看起来是正确的,因为如果我打印从文件中读取的字符串,它会显示正确的字符串。
public static String lerArquivo(File arquivo){
StringBuilder conteudo=new StringBuilder();
BufferedReader br = null;
try {
br=new BufferedReader(new FileReader(arquivo));
String linha;
while((linha=br.readLine())!=null){
conteudo.append(linha).append("\n");
}
} catch (IOException e) {
FrameErroBasico f=new FrameErroBasico(null, true);
f.setText("Erro ao ler arquivo.",e);
f.setVisible(true);
}finally{
try{br.close();}catch(Exception e){}
}
return conteudo.toString();
}