存储过程导入excel
#region 导入订单
        protected override string DoExcelData(System.Data.DataTable dt)
        {
            string data = "";
            try
            {
                if (dt.Rows.Count == 0)
                {
                    return "excel中无数据";
                }
                #region 接单日期时分取导入报表时间
                string mstime = DateTime.Now.ToString("HH:mm");
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    string time = Convert.ToDateTime(dt.Rows[i]["接单日期"].ToString()).ToString("yyyy-MM-dd");
                    dt.Rows[i]["接单日期"] = time + " " + mstime;
                }
                #endregion
                NameValueCollection cols = new NameValueCollection();
                cols.Add("客户名称", "CustomerAbbr");
                cols.Add("交货单号/出货单号", "SourceNo");
                cols.Add("任务单号", "TaskSourceNo");
                cols.Add("线路分类", "LineType");
                cols.Add("接单日期", "OrderDt");
                cols.Add("发货工厂", "FactoryAbbr");
                cols.Add("收货单位", "DealerAbbr");
                cols.Add("预开票单位", "TaxpayerName");
                cols.Add("出货仓库", "ShipmentHub");
                cols.Add("运输方式", "TransType");
                cols.Add("货物名称", "CargoName");
                cols.Add("品项", "ItemName");
                cols.Add("货量", "GW");
                cols.Add("数量", "Qty");
                //cols.Add("货物分类", "CargoType");
                cols.Add("是否中转", "IsTrans");
                cols.Add("备注", "Remark");
                ChangeDtTitle(dt, cols);
                dt.TableName = "data";
using (System.IO.StringWriter writer = new System.IO.StringWriter())
                {
                    dt.WriteXml(writer, false);
                    data = writer.ToString();
                }
                data = BaseService<dynamic>.GetScale(new { ActionName = "importDetail", data = data, DeptCode = ImportDeptCode, CreateBy = CurrentUserInfo.UserCode }, "Web_T_Order_sp");
            }
            catch (Exception e)
            {
                Exception ex = e;
                while (ex.InnerException != null)
                    ex = ex.InnerException;
                data = ex.Message;
            }
            return data;
        }
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
@data xml='',
SELECT identity(int,1,1) as RowNo,
               t.c.value('CustomerAbbr[1]','varchar(max)') CustomerAbbr,
               CAST(NULL as varchar(50) ) as CustomerCode,
               ISNULL( t.c.value('SourceNo[1]','varchar(max)'),0) SourceNo,
               t.c.value('TaskSourceNo[1]','varchar(max)') TaskSourceNo,
               t.c.value('LineType[1]','varchar(max)') LineType,
               t.c.value('OrderDt[1]','datetime') OrderDt,
               t.c.value('FactoryAbbr[1]','varchar(max)')FactoryAbbr,
               t.c.value('IsTrans[1]','varchar(max)')IsTrans,
               CAST(NULL AS varchar(50))TransCode,
               CAST(NULL as varchar(50) )FactoryCode,
               t.c.value('DealerAbbr[1]','varchar(max)')DealerAbbr,
               CAST(NULL as varchar(50) )DealerCode,
               t.c.value('TaxpayerName[1]','varchar(max)')TaxpayerName,
               CAST(NULL as varchar(50) )TaxpayerID,
               t.c.value('CargoName[1]','varchar(max)')CargoName,
               CAST(NULL as varchar(50) )CargoCode,
               t.c.value('ItemName[1]','varchar(max)')ItemName,
               CAST(NULL as varchar(50) )ItemCode,
               t.c.value('GW[1]','numeric(18,2)')GW,
               t.c.value('Qty[1]','numeric(18,2)')Qty,
               t.c.value('TransType[1]','varchar(max)')TransType,
               t.c.value('ShipmentHub[1]','varchar(max)')ShipmentHub,
               t.c.value('Remark[1]','varchar(max)')Remark,
               CAST(NULL as varchar(50))DeptCode ,
               CAST(NULL as varchar(30))QuotationNo,
               CAST(NULL as int) QuotationRowID,
               CAST(NULL as varchar(30)) SuccFulCode,
               CAST(NULL as varchar(30))LineCode,
               CAST(NULL as int) as OrderType,
               CAST(NULL as varchar(50))OrderNo,
               CAST(NULL AS varchar(50))CustomerTaskNo,
               CAST(NULL AS varchar(50))BussessType
        INTO  #tmpdetailimport
        FROM @data.nodes('//DocumentElement/data')t(c)
存储过程导入excel的更多相关文章
- Oracle导入excel数据方法汇总[转]
		
摘要:在程序编制过程和数据汇总交换过程中,经常会碰到需要将其他人员在office办公环境下编制的文件数据内容导入oracle中的情况.目前程序开发者经常使用的方法有如下几种:1,使用oracle提供的 ...
 - MySQL批量导入Excel、txt数据
		
