配置ODBC DSN数据源,导出数据库数据到Excel过程记录
一、前言
工作中我们可能遇到这样的需要:查询数据库中的信息,并将结果导出到Excel文件。这本来没什么,但数据量比较大时,用PLSQL、toad导出Excel会出现内存不足等情况,使用odbc+Microsoft query + Excel导出提数结果能在一定程度上避免这些问题。
环境:个人电脑8G内存,导出130W条记录毫无压力。
二、下载、安装Oracle Database Client
Windows默认没有按照Oracle的ODBC驱动,需要手动安装,Oracle Database Client包含了Oracle ODBC驱动组件。
1、下载
地址:https://edelivery.oracle.com/osdc/faces/SearchSoftware
在搜索框中输入oracle database client,然后选择系统平台为Windows 64,选定oracle database client ,然后按照提示,下载该组件
下载该组件,可能单击 download,没有反应,鼠标移动到要下载的软件位置,可用右击“目标另存为”方式下载要下载的组件
2、安装
三、下载、安装Instant Client
1、下载
打开链接:
http://www.oracle.com/technetwork/cn/database/features/instant-client/index-092699-zhs.html,
选择适用于Windows32位系统的instant client即可,下载该组件
选择下面两个版本中的任何一项均可:
2、安装
该组件直接解压即可,无需安装。解压到某个指定的目录下,在解压后的文件目录下创建子目录/network/admin,并将配置好的tnsname.ora文件拷贝到该目录下(或手动创建该文件并配置该文件,步骤略)
设置环境变量:
右击计算机—>属性—> 高级选项卡à环境变量—>新建系统变量或用户变量(用户变量只对当前用户有效,系统变量对所有用户有效)à设置环境变量ORACLE_HOME,指向解压文件目录。“确定”,退出
同样,设置环境变量TNS_ADMIN,指向instantclient下的network\admin目录,这样,odbc数据源就可以自动获取tns信息,如下:
3、可能遇到的问题:若不配置环境变量ORACLE_HOME,在使用ODBC数据源时,会报错“Unable to connect SQLState=08004 [Oracle][ODVC][Ora]ORA-12154:TNS:could not resolve the connect identifier specified”,这种情况同样发生在使用oracle instant组件的PowerDesigner等工具连接数据库的情况下。
四、配置odbc数据源
(1)打开odbc数据源管理工具
方式一:在开始-->所有程序中或搜索odbc,找到Microsoft ODBC管理员程序
方式二:控制面板-->管理工具-->数据源
(2)添加用户DSN
用户DSNà添加,选择Oracle驱动(MySQL、SQLserver等可安装并选择对应的驱动),完成
(4)填写ODBC配置信息并测试连通性
填写odbc数据源配置信息,标注部分为必填项,数据源名称为任意有含义的字符串,可用中文,TNS Server Name格式为“ip:port/数据库名称”,User ID 为访问数据库的用户名(port默认是1521,请记得防火墙和杀软放行1521端口),数据库名称选用tsnnames.ora文件中的SERVICE_NAME的值。
注意:TNS Service Name填写方式有两种方法:
第一种,填写完整格式:TNS Service Name的完整格式是: 数据库主机名:端口号/数据库实例名。
第二种:如果配置的数据源很多,可以按照Oracle instant Client,这里安装了instant client,并设置了TNS_ADMIN的环境变量,TNS Service Name选项下会有所有已经设置TNS的数据库实例名列表。当要操作的数据库实例比较多时,这种方法很方便。
填写完毕,先测试数据源连通性“Test Connection”,输入密码,“OK”
若提示连接成功,说明配置无误,“确定”,“OK”,退出管理程序。否则,检查并修改配置信息。
四、创建临时表
执行SQL语句,将结果集较大的查询语句加工到临时表中,如下:
CREATE TABLE TMP_TEST AS
SELECT E.EMPNO, E.ENAME, E.JOB, E.MGR, E.HIREDATE, E.SAL, D.DNAME, D.LOC
FROM EMP E, DEPT D
WHERE E.DEPTNO = D.DEPTNO;
五、配置Excel,导出数据
(1)新建Excel,数据—>自其他来源—>来自Microsoft Query
(2)选择配置好的数据源,“确定”
(3)填写对应的密码
(4)选项里可设置查找要导出的对象的范围,进入“选项”
(5)表选项里可设置要导出的对象:表、视图、同义词等,注意选择用户,当有大量用户和表时,可大大缩小查找范围
(6)在左侧要导出的表中,找到要导出的字段,>按钮可将选择好的字段导入到右侧的待查询列中。
待筛选的列,可根据需要对字段进行条件设置
排序顺序,可选择关键字排序,同时可选择多个关键字
导出默认即可,当然,也可以使用Microsoft query编辑查询,实现一些复杂的查询,并将结果导出到Excel中。
选择导入到Excel中的位置。
导出结果示例如下:
本文原始地址:http://www.cnblogs.com/chinas/p/6991311.html,转载请注明出处,谢谢!!!
配置ODBC DSN数据源,导出数据库数据到Excel过程记录的更多相关文章
- java 对excel操作 读取、写入、修改数据;导出数据库数据到excel
============前提加入jar包jxl.jar========================= // 从数据库导出数据到excel public List<Xskh> outPu ...
- 导出数据库数据制成Excel和txt
引用ICSharpCode.SharpZipLib.dll 1.编写压缩和解压代码 using System; using System.Collections.Generic; using Syst ...
- 导出数据库数据到Excel表
后台需要将用户信息数据导入到Excel表中提供给相关人员: 首先查询数据就不多说了: 导入Excel表直接亮代码(采用的是jxl的jar包提供的方法): public static File Impo ...
- 配置toad进行导入导出数据库操作
最近需要对oracle进行导入导出操作,于是研究使用toad进行导入导出oracle数据库操作,现稍作记录. oracle的导入导出不管是否使用toad还是pl/sql工具进行操作,实际上最终都是通过 ...
- 数据库数据用Excel导出的3种方法
将数据库数据用Excel导出主要有3种方法:用Excel.Application接口.用OleDB.用HTML的Tabel标签 方法1——Excel.Application接口: 首先,需要要Exce ...
- PHP导出MySQL数据到Excel文件
PHP导出MySQL数据到Excel文件 转载 常会碰到需要从数据库中导出数据到Excel文件,用一些开源的类库,比如PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存 ...
- .NET使用Office Open XML导出大量数据到 Excel
我相信很多人在做项目的都碰到过Excel数据导出的需求,我从最开始使用最原始的HTML拼接(将需要导出的数据拼接成TABLE标签)到后来happy的使用开源的NPOI, EPPlus等开源组件导出EX ...
- Excel导出数据库数据
package com.hxkr.util; import java.io.FileOutputStream; import java.util.ArrayList; import java.util ...
- DB2导入导出数据库数据
导出数据库中数据 在db2cmd命令下生成建库脚本(-z指定模式名) db2look -d BBS -z db2admin -u db2admin -e -o bbs.sql 在db2cmd命令下导出 ...
随机推荐
- [转帖]SQLSERVER的兼容级别
SQL Server数据库的兼容级别 http://www.cnblogs.com/sosoft/archive/2017/07/08/sqljrjb.html 改天尝试一下 在SQLSERVER20 ...
- 一文总结之Redis
目录 Redis 目标 Redis简介 什么是Redis 特性 Redis当前应用情况 安装 基本使用 键 exists判断键存在性.del删除键.type键类型 expire key的时效性设置 基 ...
- Ubuntu终端命令--查看端口占用及关闭
1.查看已连接的服务端口 (ESTABLISHED) netstat-a 2.查看所有的服务端口(LISTEN,ESTABLISHED) netstat-ap 3.查看指定端口,可以结 ...
- mysql事务隔离级别设置
设置innodb的事务级别方法是:set 作用域 transaction isolation level 事务隔离级别: 若没有输入作用域直接修改transaction isolation,显示修改成 ...
- 【刷题】LOJ 2480 「CEOI2017」One-Way Streets
题目描述 给定一张 \(n\) 个点 \(m\) 条边的无向图,现在想要把这张图定向. 有 \(p\) 个限制条件,每个条件形如 \((xi,yi)\) ,表示在新的有向图当中,\(x_i\) 要能够 ...
- 【BZOJ4035】数组游戏(博弈论)
[BZOJ4035]数组游戏(博弈论) 题面 BZOJ 洛谷 题解 很明显是一个翻硬币游戏的变形,因此当前局面的\(SG\)函数值就是所有白格子单独存在的\(SG\)函数的异或和. 那么,对于每一个位 ...
- 【BZOJ3105】【CQOI2013】新Nim游戏
Description 传统的Nim游戏是这样的:有一些火柴堆,每堆都有若干根火柴(不同堆的火柴数量可以不同).两个游戏者轮流操作,每次可以选一个火柴堆拿走若干根火柴.可以只拿一根,也可以拿走整堆火柴 ...
- BZOJ3836 [Poi2014]Tourism 【树形dp +状压dp】
题目链接 BZOJ3836 题解 显然这是个\(NP\)完全问题,此题的解决全仗任意两点间不存在节点数超过10的简单路径的性质 这意味着什么呢? \(dfs\)树深度不超过\(10\) \(10\)很 ...
- Metasploit+python生成免杀exe过360杀毒
Metasploit+python生成免杀exe过360杀毒 1在kali下生成一个反弹的msf的python脚本,命令如下: msfvenom -p windows/meterpreter/reve ...
- 彻底解决mac下terminal路径显示问题
mac 配色 mac shell配色 ~/.bash_profile是bash shell中当前登录用户的配置文件.bash是“终端”中默认的shell. alias ls=”ls -G”是给”ls ...