-
oracle11g数据库导入导出方法教程
2018-03-04 15:03:09oracle11g数据库导入导出: ①:传统方式——exp(导出)和(imp)导入: ②:数据泵方式——expdp导出和(impdp)导入; ③:第三方工具——PL/sql Develpoer;一、什么是数据库导入导出? oracle11g数据库的导入/导出,...oracle11g数据库导入导出:
①:传统方式——exp(导出)和(imp)导入:
②:数据泵方式——expdp导出和(impdp)导入;
③:第三方工具——PL/sql Develpoer;
一、什么是数据库导入导出?
oracle11g数据库的导入/导出,就是我们通常所说的oracle数据的还原/备份。
数据库导入:把.dmp 格式文件从本地导入到数据库服务器中(本地oracle测试数据库中);
数据库导出:把数据库服务器中的数据(本地oracle测试数据库中的数据),导出到本地生成.dmp格式文件。
.dmp 格式文件:就是oracle数据的文件格式(比如视频是.mp4 格式,音乐是.mp3 格式);
二、二者优缺点描述:
1.exp/imp:
优点:代码书写简单易懂,从本地即可直接导入,不用在服务器中操作,降低难度,减少服务器上的操作也就 保证了服务器上数据文件的安全性。
缺点:这种导入导出的速度相对较慢,合适数据库数据较少的时候。如果文件超过几个G,大众性能的电 脑,至少需要4~5个小时左右。
2.expdp/impdp:
优点:导入导出速度相对较快,几个G的数据文件一般在1~2小时左右。
缺点:代码相对不易理解,要想实现导入导出的操作,必须在服务器上创建逻辑目录(不是真正的目录)。我们 都知道数据库服务器的重要性,所以在上面的操作必须慎重。所以这种方式一般由专业的程序人员来完 成(不一定是DBA(数据库管理员)来干,中小公司可能没有DBA)。
3.PL/sql Develpoer:
优点:封装了导入导出命令,无需每次都手动输入命令。方便快捷,提高效率。
缺点:长时间应用会对其产生依赖,降低对代码执行原理的理解。
三、特别强调:
目标数据库:数据即将导入的数据库(一般是项目上正式数据库);
源数据库:数据导出的数据库(一般是项目上的测试数据库);
1.目标数据库要与源数据库有着名称相同的表空间。
2.目标数据在进行导入时,用户名尽量相同(这样保证用户的权限级别相同)。
3.目标数据库每次在进行数据导入前,应做好数据备份,以防数据丢失。
4.使用数据泵时,一定要现在服务器端建立可用的逻辑目录,并检查是否可用。
5.弄清是导入导出到相同版本还是不同版本(oracle10g版本与oracle11g版本)。
6.目标数据导入前,弄清楚是数据覆盖(替换),还是仅插入新数据或替换部分数据表。
7.确定目标数据库磁盘空间是否足够容纳新数据,是否需要扩充表空间。
8.导入导出时注意字符集是否相同,一般Oracle数据库的字符集只有一个,并且固定,一般不改变。
9.导出格式介绍:
Dmp格式:.dmp是二进制文件,可跨平台,还能包含权限,效率好;
Sql格式:.sql格式的文件,可用文本编辑器查看,通用性比较好,效率不如第一种,
适合小数据量导入导出。尤其注意的是表中不能有大字段 (blob,clob,long),如果有,会报错;
Pde格式:.pde格式的文件,.pde为PL/SQL Developer自有的文件格式,只能用PL/SQL Developer工具
导入导出,不能用文本编辑器查看;
10.确定操作者的账号权限。
四、二者的导入导出方法:
1、传统方法:
通用命令:exp(imp) username/password@SERVICENAME:1521 file="e:\temp.dmp" full = y;
数据库导出举例:exp xinxiaoyong/123456@127.0.0.1:1521 file="e:\temp.dmp" full = y;
exp:导出命令,导出时必写。
imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。
username:导出数据的用户名,必写;
password:导出数据的密码,必写;
@:地址符号,必写;
SERVICENAME:Oracle的服务名,必写;
1521:端口号,1521是默认的可以不写,非默认要写;
file="e:\temp.dmp" : 文件存放路径地址,必写;
full=y :表示全库导出。可以不写,则默认为no,则只导出用户下的对象;
方法细分:
1.完全导入导出:
exp(imp) username/password@SERVICENAME:1521 file="e:\temp.dmp" full = y;
2.部分用户表table导入导出:
exp(imp) username/password@SERVICENAME:1521 file="e:\temp.dmp" tabels= (table1,table2,table3,...);
3.表空间tablespaces导入导出:
//一个数据库实例可以有N个表空间(tablespace),一个表空间下可以有N张表(table)。
exp(imp) username/password@SERVICENAME:1521 file="e:\temp.dmp" tablespaces= (tablespace1,tablespace2,tablespace3,...);
4.用户名username对象导入导出:
exp(imp) username/password@SERVICENAME:1521 file="e:\temp.dmp" owner(username1,username2,username3);
2、数据泵方法:
创建directory:
expdp(impdp) username/password@SERVICENAME:1521 schemas=username dumpfile=file1.dmp logfile=file1.log directory=testdata1 remap_schema=test:test;
数据库导出举例:
expdp xinxiaoyong/123456@127.0.0.1:1521 schemas=xinxiaoyong dumpfile=test.dmp
logfile=test.log directory=testdata1;
exp:导出命令,导出时必写。
imp:导入命令,导入时必写,每次操作,二者只能选择一个执行。
username:导出数据的用户名,必写;
password:导出数据的密码,必写;
@:地址符号,必写;
SERVICENAME:Oracle的服务名,必写;
1521:端口号,1521是默认的可以不写,非默认要写;
schemas:导出操作的用户名;
dumpfile:导出的文件;
logfile:导出的日志文件,可以不写;
directory:创建的文件夹名称;
remap_schema=源数据库用户名:目标数据库用户名,二者不同时必写,相同可以省略;
1.查看表空间:
select * from dba_tablespaces;
2.查看管理理员目录(同时查看操作系统是否存在,因为Oracle并不关心该目录是否存在,如果不存 在,则出错)。
select * from dba_directories;
3.创建逻辑目录,该命令不会在操作系统创建真正的目录,最好以system等管理员创建。
create directory testdata1 as 'd:\test\dump';
4.给xinxiaoyong用户赋予在指定目录的操作权限,最好以system等管理员赋予。
//xinxiaoyong 是用户名(123456是用户密码)
grant read,write on directory testdata1 to xinxiaoyong;
5.导出数据1)按用户导 expdp xinxiaoyong/123456@orcl schemas=xinxiaoyong dumpfile=expdp.dmp directory=testdata1;
2)并行进程parallel expdp xinxiaoyong/123456@orcl directory=testdata1 dumpfile=xinxiaoyong3.dmp parallel=40 job_name=xinxiaoyong3
3)按表名导 expdp xinxiaoyong/123456@orcl tables=emp,dept dumpfile=expdp.dmp directory=testdata1;
4)按查询条件导 expdp xinxiaoyong/123456@orcl directory=testdata1 dumpfile=expdp.dmp tables=emp query='WHERE deptno=20';
5)按表空间导 expdp system/manager directory=testdata1 dumpfile=tablespace.dmp tablespaces=temp,example;
6)导整个数据库 expdp system/manager directory=testdata1 dumpfile=full.dmp FULL=y;
6.还原数据
1)导到指定用户下 impdp xinxiaoyong/123456 directory=testdata1 dumpfile=expdp.dmp schemas=xinxiaoyong;
2)改变表的owner impdp system/manager directory=testdata1 dumpfile=expdp.dmp tables=xinxiaoyong.dept remap_schema =xinxiaoyong:system;
3)导入表空间 impdp system/manager directory=testdata1 dumpfile=tablespace.dmp tablespaces=example;
4)导入数据库 impdb system/manager directory=dump_dir dumpfile=full.dmp FULL=y;
5)追加数据 impdp system/manager directory=testdata1 dumpfile=expdp.dmp schemas=system table_exists_action;
3、PLSQL方法:
登录plsql工具,所使用用户为源数据库有导出权限(exp_full_database,dba等)的用户。
1.导出建表语句(包括存储结构)导出步骤tools ->export user object,选择要导出的对象,导出.sql格式文件并等待导出完成,如 下图:
导出数据文件 ;
2.导出步骤tools ->export tables,选择要导出的表及导出的格式进行导出。导出为dmp格式,如下图:
导出为sql格式,如下图:
导出为pde格式,如下图:
提示说明:采用第三方工具导出导入整个数据库的话,耗时较长,一定要有足够
的时间来操作(数据量大的话需要好几个小时)。
3.导入建表语句
导入步骤tools->import tables->SQL Inserts 导入.sql文件
4.导入数据;
tools->import talbes,然后再根据导出的数据格式选择导入dmp文件,或者sql文件,
或者pde文件。
提示说明:导入之前最好把以前的表删除,当然导入另外数据库除外。
另外导入时当发现进度条一直卡在一个点,而且导出的文件不再增大时,甚至是提示程序
未响应,千万不要以为程序卡死了,这个导入导出就是比较缓慢,只要没有提示报错,或者导入完成就不要停止程序。
提示:创建数据库,表空间这里略过,本文主要讨论数据的导入导出,如果对此感觉稍有遗漏,尽请见谅。由于水平有限,本文档仅提供参考。如代码有错误之处,请见谅。如果有更好的开发经验,感谢回复。谢谢观看!!!;
-
Docker镜像的导入导出
2018-04-12 15:59:03Docker镜像的导入导出 本文介绍Docker镜像的导入导出,用于迁移、备份、升级等场景,准备环境如下: CentOS 7.0 Docker 1.18 导入导出命令介绍 涉及的命令有export、import、save、load save 命令 ...Docker镜像的导入导出
本文介绍Docker镜像的导入导出,用于迁移、备份、升级等场景,准备环境如下:
- CentOS 7.0
- Docker 1.18
导入导出命令介绍
涉及的命令有export、import、save、load
save
- 命令
docker save [options] images [images...]
- 示例
docker save -o nginx.tar nginx:latest
或
docker save > nginx.tar nginx:latest
其中-o和>表示输出到文件,nginx.tar
为目标文件,nginx:latest
是源镜像名(name:tag)
load
- 命令
docker load [options]
- 示例
docker load -i nginx.tar
或
docker load < nginx.tar
其中-i和<表示从文件输入。会成功导入镜像及相关元数据,包括tag信息
export
- 命令
docker export [options] container
- 示例
docker export -o nginx-test.tar nginx-test
其中-o表示输出到文件,nginx-test.tar
为目标文件,nginx-test
是源容器名(name)
import
- 命令
docker import [options] file|URL|- [REPOSITORY[:TAG]]
- 示例
docker import nginx-test.tar nginx:imp
或
cat nginx-test.tar | docker import - nginx:imp
区别
- export命令导出的tar文件略小于save命令导出的
- export命令是从容器(container)中导出tar文件,而save命令则是从镜像(images)中导出
- 基于第二点,export导出的文件再import回去时,无法保留镜像所有历史(即每一层layer信息,不熟悉的可以去看Dockerfile),不能进行回滚操作;而save是依据镜像来的,所以导入时可以完整保留下每一层layer信息。如下图所示,
nginx:latest
是save导出load导入的,nginx:imp
是export导出import导入的。
建议
可以依据具体使用场景来选择命令
- 若是只想备份images,使用save、load即可
- 若是在启动容器后,容器内容有变化,需要备份,则使用export、import
-
Sqoop增量导入导出总结
2020-05-21 11:50:26Sqoop做为关系型数据库RDBMS和大数据平台(HDFS,Hive,Hbase等)导入导出工具,如果不熟悉其参数作用,使用起来各种问题,本文作为博主对Sqoop的实践作出一定的总结,如有错误,仅供参考。 Sqoop Job Sqoop job ...- Sqoop做为关系型数据库RDBMS和大数据平台(HDFS,Hive,Hbase等)导入导出工具,如果不熟悉其参数作用,使用起来各种问题,本文作为博主对Sqoop的实践作出一定的总结,如有错误,仅供参考。
Sqoop Job
-
Sqoop job 的是给使用者提供一个封装sqoop job的功能,其作用是可以自动更新job 的meta信息,让增量导入时指定的last-value自动被更新记录,不用额外的使用其他手段记录信息。
-
Sqoop job操作:
创建job sqoop job --create <job-id> -- [import|export] #注意,创建导入导出job ,最后一个'--'后面要加一个空格 查看job sqoop job --show <job-id> #查看job的详细信息 查看job列表 sqoop job --list 删除job sqoop job --delete <job-id> 执行job sqoop job --exec <job-id>
-
Sqoop ‘- -password /- -password-file’ 参数
sqoop支持俩种密码的输入,一种直接传递(--password),一种使用文件(--password-file),直接在shell 上填写密码,sqoop会提示不要在命令行直接使用密码。 创建sqoop job时,如果直接在命令行使用密码(--password),是无效的,当你执行job时,依然会让你重新输入密码。
-
不输入密码的俩种方式:
1.修改sqoop-site.xml <property> <name>sqoop.metastore.client.record.password</name> <value>true</value> <description>If true, allow saved passwords in the metastore. </description> </property> 此种方式在第一次输入密码后,以后再执行就不需要输入密码 2.使用--password-file 指定密码文件,文件可以是本地文件系统,也可以是HDFS文件 echo -n 'password' > filename.password -n 参数表示不换行输出,当你的密码文件格式不正确时,执行job时会报错 java.sql.SQLException: Access denied for user 'xxx'@'xxxx' (using password: YES)
增量导入
-
限于篇幅,sqoop全量导入导出,这里就不再介绍
-
sqoop使用–incremental参数实现增量导入,有俩种模式:append和lastmodified
-
Append模式
必须参数: --check-column <column-name> #检查列,sqoop根据指定列来查询出大于last-value值的数据,实现增量导入,可以为自增的列,如id,也可以是自增的时间类型 --incremental append #指定append模式 --last-value <init-value> 此种模式,大于last-value的值会被追加到目标数据中,如果指定的是时间类型,那么之前数据被修改后,时间变动导致的增量会被追加,因此会有数据重复,一般指定自增的id。 eg: sqoop job --create job-id \ -- import \ --connect jdbc-url \ --username username \ --password-file password-file-path \ --table table-name \ --num-mappers 2 \ --split-by id \ --hive-import \ --hive-database db \ --hive-table table-name \ --check-column id \ --incremental append \ --last-value 0 \
APPEND 模式支持导入到HDFS和Hive
-
Lastmodified模式
-
lastmodified需要指定一个更新的时间列,会将大于指定时间列的值增量导入到目标数据源,被更新的数据行也会被导入,导入方式又分为append和merge-key俩种模式,需要注意的是,此种增量导入方式不支持直接导入到Hive
必须参数: --target-dir hdfs-path # HDFS路径 --check-column <column-name> #检查列,sqoop根据指定列来查询出大于last-value值的数据,实现增量导入,一般为日期时间类型 --incremental lastmodified #指定lastmodified模式 --last-value <init-value> --append 或--merge-key <column> eg: sqoop job --create job-id \ -- import \ --connect jdbc-url \ --username username \ --password-file password-file \ --table table \ --columns columns \ --num-mappers 1 \ --target-dir target-dir \ --fields-terminated-by '\t' \ --check-column check-column \ --incremental lastmodified \ --last-value "1970-01-01 08:00:00" \ --merge-key id
指定append时,更新和新增的数据会被追加到目标数据,指定merge-key时,更新的数据会和之前数据按照指定的key合并生成最新的数据,新增的数据会被追加,指定的key一般为主键,需要注意的是,如果target-dir 目录存在,那么该sqoop job会重新启动一个MapReduce作业按照merge-key更新之前的数据生成新的数据集,新生成的文件数量不受num-mappers参数影响
增量导出
-
Sqoop 增量导出基于hdfs数据,使用–export-dir指定,实现增量导出的关键是–export-dir 指定路径的数据是否是增量的,可以使用以下方式:
INSERT OVERWRITE TABLE/DIRECTORY 'table_name/directory_anme' SELECT...
-
增量导出也有俩种模式,allowinsert和updateonly,使用–update-mode 参数进行指定,allowinsert模式是对已存在的数据进行更新,新增的数据进行追加,前提是目标表存在主键,updateonly模式(默认)仅允许对存在的数据进行更新,更新指定的key,用–update-key参数指定
必要参数: --update-key <key> --update-mode <allowinsert/updateonly> eg: sqoop export --connect jdbc-url \ --username username \ --password password \ --table <targetTable> \ --fields-terminated-by ‘,’ \ --update-key key \ --update-mode allowinsert \ --export-dir export-dir
-
Java POI 导入导出Excel简单实例源代码
2014-08-28 16:25:39Java POI 导入导出Excel简单实例源代码 该源代码的jar包,参见以下博文附录截图 Java POI导出EXCEL经典实现 Java导出Excel弹出下载框 http://blog.csdn.net/evangel_z/article/details/7332535 web页面导出Excel... -
C#数据库数据导入导出系列之四 WinForm数据库导入导出到Excel
2019-02-08 12:08:58C#数据库数据导入导出系列之四 WinForm数据库导入导出到Excel 在日常的项目中,Excel,Word,txt等格式的数据导入到数据库中是很常见的,我在这里做一下总结 这里将分为Asp.net导入Sql Server,Oracle数据库和...C#数据库数据导入导出系列之四 WinForm数据库导入导出到Excel
在日常的项目中,Excel,Word,txt等格式的数据导入到数据库中是很常见的,我在这里做一下总结
这里将分为Asp.net导入Sql Server,Oracle数据库和WinForm导入Sql Server,Oracle数据库。
C#数据库数据导入导出系列之一 ASP.NET Excel导入Sql Server数据库
C#数据库数据导入导出系列之四 WinForm数据库导入导出到Excel
(注意 这里四篇文章只是基础的方法,若有更高的要求,可以参考
http://www.cnblogs.com/atao/archive/2009/11/15/1603528.html
http://www.cnblogs.com/tonyqus/category/182110.html
http://www.yongfa365.com/Item/NPOI-MyXls-DataTable-To-Excel-From-Excel.html .net 通过NPOI或MyXls把DataTable导出到Excel
)
这里将的数据库数据库导入导出,其实对Sql Server 和Oracle都是通用的
如果使用ADO.Net连接Oracle数据库,需要在引用里添加“System.Data.OracleClient ”,其他方面与连接Sql Server数据库是一样的
SqlConnection cn = new SqlConnection();
OracleConnection oraleCn = new OracleConnection();如果使用诸如Ibatis等持久层框架的话,唯一的区别就是在数据库连接语句上的差别而已。下面是两个例子
Oracle:Data Source=192.168.0.11/Contact;User ID=system;Password=ss;Unicode=True
Sql Server: Data Source=Contact;Server=localhost;uid=sa;pwd=ss
1,数据库导出到Excel
先看界面
然后是代码
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Diagnostics; using Microsoft.Office.Interop.Excel; using System.Reflection; using System.IO; using System.Data.SqlClient; using System.Data.OracleClient; namespace SqlServer__Excel { public partial class SqlDB_To_Excel : Form { public SqlDB_To_Excel() { InitializeComponent(); } private Microsoft.Office.Interop.Excel.Application myExcel = null; private void button1_Click(object sender, EventArgs e) { print(dataGridView1); } public void print(DataGridView dataGridView1) { //导出到execl try { SaveFileDialog saveFileDialog = new SaveFileDialog(); saveFileDialog.Filter = "导出Excel (*.xls)|*.xls"; saveFileDialog.FilterIndex = 0; saveFileDialog.RestoreDirectory = true; saveFileDialog.CreatePrompt = true; saveFileDialog.Title = "导出文件保存路径"; saveFileDialog.ShowDialog(); string strName = saveFileDialog.FileName; if(strName.Length != 0) { //没有数据的话就不往下执行 if(dataGridView1.Rows.Count == 0) return; // toolStripProgressBar1.Visible = true; System.Reflection.Missing miss = System.Reflection.Missing.Value; //实例化一个Excel.Application对象 Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application(); excel.Application.Workbooks.Add(true); excel.Visible = false;//若是true,则在导出的时候会显示EXcel界面。 if(excel == null) { MessageBox.Show("EXCEL无法启动!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } Microsoft.Office.Interop.Excel.Workbooks books = (Microsoft.Office.Interop.Excel.Workbooks)excel.Workbooks; Microsoft.Office.Interop.Excel.Workbook book = (Microsoft.Office.Interop.Excel.Workbook)(books.Add(miss)); Microsoft.Office.Interop.Excel.Worksheet sheet = (Microsoft.Office.Interop.Excel.Worksheet)book.ActiveSheet; sheet.Name = "test"; int m = 0, n = 0; //生成Excel中列头名称 for(int i = 0; i < dataGridView1.Columns.Count; i++) { excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;//输出DataGridView列头名 } //把DataGridView当前页的数据保存在Excel中 for(int i = 0; i < dataGridView1.Rows.Count - 1; i++) { for(int j = 0; j < dataGridView1.Columns.Count; j++) { if(dataGridView1[j, i].ValueType == typeof(string)) { excel.Cells[i + 2, j + 1] = "'" + dataGridView1[j, i].Value.ToString(); } else { excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString(); } } } sheet.SaveAs(strName, miss, miss, miss, miss, miss, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, miss, miss, miss); book.Close(false, miss, miss); books.Close(); excel.Quit(); System.Runtime.InteropServices.Marshal.ReleaseComObject(sheet); System.Runtime.InteropServices.Marshal.ReleaseComObject(book); System.Runtime.InteropServices.Marshal.ReleaseComObject(books); System.Runtime.InteropServices.Marshal.ReleaseComObject(excel); GC.Collect(); MessageBox.Show("数据已经成功导出!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information); // toolStripProgressBar1.Value = 0; System.Diagnostics.Process.Start(strName); } } catch(Exception ex) { MessageBox.Show(ex.Message, "错误提示"); } } public void printAll(System.Data.DataTable dt) { //导出到execl try { SaveFileDialog saveFileDialog = new SaveFileDialog(); saveFileDialog.Filter = "导出Excel (*.xls)|*.xls"; saveFileDialog.FilterIndex = 0; saveFileDialog.RestoreDirectory = true; saveFileDialog.CreatePrompt = true; saveFileDialog.Title = "导出文件保存路径"; saveFileDialog.ShowDialog(); string strName = saveFileDialog.FileName; if(strName.Length != 0) { //没有数据的话就不往下执行 if(dt.Rows.Count == 0) return; // toolStripProgressBar1.Visible = true; System.Reflection.Missing miss = System.Reflection.Missing.Value; //实例化一个Excel.Application对象 Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application(); excel.Application.Workbooks.Add(true); excel.Visible = false;//若是true,则在导出的时候会显示EXcel界面。 if(excel == null) { MessageBox.Show("EXCEL无法启动!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } Microsoft.Office.Interop.Excel.Workbooks books = (Microsoft.Office.Interop.Excel.Workbooks)excel.Workbooks; Microsoft.Office.Interop.Excel.Workbook book = (Microsoft.Office.Interop.Excel.Workbook)(books.Add(miss)); Microsoft.Office.Interop.Excel.Worksheet sheet = (Microsoft.Office.Interop.Excel.Worksheet)book.ActiveSheet; sheet.Name = "test"; int m = 0, n = 0; //生成Excel中列头名称 for(int i = 0; i < dt.Columns.Count; i++) { excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;//输出DataGridView列头名 } //把DataGridView当前页的数据保存在Excel中 if(dt.Rows.Count > 0) { for(int i = 0; i < dt.Rows.Count; i++)//控制Excel中行,上下的距离,就是可以到Excel最下的行数,比数据长了报错,比数据短了会显示不完 { for(int j = 0; j < dt.Columns.Count; j++)//控制Excel中列,左右的距离,就是可以到Excel最右的列数,比数据长了报错,比数据短了会显示不完 { string str = dt.Rows[i][j].ToString(); excel.Cells[i + 2, j + 1] = "'" + str;//i控制行,从Excel中第2行开始输出第一行数据,j控制列,从Excel中第1列输出第1列数据,"'" +是以string形式保存,所以遇到数字不会转成16进制 } } } sheet.SaveAs(strName, miss, miss, miss, miss, miss, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, miss, miss, miss); book.Close(false, miss, miss); books.Close(); excel.Quit(); System.Runtime.InteropServices.Marshal.ReleaseComObject(sheet); System.Runtime.InteropServices.Marshal.ReleaseComObject(book); System.Runtime.InteropServices.Marshal.ReleaseComObject(books); System.Runtime.InteropServices.Marshal.ReleaseComObject(excel); GC.Collect(); MessageBox.Show("数据已经成功导出!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information); // toolStripProgressBar1.Value = 0; System.Diagnostics.Process.Start(strName); } } catch(Exception ex) { MessageBox.Show(ex.Message, "错误提示"); } } private void SqlDB_To_Excel_Load(object sender, EventArgs e) { dataGridView1.DataSource = GetDataTableFromSqlServer(); } private void button2_Click(object sender, EventArgs e) { printAll(GetDataTableFromSqlServer()); } private System.Data.DataTable GetDataTableFromSqlServer() { string sqlconn = "database=database1;server=localhost;uid=sa;pwd=sa"; SqlConnection cn = new SqlConnection(sqlconn); string cmdText = "select * from users"; SqlDataAdapter da = new SqlDataAdapter(cmdText, cn); DataSet ds = new DataSet(); da.Fill(ds, "table1"); return ds.Tables[0]; } private System.Data.DataTable GetDataTableFromOracle() { string oracleconn = "Data Source=192.168.2.105/Database1;User ID=system;Password=ss;Unicode=True"; OracleConnection cn = new OracleConnection(oracleconn); string cmdText = "select * from users"; OracleDataAdapter da = new OracleDataAdapter(cmdText, cn); DataSet ds = new DataSet(); da.Fill(ds, "table1"); return ds.Tables[0]; } } }
结果:代码的思想就是将数据从数据库中读出到DataTable或者DataGridView中,然后遍历他们的每一个单元格的值,给Excel对应的单元格赋值。
使用DataTable作为遍历的对象,是为了去除分页的困扰。
看到这里,如果换一个List<T>对象集合,也应该能导出到数据库中了。
2,Excel数据导入到数据库
在WinForm中Excel导入到数据库中和在WebForm中的导入过程是一样的。可参见前面的内容。
这个系列的博客到此结束!
-
使用EasyPoi进行导入导出Excel(含多sheet导入导出操作)
2018-12-05 11:31:04主要是直接进行导入导出,下面给出一个补充的工具类吧 /** *Excle 文件导入导出Util(easypoi) * @ClassName:EasyPoiUtil * @author leon * @createDate 2018年11月29日 下午15:25:27 * @version v1.0... -
工具 - Chrome浏览器导入导出cookie
2018-10-31 10:43:02使用Chrome插件导入导出。 可以删除cookie、添加、刷新、导入、导出、搜索。 插件名:editthiscookie 插件链接: CSDN下载:https://download.csdn.net/download/sinat_32238399/10754935 Chrome商店:... -
Chrome浏览器导入导出cookie
2019-09-30 16:04:07使用Chrome插件导入导出。 可以删除cookie、添加、刷新、导入、导出、搜索。 插件名:editthiscookie -
Java 导入导出功能总结
2018-07-10 15:24:38项目中经常需要使用导入导出功能来加快数据的操作,尤其是一些项目的后台管理系统,特此奉上我们项目中使用到导入导出代码,均可以实际使用。准备工作:pom中加入以下依赖: <dependency> <groupId>... -
POSTGRESQL 数据库导入导出
2019-06-13 11:29:302.1 pg_dump 及pgsql配置密码导入导出数据 3.pgsql导入整个数据库 4. pg_dumpall导出及psql恢复 5.pg_restore恢复 6.压缩方法 7.xz压缩数据导入数据库方法 8.pg_restore数据导入工具 9.pg_d... -
django导入导出数据
2019-03-23 14:54:36django导入导出数据 -
MaxCompute数据导入导出
2018-09-18 11:47:09MaxCompute数据导入导出1.Tunnel命令导入数据2.MaxCompute Studio导入数据3.Tunnel SDK4.其他导入方式详细介绍请见 MaxCompute提供多种数据导入导出方式,如下所示: 直接在客户端使用Tunnel命令。 通过MaxCompute ... -
Oracle中用exp/imp命令快速导入导出数据
2016-12-14 10:45:19Oracle中用exp/imp命令快速导入导出数据 打开支付宝首页搜索“520218643”,即可领红包,帮忙领个红包还可以抵扣哦 【用 exp 数 据 导 出】: 1 将数据库TEST完全导出,用户名system 密码manager 导出到D:\daochu.... -
MySql导入导出数据库(含远程导入导出)
2014-05-26 14:39:55一、导入导出本地数据库 导出: 1、先运行cmd,cd 到mysql安装目录中的bin文件夹 2、mysqldump -u root -p 数据库名 > 导出文件名.sql 其他情况下: 1.导出整个数据库 mysqldump -u ... -
oracle之——oracle数据库数据导入导出步骤(入门)
2017-04-18 16:38:59oracle数据库数据导入导出步骤(入门)说明: 1.数据库数据导入导出方法有多种,可以通过exp/imp命令导入导出,也可以用第三方工具导出,如:PLSQL 2.如果熟悉命令,建议用exp/imp命令导入导出,避免第三方工具... -
在javaweb中实现excel的导入导出到数据库(mysql)
2019-01-16 17:01:08在做web开发时,我们经常会用到数据表格的导入导出功能,这样可以帮我们节省人工操作的时间,极大提高办事效率。 笔者所做的导入导出是针对Java springMVC框架、工作簿poi以及前端jquery-easyui插件设计的。 采用三... -
DB2批量导入导出
2018-03-22 10:45:52db2批量导入导出 -
selenium之导入导出
2019-04-04 16:41:57selenium之导入导出前言导入 - autoit导出文件定位导出内容校验 前言 文件导出的几个问题: 导入窗口输入指定文件路径, 并确认 确定导出文件路径, 便于下一步读取 导出文件内容校验 导入 - autoit 一般表单的文件... -
关于Navicat for MYSQL导入导出数据表需要注意的几点
2019-11-08 09:51:08我们在写数据库时,不免会遇到一些不可抗力因素,万一数据库表丢失了,那就大发了,现在我们来学习一下如何用Navicat for MYSQL导入导出数据表。 一、导出 1、如果将csdnurl表导出的话,右键点击对应的表。出现菜单... -
Java 5行代码搞定Excel导入导出
2019-07-15 13:16:57Java 5行代码搞定Excel导入导出场景使用创建表格映射对象导出演示导入演示引入mavengithub 场景 在工作中,导出Excel的场景经常出现,比如管理后台导出的功能、批量订正数据库等,在这些场景中的表格数据往往对应... -
pg库导入导出操作
2020-06-28 17:07:57pg库导入导出操作 因此我们可以通过登录Linux服务器操作pg库导入导出 1、先导出,导出后sql文件会存放在liunx当前的目录下,ls查看 导出命令:pg_dump -U来源数据库用户名 -h来源数据库IP -n 来源数据库模式名 来源... -
hbase导入导出数据
2016-09-13 16:57:29hbase导入导出数据 -
nodejs excel导入导出
2016-11-09 11:33:59nodejs excel导入导出 用excel-export包导出 1安装excel-export 2自定义exportExcel函数封装 3业务使用 excel导入 1需要安装的包 2前端代码示例 3后端代码示例nodejs excel导入导出用excel-export包导出1.1安装excel... -
联系人导入导出分析
2018-01-03 22:23:454,导入导出 单卡的导入导出界面如下, 导出到SIM卡的过程界面如下, 在联系人主界面(PeopleActivity)点击右上角的导入导出菜单, 就会出现界面1, PeopleActivity 的onOptionsItemSelected方法对导入导出... -
oraecl导入导出数据
2017-07-17 07:44:08首先,我们导入导出数据,肯定是要通过Oracle自带的可运行程序来完成数据的导入导出工作,imp.exe 和exp.exe这两个可运行文件都放在oracle安装目录下的BIN目录下。 一、以cmd命令操作符导入导出 先以cmd命令操作... -
基于SSM的POI导入导出Excel实战
2018-07-19 21:21:46本课程将给大家分享如何基于SSM实现POI导入导出Excel,并讲解目前企业级JavaWeb应用mvc三层模式的开发流程,可让初学者或者职场萌新掌握如何基于SSM整合第三方框架并采用mvc三层开发模式实现自己的业务模块! -
sql server导入导出方法
2017-11-06 20:57:04远程数据库与本地数据库数据之间的导入导出,从来都是一个值得人关注的问题。 下面,就给你详细介绍SQL2005将远程数据库导入到本地的方法。 首先,将SQL2005打开。方法是:“开始“→“程序”→... -
Angular表格的导入导出
2017-10-30 09:10:30最近小编在公司做项目中用到了表格,大家都知道每一个表格都有导入导出功能,导入导出功能是表格的重点,所以在表格的导入导出上就需要花点心思了,下面咱们一起来看一下吧。 -
jFinal中excel导入导出
2018-03-09 13:51:42jFinal中excel导入导出Jfinal刚接触不久,之前接触的java框架基本上是jeesite,所以,当接到excel导入及模板下载任务时,第一个想到的还是jeesite对Apache POI 3.9的简单封装,实现Excel的导入导出功能(只适用于...