C#和SQL操作Xml
#region DataTableToXml
public static string DataTableToXml(System.Data.DataTable Dt)
{
StringBuilder sbHtml = new StringBuilder();
if (Dt.Rows.Count > 0)
{
sbHtml.Append("<Root>");
for (int j = 0; j < Dt.Rows.Count; j++)
{
sbHtml.Append("<Detail ");
for (int i = 0; i < Dt.Columns.Count; i++)
{
sbHtml.AppendFormat("{0}=\"{1}\" ", Dt.Columns[i], Dt.Rows[j][Dt.Columns[i]]);
}
sbHtml.Append("></Detail>");
}
sbHtml.Append("</Root>");
}
return sbHtml.ToString();
}
#endregion
USE [DataBaseName]
GO
/****** Object: StoredProcedure [dbo].[AdjustPriceDetail_Temp_Excel] Script Date: 12/25/2014 11:11:58 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER Proc [dbo].[AdjustPriceDetail_Temp_Excel]
@UserName nvarchar(50),
@AdjustNo nvarchar(50),
@Detail NText
As
declare @hDoc int
Declare @ProductNo Nvarchar(50)
Declare @ErrorSql Nvarchar(200)
Begin Tran
Begin
set nocount on
------首先清除之前导入的数据
delete from AdjustPriceDetail_Temp where UserName=@UserName
-------导入表格
Select Top 0 ProductNo,GoldPrice,acGold,MStoneCost,SStoneCost,acStone,acLabor,acOthers,acTotal,SalesFactor,SalesPrice
Into #AdjustPrice From AdjustPriceDetail_Temp
exec sp_xml_preparedocument @hDoc output,@Detail
Insert Into #AdjustPrice(ProductNo,GoldPrice,acGold,MStoneCost,SStoneCost,acStone,acLabor,acOthers,acTotal,SalesFactor,SalesPrice)
Select ProductNo,GoldPrice,acGold,MStoneCost,SStoneCost,acStone,acLabor,acOthers,acTotal,SalesFactor,SalesPrice
from openxml(@hDoc,'/Root/Detail')
with AdjustPriceDetail_Temp where ProductNo<>''
if @@Error<>0 goto Err
exec sp_xml_removedocument @hDoc
--1.产品编号
Set @ProductNo=(Select Top 1 ProductNo From #AdjustPrice Group By ProductNo having(COUNT(ProductNo)>1))
IF @ProductNo Is Not Null
Begin
Set @ErrorSql= N'EXCEL表格中货品编号为:'+@ProductNo+'不能出现重复!';
Goto Err
End
Set @ProductNo=(Select Top 1 ProductNo From AdjustPriceDetail_Temp Where ProductNo In(Select ProductNo From #AdjustPrice))
IF @ProductNo Is Not Null
Begin
Set @ErrorSql= N'数据库中货品编号为:'+@ProductNo+'不能出现重复导入!';
Goto Err
End
Set @ProductNo=(Select Top 1 ProductNo From #AdjustPrice Where ProductNo NOT In(Select ProductNo From Product))
IF @ProductNo Is Not Null
Begin
Set @ErrorSql= N'库存表中不存在中货品编号为:'+@ProductNo+'的货品!';
Goto Err
End
INSERT INTO AdjustPriceDetail_Temp
([UserName]
,[AdjustPriceNo]
,[ProductNo]
,[ProductName]
,[StyleNo]
,[SubTypeNo]
,[ItemTypeNo]
,[FinenessNo]
,[SalesTypeNo]
,[NetWtGM]
,[acGoldWtGM]
,[GoldPrice]
,[acGold]
,[MStoneQty]
,[MStoneWt]
,[SStoneQty]
,[SStoneWt]
,[MStoneCost]
,[SStoneCost]
,[acStone]
,[acLabor]
,[acOthers]
,[acTotal]
,[SalesFactor]
,[SalesPrice])
select
@UserName,
@AdjustNo,
A.ProductNo,
B.ProductName,
B.StyleNo,
B.SubTypeNo,
B.ItemTypeNo,
B.FinenessNo,
B.SalesTypeNo,
B.NetWtGM,
B.acGoldWtGM,
A.GoldPrice,
A.acGold,
B.MStoneQty,
B.MStoneWt,
B.SStoneQty,
B.SStoneWt,
A.MStoneCost,
A.SStoneCost,
A.acStone,
A.acLabor,
A.acOthers,
A.acTotal,
A.SalesFactor,
A.SalesPrice
from #AdjustPrice AS A left join Product AS B On A.ProductNo = B.ProductNo
if @@Error<>0 goto Err
Drop Table #AdjustPrice
if @@Error<>0 goto Err
Select N'success' As ErrorSql
End
Commit Tran
Return
Err:
RollBack Tran
Select @ErrorSql As ErrorSql
Return
C#和SQL操作Xml的更多相关文章
- SQL操作XML
前面一段时间为了赶项目的进度,一直在加班,现在空闲了下来将前面碰到的问题整理了一下,发现了一些十分有用的,在此记录下来,看能不能帮助到遇到同样问题的朋友,此文仅是自己个人的意见,若存在问题,还望不宁赐 ...
- sql操作xml小总结
一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和参数.为了更好地支持 XM ...
- (转)SQL对Xml字段的操作
T-Sql操作Xml数据 一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和 ...
- SQL对Xml字段的操作
转:http://www.cnblogs.com/youring2/archive/2008/11/27/1342288.html T-Sql操作Xml数据 一.前言 SQL Server 2005 ...
- SQL Server 操作XML数据
.xml.exist 输入为XQuery表达式,返回0,1或是Null.0表示不存在,1表示存在,Null表示输入为空 .xml.value 输入为XQuery表达式,返回一个SQL Server标量 ...
- (轉載)sql server xml字段的操作
原文轉自:http://blog.csdn.net/hliq5399/article/details/8315373 另外可參考:https://msdn.microsoft.com/en-us/li ...
- sql server 操作xml例子
sql server 操作xml例子 /* sql xml 入门: --by jinjazz --http://blog.csdn.net/jinjazz 1.xml: 能认识元素.属性和值 2.xp ...
- 一个由正则表达式引发的血案 vs2017使用rdlc实现批量打印 vs2017使用rdlc [asp.net core 源码分析] 01 - Session SignalR sql for xml path用法 MemCahe C# 操作Excel图形——绘制、读取、隐藏、删除图形 IOC,DIP,DI,IoC容器
1. 血案由来 近期我在为Lazada卖家中心做一个自助注册的项目,其中的shop name校验规则较为复杂,要求:1. 英文字母大小写2. 数字3. 越南文4. 一些特殊字符,如“&”,“- ...
- SqlServer简单的操作XML以及SQl的 try catch等统一格式
1:SqlServer简单的操作XML: ALTER PROCEDURE [dbo].[SP_CRM_FranchiseeRecharge_Money] @Create_By VARCHAR(), @ ...
随机推荐
- Light OJ 1064 - Throwing Dice
题目大意: 给你n个骰子, 问点数大于等于x的概率是多少? #include<cstdio> #include<cstring> #include<iostream> ...
- 在windows下编辑shell脚本注意点
编辑脚本是直接在windows下写的,并没有使用特定的编辑器或者其他工具,所以很有可能出现一些莫名其妙的异常,这些错误是我们眼睛看不到的,遇到这个情况,例如如下异常或者提示语法错误 Java代码 ...
- [原]RobotFrameWork(二)Ride简单使用及快捷键
一.简单示例 注意:以下操作使用到快捷键的,请先确保没有与其他软件的快捷键设置冲突,比如sogou拼音.有道词典等等 1.启动ride 启动ride方法: 1) 通过界面图标 2) dos命令行: ...
- bzoj 4016 [FJOI2014]最短路径树问题(最短路径树+树分治)
4016: [FJOI2014]最短路径树问题 Time Limit: 5 Sec Memory Limit: 512 MBSubmit: 426 Solved: 147[Submit][Stat ...
- [SAM4N学习笔记]SAM4N工程模板搭建
一.需要安装的软件: 因为笔者是使用MDK-ARM开发的版本是4.72,所以需要安装这个工具,具体在哪里下载自行放狗或问度娘.除了这个重要工具以为,还需要安装Atmel官方的Atmel Studio, ...
- linux 多线程基础3
一.线程属性 线程具有属性,用pthread_attr_t表示,在对该结构进行处理之前必须进行初始化,在使用后需要对其去除初始化.我们用pthread_attr_init函数对其初始化,用pthrea ...
- usaco 购买饲料 && 修剪草坪
购买饲料 Description 如约翰在镇上,沿着公路开车回家,他的家离起点有E公里.他顺便准备买K吨饲料回家.运送饲料是要花油钱的,如果他的车上有X吨饲料,行驶一公里需要X^2元,行驶D公里就 需 ...
- 初识chromium thread的实现
接触chromium已有一段时间,写点东西学习一下吧. 首先说一下用法,如何利用chromium封装好的thread类来开一个线程.在base里有一个封装该类的头文件thread.h,include它 ...
- use of undeclared identifier *** , did you mean ***. in xcode
A property is not the same thing os a instance variable, you should read a little bit of them, there ...
- Django中的ORM进阶操作
Django中的ORM进阶操作 Django中是通过ORM来操作数据库的,通过ORM可以很easy的实现与数据库的交互.但是仍然有几种操作是非常绕也特别容易混淆的.于是,针对这一块,来一个分类总结吧. ...