java向mysql数据库中传数据

本文介绍了一个使用Java将文本文件中的内容读取并插入到数据库的方法。通过编码适配、异常处理及数据库连接管理等步骤,实现了批量数据导入的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package lianjie;


import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;


import lianjie.Dbutil;


public class Chashuju {
public static void readTxtFile(String filePath){
Connection conn=null;


        try {
            String encoding="GBK";
            File file=new File(filePath);
            if(file.isFile() && file.exists()){ //判断文件是否存在
                InputStreamReader read = new InputStreamReader(
                        new FileInputStream(file),encoding);//考虑到编码格式
                BufferedReader bufferedReader = new BufferedReader(read);
                String lineTxt = null;
                int i=0;
                while((lineTxt = bufferedReader.readLine()) != null){
                System.out.println(lineTxt);
               
                i++;
                try{
                conn= Dbutil.getConnection();
                String sql = "insert into www values(?)";
                PreparedStatement ps = conn.prepareStatement(sql);
                ps.setString(1,lineTxt.replaceAll(" ",""));
                ps.execute();
               
                }catch(SQLException e){
                e.printStackTrace();
                throw new RuntimeException("添加失败",e);
                }finally {
Dbutil.close(conn);
}
               
                }
                
                read.close();
            }else{
                System.out.println("找不到指定的文件");
            }
        } catch (Exception e) {
            System.out.println("读取文件内容出错");
            e.printStackTrace();
        }
    }
    public static void main(String argv[]){
        String filePath = "E://新项目//预测.txt";
        readTxtFile(filePath);
    }

}

连接数据库的代码

package lianjie;


import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;






public class Dbutil {




static {
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}


public static Connection getConnection() throws SQLException {
return  DriverManager.getConnection("jdbc:mysql://192.168.0.103:3306/data?useUnicode=true&characterEncoding=utf-8","root","123456");
}

public static void close(Connection conn) {
if(conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();


}
}
}


}



在基于SpringBoot的java后端中,对应的数据库MySQL。现在需要开发一个功能。 已经知晓,从第三方系统中过来了一个Json,保存在了数据库的表A中 需要从表B中取出已经添加好的Json标准模板。然后再将第三方系统的Json和Json标准模板进行比较。 需要校验第三方Json的结构,以及在模板中必填的项,必填项标志为:"^",需要校验是否填写了。同时在表B中要设计一个存储可能存在多个子集的项的字段。存储的项会用英文逗号分隔。 我解释一下什么是可能存在多个子集的项。比如说"凭证明细"是可能存在多个子集的项。 那过来的第三方系统的Json的"凭证明细"部分可能是以下这样的: "凭证明细": [{ "电子文件号": "1020_2025_0100001587", "行号": "002", "摘要": "BXD202501170-报差旅费-160377|陆文兵", "分配": "00052444", "记账码": "40", "总账科目代码": "2221010138", "总账科目": "应交税费-应交增税-进项税额-客运服务-非专票", "借方": "11.56", "贷方": "0", "原币金额": "11.56" }, { "电子文件号": "1020_2025_0100001587", "行号": "005", "摘要": "BXD202501170-报差旅费-160377|陆文兵", "分配": "BXD202501170", "记账码": "40", "总账科目代码": "5301011700", "总账科目": "研发支出-费用化支出-差旅费", "借方": "240", "贷方": "0", "原币金额": "240" }], 子集里面的信息都是需要校验的。 综上所述,请问如何去设计实现这个功能呢? 以下给出一个标准模板进行参考,其中:"凭证明细"、"关联凭证"字段,是可能存在多个子集的项: { "文件实体块": { "文件实体": { "来源": { "全宗名称": "^", "立档单位名称": "^", "电子文件号": "^" }, "档号": { "全宗号": "^", "目录号": "", "年度": "^", "保管期限": "", "机构或问题": "", "类别号": "^", "室编案卷号": "", "室编件号": "", "文档序号": "", "页号": "" }, "内容描述": { "单据类型": "^", "单位": "^", "财务主体代码": "^", "销售合同号": "^", "责任者": "^", "期间": "^YYYY-MM", "过账日期": "^YYYY-MM-DD", "凭证编号": "^", "货币": "^", "汇率": "^", "凭证类型": "^", "凭证抬头文本": "^", "凭证明细": [{ "行号": "^", "摘要": "^", "总账科目": "^", "明细对象": "^", "借方": "^", "贷方": "^", "原币金额": "^" }], "附件": "^", "合计借方金额": "^", "合计贷方金额": "^", "财务主管": "^", "财务主管工号": "^", "复审模式": "^", "复核": "^", "复核工号": "^", "制单": "^", "制单工号": "^", "经办人": "^", "经办人工号": "^", "备注": "^", "关联凭证": [{ "公司代码": "^", "凭证类型": "^", "凭证号": "^" }], "关联业务单据": [{ "系统代码": "^", "业务单据号": "^" }],
最新发布
03-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值