将txt文件和excel文件导入SQL2000数据库

在做一些web数据库管理系统的时候经常要实现将帐户批量注册的功能,今天就来讲讲如何在C#-web项目中将txt文件和excel文件导入SQL2000数据库。
1.数据库准备
在SQL2000数据库的实例数据库pubs中建立一个数据表txtInsert,字段很简单:id,name两个。
2.txt文本文件导入
对于数据文件导入与导出SQL2000提供了BULK INSERT和BCP语句,在这里可以使用BULK INSERT命令实现。假设在c盘上有一个文本文件stu.txt内容为:
    1,tom
    2,jack
    3,jhon
    ......
实现导入的C#代码如下:
protected System.Web.UI.HtmlControls.HtmlInputFile fName; 
protected System.Web.UI.WebControls.Button BtnInsert;
//上面两个控件自己添加
None.gifprivate void BtnInsert_Click(object sender, System.EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif  
dot.gif{
InBlock.gif                
string fPath=this.fName.PostedFile.FileName;//获得要导入的文本文件                  
InBlock.gif
            string extName=fPath.Substring(fPath.LastIndexOf(".")+1);//获得文件的扩展名            
InBlock.gif
            SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");//数据库连接对象
InBlock.gif
            con.Open();
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif      
dot.gif{                    
InBlock.gif                    SqlCommand com
=new SqlCommand("BULK INSERT pubs.dbo.txtInsert FROM '"+fPath+"' WITH  (FIELDTERMINATOR = ',',ROWTERMINATOR= '\n')",con);
InBlock.gif                       
//其中的FIELDTERMINATOR=','指明字段间所使用的分隔符为逗号
InBlock.gif                       
//其中ROWTERMINATOR= '\n'指明记录间所使用的分隔符为回车
InBlock.gif
                    com.ExecuteNonQuery();
InBlock.gif                    Response.Write(
"<script language=javascript>alert('数据导入成功!')</script>");                    
ExpandedSubBlockEnd.gif                }

InBlock.gif             
catch (SqlException SQLexc)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    Response.Write(
"导入数据库时出错:" + SQLexc.ToString());
ExpandedSubBlockEnd.gif                }

InBlock.gifcon.Close();
ExpandedBlockEnd.gif}

好了,这个txt文件的导入相对简单,在数据库中我也没有设置主键,我在里面也没有加出错回滚事务操作,在下面的excel文件的导入中介绍。
3.excel文件的导入
在c盘里建立一个stu.xls文件,在sheet1工作表中有两列数据如下:
     编号  姓名
     1        tom
     2        jack
     3        john
     ......
