如何往数据库中添加数据及如何导出数据库中的数据

首先,我们应该了解添加数据和导出数据所完成的过程。

添加数据首先要做的是从文件中读取数据(主语是”程序“),"读"----告诉我们应该用Readerh或者InputStream流,而我们的数据中存在中文,就不能用InputStream流来读取文件了,因为他是字节流,在读取文件的时候是一个字节(八个比特)-----0101 1011----这样读取的,首位必须是0,也就是说一个字节只可以表示2^8-1=127中字符,相信你们现在脑子里面肯定会想到ASCII表,当然你们是对的,这127种字符刚好对应ASCII表上面的值。也正是这让我们能出现了中文,会乱码的原因-----不能正确的读取。

为了解决这一情况,我们国家也制作了一个GBK编码集,当然只能显示中文英文,再后来为了解决这一现象,又推出了可以包含全世界各个国家的语言编码集(Unicode字符集 ),UTF-8,UTF-16,UTF-32是编码格式。

 GBK编码格式是一个中文占两个字节,二进制第一位是1,第一个字节转换成十进制是负数,英文占一个字节。UTF-8编码格式是,一个中文占三个字节,二进制和第一位是1,第一个字节转换成十进制是负数,英文占一个字节。

扯得有点远了。上面的听听就行了。回归正题。

 这时候,我们就知道该用Reader流读取文件了,因为Reader是字符流。现在我们有两个选择,要不用BufferedReader流读,要不就用FileReader流读取文件。当然,最后还是用了BufferedReader流读取文件,因为这个流中有特有的方法,可以每次读一行,readLine();

最好再通过分割字符串的方法获取到一个String类型的数组。再连接数据库进行插入,最后不要忘记关流。

下面是一个例子:

try {
                    //通过BufferedReader特有的方法读取数据,再切割数据
                    BufferedReader br=new BufferedReader(new FileReader("src/work/file_user/党组织信息.txt"));
                    //第一行数据是列名,不需要获取,所以我们先在这里get一下,循环的时候直接从第二行开始读了
                    br.readLine();
                    Connection con = null;
                    Statement statement = null;
                    ResultSet resultSet = null;
                    try {
                        Class.forName("com.mysql.cj.jdbc.Driver");
                        System.out.println("加载驱动成功");
                    } catch (Exception e) {
                        System.out.println("加载驱动失败");
                        System.out.println(e);
                    }
                    String url = "jdbc:mysql://127.0.0.1:3306/communist1?useSSL=false";
                    String user = "root";
                    String password = "123456";
                    try {
                        con = DriverManager.getConnection(url, user, password);
                        if (!con.isClosed()) {
                            System.out.println("成功连接到数据库");
                        }
                        statement = con.createStatement();
                        String sql1 = "use communist";
                        try {
                            statement.executeUpdate(sql1);
                            System.out.println("正在使用communist数据库");
                        } catch (SQLException e) {
                            System.out.println("切换数据库失败");
                            e.printStackTrace();
                        }
                        String s=null;
                        int n=0;
                        while((s= br.readLine())!=null){
                            String[] text=s.split(" ");
                            String sql="insert into 党组织信息\r\n" +
                                    "VALUES("+text[0]+",'"+text[1]+"','"+text[2]+"','"+text[3]+"')";
                            n = statement.executeUpdate(sql);
                        }
                        //判断数据是否导入成功,如果导入成功n=1(每次导入一行数据)
                        if(n!=0){
                            JOptionPane.showMessageDialog(management.super.rootPane, "导入信息成功!");
                        }
                        else{
                            JOptionPane.showMessageDialog(management.super.rootPane, "导入信息失败!");
                        }
                    } catch (Exception e) {
                        System.out.println(e);
                    } finally {
                        //关流
                        br.close();
                        try {
                            if (resultSet != null) {
                                resultSet.close();
                            }
                            if (statement != null) {
                                statement.close();
                            }
                            if (con != null) {
                                con.close();
                            }
                        } catch (SQLException e) {
                            System.out.println(e);
                        }
                    }
                } catch (IOException e) {
                    throw new RuntimeException(e);
                }

 导出就更简单了,首先从数据库中读取文件,然后再写入到相应的路径中去。因为有汉字,所以要用Writer进行写入,可以选择FileWriter也可以选择 BufferedWriter,这两个流都有缓冲区的,效率几乎毫无差别。BufferedWriter有自己独特的方法,换行(newLine();)。

