如何将XML从C#传递到SQL Server 2008中的存储过程?

前端之家收集整理的这篇文章主要介绍了如何将XML从C#传递到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,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部分,请参阅我对 Stored procedure: pass XML as an argument and INSERT (key/value pairs)的回答,了解如何在存储过程中使用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)

猜你在找的XML相关文章