MySQL批量导入Excel.txt数据 我想Excel是当今最大众化的批量数据管理软件了吧,所以我们会经常涉及到将Excel中数据导入到MySQL中的工作.网上有一些关于直接将Excel导入MySQ ...
 - 一步步实现ABAP后台导入EXCEL到数据库【3】
		
在一步步实现ABAP后台导入EXCEL到数据库[2]里,我们已经实现计划后台作业将数据导入数据库的功能.但是,这只是针对一个简单的自定义结构的导入程序.在实践应用中,面对不同的表.不同的导入文件,我们 ...
 - 一步步实现ABAP后台导入EXCEL到数据库【1】
		
在SAP的应用当中,导入.导出EXCEL文件的情况是一个常见的需求,有时候用户需要将大量数据定期导入到SAP的数据库中.这种情况下,使用导入程序在前台导入可能要花费不少的时间,如果能安排导入程序为后台 ...
 - [Asp.net]常见数据导入Excel,Excel数据导入数据库解决方案,总有一款适合你!
		
引言 项目中常用到将数据导入Excel,将Excel中的数据导入数据库的功能,曾经也查找过相关的内容,将曾经用过的方案总结一下. 方案一 NPOI NPOI 是 POI 项目的 .NET 版本.POI ...
 - IE8下导入EXCEL数据传到客户端以附件下载
		
IE8下导入EXCEL数据传到客户端以附件下载方式出现,而不显示数据,解决方法:以text/html格式返回. HttpResponseMessage message = new HttpRespon ...
 - java的poi技术读取和导入Excel
		
项目结构: http://www.cnblogs.com/hongten/gallery/image/111987.html 用到的Excel文件: http://www.cnblogs.com/h ...
 - 报表工具如何实现多次导入Excel
		
很多人在开发报表的时候会遇到将多张表样相同的excel导入到模板,然后提交至数据库中.但问题是很多情况,在线导入不支持一次性选择多个excel,一次只能选择一个excel,也不能将多个excel中的数 ...
 - .NET导入Excel到SQL数据库
		
在我们开发各类应用型系统,经常会遇到导入导出Excel,为什么会用到他呢?企业或者单位在从无信息化到信息化的一个转变过程.在没有信息化的企业或单位之前,一般都采用Excel来记录相应的数据,做统计计算 ...
 
随机推荐
- Thread Synchronization Queue with Boost
			
介绍:当开发一个多线程程序时,同步是一个很大的问题.如果你的程序需要数据流包,那么用队列是个好办法. 你可以在 http://www.boost.org/ 发现 boost 库和文档,从它的网站可以看 ...
 - inode索引详解
			
理解inode inode是一个重要概念,是理解Unix/Linux文件系统和硬盘储存的基础. 我觉得,理解inode,不仅有助于提高系统操作水平,还有助于体会Unix设计哲学,即如何把底层的复杂性抽 ...
 - oracle 在C# 中调用oracle的数据库时,出现引用库和当前客户端不兼容的问题解决方案
			
oracle 在C# 中调用oracle的数据库时,出现引用库和当前客户端不兼容的问题解决方案 解决方案 1.直接引用 Oracle.ManagedDataAccess.Client.dll动态库即 ...
 - 电子书转换为PDF格式
			
目录 一.mobi 转换 pdf 步骤 二.查看转换后的结果目录 三.将PDF还原文件名且移出至新目录 背景:当我们从网上下载一些电子小说或书籍的时候,一般文件的格式可能是.epub..mobi等.这 ...
 - HTML5 缓存: cache manifest
			
---恢复内容开始--- 1:MIME TYPE:text/cache-manifest 服务器配置MIME类型2:需要由你创建的:NAME.manifest 创建manifest文件3:给 < ...
 - LeetCode(74):搜索二维矩阵
			
Medium! 题目描述: 编写一个高效的算法来判断 m x n 矩阵中,是否存在一个目标值.该矩阵具有如下特性: 每行中的整数从左到右按升序排列. 每行的第一个整数大于前一行的最后一个整数. 示例 ...
 - 《剑指offer》 合并两个排序的链表
			
本题来自<剑指offer> 合并两个排序的链表 题目: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路: A:采用递归的方式(C++ C ...
 - Brup Suite 渗透测试笔记(七)
			
继续接上次笔记: 1.Burp Intruder的payload类型的子模块(Character blocks)使用一种给出的输入字符,根据指定的设置产生指定大小的字符块,表现形式为生成指定长度的字符 ...
 - java----面对对象
			
面对对象: public class Demo { public static void main(String[] args){ Horse h = null; h = new Horse(); / ...
 - C++ gethostname()
			
使用“gethostname();”获取计算机名,先看源码: 在Code::Blocks 16.01中,设置project的Build options...,Debug > Linker set ...