偷懒工具设计之sql2Excel

2024-03-21 05:48
文章标签 工具 设计 偷懒 sql2excel

本文主要是介绍偷懒工具设计之sql2Excel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 偷懒工具设计之sql2Excel

        今天在公司陪山东客户调试,远程登录,我在linux下什么工具都没有,用ssh登录服务器,直接用mysql查询数据库,提出记录中的所有汉字全是乱码。哎,可恶的公司,不让我用windows,要不我就可以用putty或者EMS了,我ft!
         甚是不爽之下,我决定自己写个工具了,把客户数据库中的数据全部提取并保存到Excel中,这样我不就可以一目了然了嘛,嘿嘿,好吧,那我就写一个工具吧。

第一部分就是谁都会的jdbc操作,连接数据库,提取数据集合。
    Connection con;
    Statement state;
    
/**初始化连接
     * 
@param serverIp
     * 
@param dataBase
     * 
@param userName
     * 
@param password
     * 
@throws ClassNotFoundException
     * 
@throws SQLException
     
*/

    
public   void  init(String serverIp,String dataBase,String userName,String password)  throws  ClassNotFoundException, SQLException {
        Class.forName(
"com.mysql.jdbc.Driver");
        
//配置数据源
        String url="jdbc:mysql://"+serverIp+"/"+dataBase+"?useUnicode=true&characterEncoding=GB2312";
        con
=DriverManager.getConnection(url,userName,password); 
    }

    
/**得到查询结果集
     * 
@param sql
     * 
@return
     * 
@throws SQLException
     
*/

    
public  ResultSet getResultSet(String sql)  throws  SQLException {
        state 
= con.createStatement();
        ResultSet res 
= state.executeQuery(sql);
        
return res;
    }

    
/**关闭连接
     * 
@throws SQLException
     
*/

    
public   void  close()  throws  SQLException {
        
if(con!=null)
            con.close();
        
if(state!=null)
            state.close();
    }

第二部分就是把ResultSet中的记录写入一个Excel文件
操作Excel,我用的是jxl,不熟的同学可以参考: 利用java操作Excel文件
     /**将查询结果写入Excel文件中
     * 
@param rs
     * 
@param file
     * 
@throws SQLException
     
*/

    
public   void  writeExcel(ResultSet rs,File file)  throws  SQLException {
          WritableWorkbook wwb 
= null;
            
try{
                
//首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象
                wwb = Workbook.createWorkbook(file);
            }
 catch (IOException e){
                e.printStackTrace();
            }

            
if(wwb!=null){
                WritableSheet ws 
= wwb.createSheet("sheet1"0);
                
int i=0;
                
while(rs.next()){
                    Label label1 
= new Label(0, i, rs.getString("id"));
                    Label label2 
= new Label(1, i, rs.getString("category"));
                     
try {
                        ws.addCell(label1);
                        ws.addCell(label2);
                    }
 catch (RowsExceededException e) {
                        e.printStackTrace();
                    }
 catch (WriteException e) {
                        e.printStackTrace();
                    }

                    i
++;
                }
    

                
try {
                    
//从内存中写入文件中
                    wwb.write();
                    
//关闭资源,释放内存
                    wwb.close();
                }
 catch (IOException e) {
                    e.printStackTrace();
                }
 catch (WriteException e){
                    e.printStackTrace();
                }

            }

    }

测试程序:
        Sql2Excel se  =   new  Sql2Excel();
        
try   {
            se.init(
"127.0.0.1","mydabase""root""1234");
            ResultSet rs 
= se.getResultSet("select id,category from xx ");
            se.writeExcel(rs, 
new File("/root/sql2excel.xls"));
            se.close();
        }
  catch  (ClassNotFoundException e)  {
            e.printStackTrace();
        }
  catch  (SQLException e)  {
            e.printStackTrace();
        }


         呵呵,比较简单吧,不过还是很有用的,其实那些数据库查询工具EMS,Mysql Query Browser之类的和这个差不多,掌握了原理,我们也可以自己开发查询工具,备份工具。


这篇关于偷懒工具设计之sql2Excel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/831906

相关文章

Docker部署Jenkins持续集成(CI)工具的实现

《Docker部署Jenkins持续集成(CI)工具的实现》Jenkins是一个流行的开源自动化工具,广泛应用于持续集成(CI)和持续交付(CD)的环境中,本文介绍了使用Docker部署Jenkins... 目录前言一、准备工作二、设置变量和目录结构三、配置 docker 权限和网络四、启动 Jenkins

MobaXterm远程登录工具功能与应用小结

《MobaXterm远程登录工具功能与应用小结》MobaXterm是一款功能强大的远程终端软件,主要支持SSH登录,拥有多种远程协议,实现跨平台访问,它包括多会话管理、本地命令行执行、图形化界面集成和... 目录1. 远程终端软件概述1.1 远程终端软件的定义与用途1.2 远程终端软件的关键特性2. 支持的

Java数字转换工具类NumberUtil的使用

《Java数字转换工具类NumberUtil的使用》NumberUtil是一个功能强大的Java工具类,用于处理数字的各种操作,包括数值运算、格式化、随机数生成和数值判断,下面就来介绍一下Number... 目录一、NumberUtil类概述二、主要功能介绍1. 数值运算2. 格式化3. 数值判断4. 随机

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

Java中基于注解的代码生成工具MapStruct映射使用详解

《Java中基于注解的代码生成工具MapStruct映射使用详解》MapStruct作为一个基于注解的代码生成工具,为我们提供了一种更加优雅、高效的解决方案,本文主要为大家介绍了它的具体使用,感兴趣... 目录介绍优缺点优点缺点核心注解及详细使用语法说明@Mapper@Mapping@Mappings@Co

使用Python实现图片和base64转换工具

《使用Python实现图片和base64转换工具》这篇文章主要为大家详细介绍了如何使用Python中的base64模块编写一个工具,可以实现图片和Base64编码之间的转换,感兴趣的小伙伴可以了解下... 简介使用python的base64模块来实现图片和Base64编码之间的转换。可以将图片转换为Bas

使用Java实现一个解析CURL脚本小工具

《使用Java实现一个解析CURL脚本小工具》文章介绍了如何使用Java实现一个解析CURL脚本的工具,该工具可以将CURL脚本中的Header解析为KVMap结构,获取URL路径、请求类型,解析UR... 目录使用示例实现原理具体实现CurlParserUtilCurlEntityICurlHandler

Rsnapshot怎么用? 基于Rsync的强大Linux备份工具使用指南

《Rsnapshot怎么用?基于Rsync的强大Linux备份工具使用指南》Rsnapshot不仅可以备份本地文件,还能通过SSH备份远程文件,接下来详细介绍如何安装、配置和使用Rsnaps... Rsnapshot 是一款开源的文件系统快照工具。它结合了 Rsync 和 SSH 的能力,可以帮助你在 li

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni