[英]How to pass XML from C# to a stored procedure in SQL Server 2008?
我想将 xml 文档传递给 sql server 存储过程,例如:
CREATE PROCEDURE BookDetails_Insert (@xml xml)
我想将一些字段数据与其他表数据进行比较,如果匹配,则必须将记录插入到表中。
要求:
如何将 XML 传递给存储过程? 我试过这个,但它不起作用: [工作]
command.Parameters.Add( new SqlParameter("@xml", SqlDbType.Xml) { Value = new SqlXml(new XmlTextReader(xmlToSave.InnerXml, XmlNodeType.Document, null)) });
如何访问存储过程中的 XML 数据?
编辑: [工作]
String sql = "BookDetails_Insert";
XmlDocument xmlToSave = new XmlDocument();
xmlToSave.Load("C:\\Documents and Settings\\Desktop\\XML_Report\\Books_1.xml");
SqlConnection sqlCon = new SqlConnection("...");
using (DbCommand command = sqlCon.CreateCommand())
{
**command.CommandType = CommandType.StoredProcedure;**
command.CommandText = sql;
command.Parameters.Add(
new SqlParameter("@xml", SqlDbType.Xml)
{
Value = new SqlXml(new XmlTextReader(xmlToSave.InnerXml
, XmlNodeType.Document, null))
});
sqlCon.Open();
DbTransaction trans = sqlCon.BeginTransaction();
command.Transaction = trans;
try
{
command.ExecuteNonQuery();
trans.Commit();
sqlCon.Close();
}
catch (Exception)
{
trans.Rollback();
sqlCon.Close();
throw;
}
编辑2 :如何创建一个选择查询来选择页面,基于一些条件的描述。
<booksdetail> <isn_13>700001048</isbn_13> <isn_10>01048B</isbn_10>
<Image_URL>http://www.landt.com/Books/large/00/7010000048.jpg</Image_URL>
<title>QUICK AND FLUPKE</title> <Description> PRANKS AND JOKES QUICK AND FLUPKE </Description> </booksdetail>
对于您问题的第 2 部分,请参阅我对存储过程的回答:将 XML 作为参数传递和插入(键/值对)以获取有关如何在存储过程中使用 XML 的示例。
编辑:下面的示例代码基于评论中给出的具体示例。
declare @MyXML xml
set @MyXML = '<booksdetail>
<isbn_13>700001048</isbn_13>
<isbn_10>01048B</isbn_10>
<Image_URL>http://www.landt.com/Books/large/00/70100048.jpg</Image_URL>
<title>QUICK AND FLUPKE</title>
<Description> PRANKS AND JOKES QUICK AND FLUPKE - CATASTROPHE QUICK AND FLUPKE </Description>
</booksdetail>'
select Book.detail.value('(isbn_13/text())[1]','varchar(100)') as isbn_13,
Book.detail.value('(isbn_10/text())[1]','varchar(100)') as isbn_10,
Book.detail.value('(Image_URL/text())[1]','varchar(100)') as Image_URL,
Book.detail.value('(title/text())[1]','varchar(100)') as title,
Book.detail.value('(Description/text())[1]','varchar(100)') as Description
from @MyXML.nodes('/booksdetail') as Book(detail)
如http://support.microsoft.com/kb/555266中所述,您需要将 xml 数据作为 NText 传递。
您可以按如下方式查询 XML 变量:
DECLARE @PeopleXml XML
SET @PeopleXml = '<People>
<Person>
<Name>James</Name>
<Age>28</Age>
</Person>
<Person>
<Name>Jane</Name>
<Age>24</Age>
</Person>
</People>'
-- put [1] at the end to ensure the path expression returns a singleton.
SELECT p.c.value('Person[1]/Name[1]', 'varchar(50)')
FROM @PeopleXml.nodes('People') p(c) -- table and column aliases
public static string UpdateStaticCertificateFormateNo1Data(StaticCertificateFormatNo1LogicLayer StaticFormat1Detail)
{
SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["ConnectionString"].ToString());
con.Open();
string strXMLRegistrationDetails, strXMLQutPut = "<root></root>";
System.Xml.Serialization.XmlSerializer x = new System.Xml.Serialization.XmlSerializer(StaticFormat1Detail.GetType());
System.IO.MemoryStream stream = new System.IO.MemoryStream();
x.Serialize(stream, StaticFormat1Detail);
stream.Position = 0;
XmlDocument xd = new XmlDocument();
xd.Load(stream);
strXMLRegistrationDetails = xd.InnerXml;
SqlTransaction trn = con.BeginTransaction();
try
{
SqlParameter[] paramsToStore = new SqlParameter[2];
paramsToStore[0] = ControllersHelper.GetSqlParameter("@StaticFormat1Detail", strXMLRegistrationDetails, SqlDbType.VarChar);
paramsToStore[1] = ControllersHelper.GetSqlParameter("@OutPut", strXMLQutPut, SqlDbType.VarChar);
SqlHelper.ExecuteNonQuery(trn, CommandType.StoredProcedure, "UPS_UpdateStaticCertificateFormateNo1Detail", paramsToStore);
trn.Commit();
}
catch (Exception ex)
{
trn.Rollback();
con.Close();
if (ex.Message.Contains("UNIQUE KEY constrastring"))
{ return "Details already in List"; }
else { return ex.Message; }
}
con.Close();
return "Details successfully Added...";
}
您将主要使用 xPath 和 XQuery 来查询和修改 XML 数据。
这是一个很好的起点http://msdn.microsoft.com/en-us/library/ms190798.aspx 。
我真的无法更具体,因为你的问题非常模糊。 如果您需要有关如何使用 XPath 和 XQuery 的帮助,请询问有关如何做某事的具体问题。
var MainXML = new XElement("DocumentElement");
foreach (GridViewRow gvr in gvStudent.Rows)
{
DropDownList ddl = (DropDownList)gvr.FindControl("ddlStudent");
if (ddl.SelectedValue != "Select")
{
string StuId = ((HiddenField)gvr.FindControl("hfStudentId")).Value;
var datacontent =
new XElement("StudentStatus",
new XElement("Status", ddl.SelectedValue),
new XElement("StudentId", StuId)
);
MainXML.Add(datacontent);
}
}
if (MainXML.ToString() == "<DocumentElement />")
{
return;
}
string msg = obj.UpdateStudentProjectStatus(MainXML.ToString());
--------------------------Sql--------------------------
DECLARE
@XMLData XML
IF OBJECT_ID('tempdb..#tmpSelectionParameters') IS NOT NULL --Remove dbo here
DROP TABLE #tmpSelectionParameters -- Remove "tempdb.dbo"
SELECT
CAST(colx.query('data(Status)') AS varchar(500)) AS Status,
CAST(colx.query('data(StudentId)') AS varchar(500)) AS StudentId
INTO #tmpSelectionParameters
FROM @XMLData.nodes('DocumentElement/StudentStatus') AS Tabx ( Colx )
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.