注意,工作表的第一行是作为标题行的不会被插入到数据库中,真正导入从第二行开始。
为了演示事物出错回滚,在这里将txtInsert数据库表中的id字段设置为主键。实现的C#代码如下:
None.gifprivate void BtnInsert_Click(object sender, System.EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif  
dot.gif{
InBlock.gif   
string fPath=this.fName.PostedFile.FileName;//获得要导入的文本文件     
InBlock.gif
   string extName=fPath.Substring(fPath.LastIndexOf(".")+1);//获得文件的扩展名   
InBlock.gif
   SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");//数据库连接对象
InBlock.gif
   con.Open();   
InBlock.gif    
//注意下面的连接字符串,是它起到了导入的作用
InBlock.gif
    SqlCommand excelCmd=new SqlCommand("insert into txtInsert select * from OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel 5.0;HDR=YES;DATABASE="+fPath+"',Sheet1$)",con);
InBlock.gif    SqlTransaction myTran
=con.BeginTransaction();//开始一个事务操作
InBlock.gif
    excelCmd.Transaction=myTran;
InBlock.gif    
try
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{       
InBlock.gif     excelCmd.ExecuteNonQuery();
InBlock.gif     myTran.Commit();
//提交事务       
InBlock.gif
     Response.Write("<script language=javascript>alert('数据导入成功!')</script>");
ExpandedSubBlockEnd.gif    }

InBlock.gif    
catch (SqlException err)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{       
InBlock.gif     myTran.Rollback(); 
//出错回滚事务操作
InBlock.gif     
//以下三行是去掉数据库出错信息中的非法字符单引号、回车和换行符,否则在使用时javascript代码将有语法错误
InBlock.gif     
//因为js的编码和c#的编码不同
InBlock.gif
     string errString=err.Message.Replace("'"," ");
InBlock.gif     errString
=errString.Replace(Convert.ToChar(13).ToString(),"");
InBlock.gif     errString
=errString.Replace(Convert.ToChar(10).ToString(),"");
InBlock.gif     
//显示出错信息框
InBlock.gif
     Response.Write("<script language=javascript>alert('导入数据库时出错!详细信息:"+errString+"')</script>");         
ExpandedSubBlockEnd.gif    }
   
InBlock.gif   con.Close();
ExpandedBlockEnd.gif  }
None.gif
这里“显示出错信息框”开始我没有田间那三行代码,结果搞了半天,最后还是在html文件中发现javascript代码部分出现了分行,老是提示“未结束的字符串常量”,所以导致不能打开信息框,郁闷死我了,花了好多时间。
4.将excel中部分列导入数据库的方法
上面讲了关于将整个excel文件导入数据库的方法,那么在实际项目中遇到将excel文件中若干列导入数据库怎么办的呢,原理差不多,我就将代码直接给出了:
string  fPath=this.fName.PostedFile.FileName;//获得要导入的文本文件     
                   string  extName=fPath.Substring(fPath.LastIndexOf(".")+1);//获得文件的扩展名   
                   SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");//数据库连接对象
                   con.Open();None.gif                
                   string mystring="Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = '"+fPath+"';Extended Properties=Excel 8.0";
None.gif                OleDbConnection cnnxls 
= new OleDbConnection (mystring);
None.gif                OleDbDataAdapter myDa 
=new OleDbDataAdapter("select * from [Sheet1$]",cnnxls);
None.gif                DataSet myDs 
=new DataSet();
None.gif                myDa.Fill(myDs);
None.gif                
if(myDs.Tables[0].Rows.Count > 0)
ExpandedBlockStart.gifContractedBlock.gif                
dot.gif{
InBlock.gif                    
string strSql = "";
InBlock.gif                    
string CnnString="Provider=SQLOLEDB;database=pubs;server=.;uid=sa;pwd=";
InBlock.gif                    OleDbConnection conn 
=new OleDbConnection(CnnString);
InBlock.gif                    conn.Open ();
InBlock.gif                    OleDbCommand myCmd 
=null;                    
InBlock.gif                    
for(int i=0; i<myDs.Tables[0].Rows.Count;i++)//第一个工作表中行数,不包括第一行,
ExpandedSubBlockStart.gifContractedSubBlock.gif
                    dot.gif{
InBlock.gif                        
strSql="insert into txtInsert(id,name) values (";
InBlock.gif                        strSql 
+= myDs.Tables[0].Rows[i].ItemArray[0].ToString() + ", '";
InBlock.gif                        strSql 
+= myDs.Tables[0].Rows[i].ItemArray[1].ToString() + "')";
InBlock.gif                        myCmd
=new OleDbCommand(strSql,conn);
                        
InBlock.giftry
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{                            
InBlock.gif                            myCmd.ExecuteNonQuery();InBlock.gif                                                        
InBlock.gif                            Response.Write(
"<script language=javascript>alert('数据导入成功!')</script>");
ExpandedSubBlockEnd.gif                        }

InBlock.gif                        
catch (OleDbException err)
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{                            InBlock.gif                           
InBlock.gif                            Response.Write(
"导入数据库时出错:" +err.ToString());
InBlock.gif                            
break;
ExpandedSubBlockEnd.gif                        }

ExpandedSubBlockEnd.gif                    }

InBlock.gif                    conn.Close();
其他部分代码自己加吧,这里就是出错失误回滚有点不好处理,请高手指教!!

转载于:https://www.cnblogs.com/mc-dragon/archive/2007/01/18/624238.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/364101.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux ifconfig 配置网络接口

Linux ifconfig 可以用来配置网络接口的IP地址、掩码、网关、物理地址等&#xff1b;值得一说的是用Linux ifconfig 为网卡指定IP地址&#xff0c;这只是用来调试网络用的&#xff0c;并不会更改系统关于网卡的配置文件。 如果您想把网络接口的IP地址固定下来&#xff0c;目前有…

Java 8 Friday:Java 8将彻底改变数据库访问

在Data Geekery &#xff0c;我们喜欢Java。 而且&#xff0c;由于我们真的很喜欢jOOQ的流畅的API和查询DSL &#xff0c;我们对Java 8将为我们的生态系统带来什么感到非常兴奋。 对于Java 8系列 &#xff0c;我们很荣幸主持Iu Ming-Yee Iu博士发表的非常相关的嘉宾帖子。 Iu …

WebUploader点击上传文件选择框会延迟几秒才会显示

1 accept: { 2 title: Images, 3 extensions: jpg,jpeg,png, 4 mimeTypes: image/* 5 } 改为 1 accept: { 2 title: Images, 3 extensions: jpg,jpeg,png, 4 mimeTypes: image/jpg,image/jpeg,image/png //修改这行 5 } 更多专业前端知识&#xff0c;请…

Linux文件权限管理

权限管理 1、权限解读 权限&#xff1a;用户针对文件是否有读、写、执行的权利。 权限划分&#xff1a;读&#xff08;Read&#xff09;、写&#xff08;Write&#xff09;、执行&#xff08;eXecute&#xff09; 权限针对用户的划分&#xff1a;主人&#xff08;User&#xff…

Sqoop数据迁移工具的使用

文章作者&#xff1a;foochane 原文链接&#xff1a;https://foochane.cn/article/2019063001.html Sqoop数据迁移工具的使用 sqoop简单介绍 sqoop数据到HDFS/HIVE sqoop数据到MySQL 1 sqoop简单介绍 sqoop是apache旗下一款“Hadoop和关系数据库服务器之间传送数据”的工具。用…

Spring 3.2矩阵变量是什么? –第2部分:代码

关于Spring对Matrix Variables的支持&#xff0c;我最近的博客集中在解释它们是什么以及为什么要使用它们。 整理了内容和原因之后 &#xff0c;此博客全面介绍了如何以及如何使用它们。 我还给出了几个Matrix URI的示例&#xff0c;因此&#xff0c;演示一些处理几个URI的代码…

java中io.nio.aio_Java中网络IO的实现方式-BIO、NIO、AIO

在网络编程中&#xff0c;接触到最多的就是利用Socket进行网络通信开发。在Java中主要是以下三种实现方式BIO、NIO、AIO。关于这三个概念的辨析以前一直都是好像懂&#xff0c;但是表达的不是很清楚&#xff0c;下面做个总结完全辨析清楚。1. BIO方式首先我用一个较为通俗的语言…

CentOS 中 配置 Nginx 支持 https

一、基础设置&#xff1a; 1、yum -y update 2、yum -y install openssl* 3、cd /usr/local/nginx/conf 4、mkdir ./ssl 5、cd ./ssl  # 在ssl目录下用openssl创建 .key 私钥文件和 .crt 证书文件 6、openssl req -x509 -nodes -days 3650 -newkey rsa:2048 -keyout www.usha…

小a与黄金街道(欧拉函数,快速幂)

链接&#xff1a;https://ac.nowcoder.com/acm/contest/317/D来源&#xff1a;牛客网 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒空间限制&#xff1a;C/C 32768K&#xff0c;其他语言65536K64bit IO Format: %lld题目描述 小a和小b来到了一条布满了黄金的街道上。它…

呼叫中心资料

概念&#xff1a;呼叫中心是利用现代通信手段集中处理与客户关系的交互过程的机构。组成&#xff1a; 交换机(PBX)排队机(ACD)计算机电话集成(CTI)交互式语音应答(IVR)来话呼叫管理去话呼叫管理业务计费系统监控系统管理/统计系统客户关系管理(CRM)系统帮助台多种应用服务器&a…

如何在Play Framework 2中实现会话超时

如果您遵循Play Framework 2指南以实施身份验证&#xff1a; http://www.playframework.com/doc-m-e-t-t-i o / n..2..2..2 / Jac agide4-您会注意到Play框架2中没有会话超时。在Play框架1中存在&#xff0c;但Play框架2采用了不同的方法。 我要实现自己的会话超时&#xff0c…

C++中this指针

由类生成对象时&#xff0c;对象中只保存私有数据。 因为由一个类生成的所有对象为其数据服务的方法都是相同的&#xff0c;因此&#xff0c;一个类中的方法是大家所共用的。 而这就牵扯到当对象A调用方法时&#xff0c;如何保证该方法操作的数据是对象A的数据。 #include<i…

jfinal java搭建_Eclipse快速搭建Jfinal web应用 (一)

JFinal简介JFinal 是基于 Java 语言的极速 WEB ORM 框架&#xff0c;其核心设计目标是开发迅速、代码量少、学习简单、功能强大、轻量级、易扩展、Restful。在拥有Java语言所有优势的同时再拥有ruby、python、php等动态语言的开发效率&#xff01;为您节约更多时间&#xff0c…

PHP后台处理jQuery Ajax跨域请求问题 — xx was not called解决办法

// 前台代码 $.ajax({url: http://www.ushark.net/home/save_trial_apply,dataType: jsonp,processData: false,data: $(.layui-layer-content #trialFormInfo).serialize(), }) .done(function(data) {layer.msg(申请成功); }) .fail(function(jqXHR, textStatus, errorThrown…

[转]JavaScript面向对象的特性

如果你使用JavaScript编程&#xff0c;你或许会怀疑它是否包含了面向对象&#xff08;OO&#xff09;的结构。实际上&#xff0c;JavaScript的确支持面向对象的架构――在某种程度上。本文将通过一个可扩展向量图形&#xff08;SVG&#xff09;的实例来说明JavaScript的OO结构。…

命令行获取docker远程仓库镜像列表

命令行获取docker远程仓库镜像列表 获取思路 通过curl获取镜像tag的json串,解析后得到${image}:${tag}的格式 curl获取示例 # curl [:-s] ${API}/${image}/tags curl https://registry.hub.docker.com/v1/repositories/nginx/tags 获取脚本docker-search docker-search.sh #!/b…

如何使用VisualVM监视服务器上的多个JVM

在上一篇文章中&#xff0c;我向您展示了如何使用单个管理员服务器和多个托管服务器启动WebLogic Server。 这些启动之后&#xff0c;您如何检查它们的健康状况&#xff1f; 您可以使用管理员的/ console网络应用。 但是&#xff0c;所有默认的Oracle / Open JDK 6附带的另一个…

java isight zmf_isight集成catia和abaqus,nastran流程详解

isight集成catia和abaqus,nastran流程详解CAD软件中参数化建模&#xff0c;导入有限元软件中计算各个工况&#xff0c;isight根据计算结果调整模型参数&#xff0c;反复迭代计算的过程是尺寸优化的典型问题~下面将比较详解叙述菜鸟新手是如何成功用isight集成catia和abaqus流程…

KindEditor编辑器, 利用ajax动态切换编辑器内容

// 后台成功返回数据后的js处理 KindEditor.remove(#content_id); // 先移除之前创建的编辑器 var editor KindEditor.create(#content_id, { // 再重新创建编辑器     themeType: simple,     resizeType: 1,     urlType: domain,   // 将图片保存为绝对路径…

排序算法 JavaScript

一、冒泡排序 算法介绍&#xff1a; 1.比较相邻的两个元素,如果前一个比后一个大&#xff0c;则交换位置。 2.第一轮把最大的元素放到了最后面。 3.由于每次排序最后一个都是最大的&#xff0c;所以之后按照步骤1排序最后一个元素不用比较。 function bubble_sort(arr){var swa…