偷懒工具设计之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

相关文章

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

sqlite3 命令行工具使用指南

《sqlite3命令行工具使用指南》本文系统介绍sqlite3CLI的启动、数据库操作、元数据查询、数据导入导出及输出格式化命令,涵盖文件管理、备份恢复、性能统计等实用功能,并说明命令分类、SQL语... 目录一、启动与退出二、数据库与文件操作三、元数据查询四、数据操作与导入导出五、查询输出格式化六、实用功

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

SQLite3命令行工具最佳实践指南

《SQLite3命令行工具最佳实践指南》SQLite3是轻量级嵌入式数据库,无需服务器支持,具备ACID事务与跨平台特性,适用于小型项目和学习,sqlite3.exe作为命令行工具,支持SQL执行、数... 目录1. SQLite3简介和特点2. sqlite3.exe使用概述2.1 sqlite3.exe

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI