java登录sql语句_java psql控制台调用,登录执行sql语句

主要是登录的问题,一开始是使用 Process p = Runtime.getRuntime().exec( "psql -U username -d dbname -h serverhost -f scripfile.sql"); 尝试在代码中执行export PGPASSWORD=test、创建.pgpass文件、利用p.getOutputStream()对象流输入密码,但效果并不理想,之后发现了这方法,完美解决了我这边的需求,写下来做个记录。

这里利用ProcessBuilder执行psql,通过ProcessBuilder.environment().put()设置环境变量,psql登录时从PGPASSWORD环境变量读取密码,从而不弹出密码输入提示。

import java.io.*;

import java.util.ArrayList;

import java.util.List;

public class Main {

public static void main(String[] args) {

String sql = "drop table table_name1;\n" +

"INSERT INTO public.table_name2 (id, username) VALUES (DEFAULT, 'user');\n" +

"UPDATE public.table_name2 set username = 'xiaoming' where id = 1;";

Execute e = new Execute();

e.sqlExec(sql);

}

}

class Execute {

// 将sql语句写入文件

public String createSqlFile(String sql) {

String sqlFile = "";

try {

File file = File.createTempFile("test", "sql");

FileWriter writer = new FileWriter(file, false);

writer.append(sql);

writer.flush();

// 退出JVM时删除该临时文件

file.deleteOnExit();

sqlFile = file.getAbsoluteFile().toString();

} catch (IOException e) {

e.printStackTrace();

}

return sqlFile;

}

public void sqlExec(String sql) {

String sqlFile = this.createSqlFile(sql);

// 生成psql命令

List commandList = new ArrayList();

commandList.add("psql");

// host

commandList.add("-h");

commandList.add("127.0.0.1");

// username

commandList.add("-U");

commandList.add("test");

// database

commandList.add("-d");

commandList.add("test");

// port

commandList.add("-p");

commandList.add("5432");

// sql file

commandList.add("-f");

commandList.add(sqlFile);

// 不弹出密码输入行

commandList.add("-w");

ProcessBuilder pd = new ProcessBuilder(commandList);

// 从环境变量读取数据库密码

pd.environment().put("PGPASSWORD", "test");

try {

Process p = pd.start();

String line;

BufferedReader input = new BufferedReader(new InputStreamReader(p

.getInputStream()));

while ((line = input.readLine()) != null) {

if (line.equals("")) {

continue;

}

// 将控制台执行结果输出

System.out.println(line);

}

input.close();

} catch (Exception e) {

e.printStackTrace();

}

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值