这个是导出的例子: 

对于Windows系统来说,在文本文件中换行符通常是"\r\n"(回车符+换行符)组合的形式,但也可以使用单独的"\n"(换行符)作为换行符,并且在一些情况下,Windows系统会自动给你补全"\r"(回车符)。

try {
                    //用字符流写入数据
                    FileWriter fw=new FileWriter("src/work/file/党组织信息导出表.txt");
                    fw.write("组织编号 "+" 组织全名称 "+"组织属性 "+"属地关系 \r\n");
                    Connection con = null;
                    Statement statement = null;
                    ResultSet resultSet = null;
                    try {
                        Class.forName("com.mysql.cj.jdbc.Driver");
                        System.out.println("加载驱动成功");
                    } catch (Exception e) {
                        System.out.println("加载驱动失败");
                        System.out.println(e);
                    }
                    String url = "jdbc:mysql://127.0.0.1:3306/communist?useSSL=false";
                    String user = "root";
                    String password = "123456";
                    try {
                        con = DriverManager.getConnection(url, user, password);
                        if (!con.isClosed()) {
                            System.out.println("成功连接到数据库");
                        }
                        statement = con.createStatement();
                        String sql1 = "use communist";
                        try {
                            statement.executeUpdate(sql1);
                            System.out.println("正在使用communist数据库");
                        } catch (SQLException e) {
                            System.out.println("切换数据库失败");
                            e.printStackTrace();
                        }
                        String sql = "SELECT * FROM 党组织信息";
                        resultSet = statement.executeQuery(sql);
                        while (resultSet.next()) {
                            int bianhao= resultSet.getInt("组织编号");
                            String name = resultSet.getString("组织全名称");
                            String shuxing = resultSet.getString("组织属性");
                            String shudi = resultSet.getString("属地关系");
                            fw.write(bianhao+"\t "+name+"\t "+shuxing+"\t "+shudi+"\r\n");
                        }
                    } catch (Exception e) {
                        System.out.println(e);
                    } finally {
                        fw.close();
                        try {
                            if (resultSet != null) {
                                resultSet.close();
                            }
                            if (statement != null) {
                                statement.close();
                            }
                            if (con != null) {
                                con.close();
                            }
                        } catch (SQLException e) {
                            System.out.println(e);
                        }
                    }
                } catch (Exception ex) {
                    throw new RuntimeException(ex);
                }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要从 MySQL 数据库获取数据并将其导出到 Excel,你可以使用 Flask、MySQL Connector 和 openpyxl 库。以下是一个简单的示例代码: ```python from flask import Flask, make_response import mysql.connector from openpyxl import Workbook app = Flask(__name__) @app.route('/export-excel') def export_excel(): # 连接到 MySQL 数据库 conn = mysql.connector.connect( host='localhost', user='root', password='password', database='database' ) # 从数据库获取数据 cursor = conn.cursor() cursor.execute('SELECT * FROM table') data = cursor.fetchall() # 创建一个 Workbook 对象 wb = Workbook() # 选择默认的工作表 ws = wb.active # 将数据添加到工作表 for row in data: ws.append(row) # 将 Workbook 对象保存到内存 output = BytesIO() wb.save(output) # 创建一个响应对象并将 Excel 文件作为附件添加到响应 response = make_response(output.getvalue()) response.headers['Content-Disposition'] = 'attachment; filename=example.xlsx' response.headers['Content-Type'] = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' # 关闭数据库连接并返回响应 cursor.close() conn.close() return response if __name__ == '__main__': app.run() ``` 在上面的代码,我们首先连接到 MySQL 数据库,并从表获取数据。然后,我们创建一个 Workbook 对象,并将数据添加到工作表。接下来,我们将 Workbook 对象保存到内存,并创建一个响应对象,将 Excel 文件作为附件添加到响应。最后,我们关闭数据库连接并返回响应。请根据需要更改代码数据库连接和查询语句。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小羊没烦恼~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值