PostgreSQL之copy命令

导入依赖:
在这里插入图片描述
样例代码:
@SpringBootApplication
public class CopyTest implements ApplicationRunner {

private static final Logger logger = LoggerFactory.getLogger(CopyTest .class);

public static void main(String[] args) {
	SpringApplication.run(CopyTest .class, args);
}

@Override
public void run(ApplicationArguments args) throws Exception {
	String gpip="10.154.1.32",gpport="5432",gpdbname="test",gpuser="test",gppass="123456";
	Connection connection=null;
    Long lines = 0L;
    Statement stmt =null;
    Class.forName("org.postgresql.Driver").newInstance();
	connection = DriverManager.getConnection("jdbc:postgresql://" + gpip + ":" + gpport + "/" + gpdbname + "",
			gpuser, gppass);
	logger.info("数据库连接成功");
	
	CopyTest itd = new CopyTest ();
	
	Vector<String> listfile = itd.traverseFolder2("D:\\wang");  //copy的文件路径
	if(listfile!=null){
	for(String file:listfile){
		String[] fileName= file.split("\\\\");
		logger.info("文件名:" + file);
		stmt = connection.createStatement();
        lines=itd.copyFromFile(connection, file, "表名");
		logger.info(file + " 插入多少行:" + lines);
	}}
}


public Vector<String> traverseFolder2(String path) {

    File file = new File(path);
    Vector<String> listfile = new Vector<String>();
    if (file.exists()) {
        File[] files = file.listFiles();
        if (null == files || files.length == 0) {
           
            return null;
        } else {
            for (File file2 : files) {
                if (file2.isDirectory()) {
                    continue;
                } else {
                	listfile.add(file2.getAbsolutePath());
                }
            }
        }
    } else {
        return null;
        
        		
    }
    return listfile;
}

 /**
 * 将文件中的数据导入到数据库中
 *
 * @param connection 连接
 * @param filePath   文件路径
 * @param tableName  表名
 * @return long  导入的行数
 */
public static long copyFromFile(Connection connection, String filePath, String tableName)
        throws SQLException, IOException {
	
    FileInputStream fileInputStream = null;
    try {
        CopyManager copyManager = new CopyManager((BaseConnection) connection);
        fileInputStream = new FileInputStream(filePath);
        String copyIn = "COPY " + tableName + " FROM STDIN DELIMITER  ','";
        return copyManager.copyIn(copyIn, fileInputStream);
    } finally {
        if (fileInputStream != null) {
            try {
                fileInputStream.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
}

}
注意:文件的头部要与copy的表中字段一一对应。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值