读取本地文件名并且批量导入数据库

在批量导入前,需要有自己的数据库或者是可用的数据库,需要数据库相关的jar文件,本文中使用的是mysql,具体的代码如下:

import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.sql.Connection;  
import java.sql.DriverManager;  
import java.sql.ResultSet;  
import java.sql.SQLException;  
import java.sql.Statement;  
import java.util.HashMap;
import java.util.Map;
public class ChangeFileName {  
    // 创建静态全局变量  
    static Connection conn;  
  
    static Statement st;  
  
    public static void main(String[] args)throws Exception {  
    Map<Integer, String> map = readfile("E:/工作文件夹/短信管理/处理图片/downbank0122pstupiansucaiku/pstupiansucaiku/pstupiansucaiku",null);
    System.out.println("mapsize=="+map.size());
      for(int i=0 ; i < map.size(); i++) {
       System.out.println(map.get(i));
      }
        insert();   //插入添加记录  
       // query();    //查询记录并显示  
    }  
      
    /* 插入数据记录,并输出插入的数据记录数*/  
    public static void insert()throws Exception {  
          
        conn = getConnection(); // 首先要获取连接,即连接到数据库  
  
        try { 
        Map<Integer, String> map = readfile("E:/工作文件夹/短信管理/处理图片/downbank0122pstupiansucaiku/pstupiansucaiku/pstupiansucaiku",null);
       
        for(int i = 0; i <= map.size(); i++){
        String path = map.get(i);
        String img_title = path.substring(79);
        String img_path = "/upload/images/" + img_title;
            String sql = "INSERT INTO wxs_img(img_path, img_title,user_id, add_date)"  
                    + " VALUES ('"+img_path+"', '"+img_title+"',5,curdate());";  // 插入数据的sql语句  
            System.out.println("sqlsqlsqlsqlsqlsql="+sql);
            
            st = (Statement) conn.createStatement();    // 创建用于执行静态sql语句的Statement对象  
              
            int count = st.executeUpdate(sql);  // 执行插入操作的sql语句,并返回插入数据的个数  
              
            System.out.println("向staff表中插入 " + count + " 条数据"); //输出插入操作的处理结果  
              
           
       
        conn.close();   //关闭数据库连接  
        } catch (SQLException e) {  
            System.out.println("插入数据失败" + e.getMessage());  
        }  
    }  
      
    /* 更新符合要求的记录,并返回更新的记录数目*/  
    public static void update() {  
        conn = getConnection(); //同样先要获取连接,即连接到数据库  
        try {  
            String sql = "update staff set wage='2200' where name = 'lucy'";// 更新数据的sql语句  
              
            st = (Statement) conn.createStatement();    //创建用于执行静态sql语句的Statement对象,st属局部变量  
              
            int count = st.executeUpdate(sql);// 执行更新操作的sql语句,返回更新数据的个数  
              
            System.out.println("staff表中更新 " + count + " 条数据");      //输出更新操作的处理结果  
              
            conn.close();   //关闭数据库连接  
              
        } catch (SQLException e) {  
            System.out.println("更新数据失败");  
        }  
    }  
  
    /* 查询数据库,输出符合要求的记录的情况*/  
    public static void query() {  
          
        conn = getConnection(); //同样先要获取连接,即连接到数据库  
        try {  
            String sql = "select * from staff";     // 查询数据的sql语句  
            st = (Statement) conn.createStatement();    //创建用于执行静态sql语句的Statement对象,st属局部变量  
              
            ResultSet rs = st.executeQuery(sql);    //执行sql查询语句,返回查询数据的结果集  
            System.out.println("最后的查询结果为:");  
            while (rs.next()) { // 判断是否还有下一个数据  
                  
                // 根据字段名获取相应的值  
                String name = rs.getString("name");  
                int age = rs.getInt("age");  
                String sex = rs.getString("sex");  
                String address = rs.getString("address");  
                String depart = rs.getString("depart");  
                String worklen = rs.getString("worklen");  
                String wage = rs.getString("wage");  
                
                  
                //输出查到的记录的各个字段的值  
                System.out.println(name + " " + age + " " + sex + " " + address  
                        + " " + depart + " " + worklen + " " + wage);  
              
            }  
            conn.close();   //关闭数据库连接  
              
        } catch (SQLException e) {  
            System.out.println("查询数据失败");  
        }  
    }  
  
    /* 删除符合要求的记录,输出情况*/  
    public static void delete() {  
  
        conn = getConnection(); //同样先要获取连接,即连接到数据库  
        try {  
            String sql = "delete from staff  where name = 'lili'";// 删除数据的sql语句  
            st = (Statement) conn.createStatement();    //创建用于执行静态sql语句的Statement对象,st属局部变量  
              
            int count = st.executeUpdate(sql);// 执行sql删除语句,返回删除数据的数量  
              
            System.out.println("staff表中删除 " + count + " 条数据\n");    //输出删除操作的处理结果  
              
            conn.close();   //关闭数据库连接  
              
        } catch (SQLException e) {  
            System.out.println("删除数据失败");  
        }  
          
    }  
      
    /* 获取数据库连接的函数*/  
    public static Connection getConnection() {  
        Connection con = null;  //创建用于连接数据库的Connection对象  
        try {  
            Class.forName("com.mysql.jdbc.Driver");// 加载Mysql数据驱动  
              
            con = DriverManager.getConnection(  
                    "jdbc:mysql://localhost:3306/sms_channel", "root", "root");// 创建数据连接  
              
        } catch (Exception e) {  
            System.out.println("数据库连接失败" + e.getMessage());  
        }  
        return con; //返回所建立的数据库连接  
    }  
    
    public static Map<Integer, String> readfile(String filepath, Map<Integer, String> pathMap) throws Exception {
     if (pathMap == null) {
      pathMap = new HashMap<Integer, String>();
     }
     String filepathnew=filepath.substring(50);
     File file = new File(filepath); 
     // 文件
     if (!file.isDirectory()) { 
      pathMap.put(pathMap.size(), file.getPath());


     } else if (file.isDirectory()) { // 如果是目录, 遍历所有子目录取出所有文件名 
      String[] filelist = file.list(); 
      for (int i = 0; i < filelist.length; i++) { 
       File readfile = new File(filepath + "/" + filelist[i]); 
       if (!readfile.isDirectory()) {
        pathMap.put(pathMap.size(), readfile.getPath());


       } else if (readfile.isDirectory()) { // 子目录的目录
        readfile(filepath + "/" + filelist[i], pathMap); 
       } 
      } 
     } 
     return pathMap; 
    }
}  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值