Sql Server xml 类型字段的增删改查

1.定义表结构

在MSSM中新建数据库表CommunicateItem,定义其中一个字段ItemContentXml 为xml类型

2.编辑表数据,新增一行,发现xml类型不能通过设计器录入数据。

需要写sql更新或插入。

DECLARE  @xml XML
SET @xml=‘
<MyHobby>
  <MyCode>1</MyCode>
  <MyName>爬山</MyName>
</MyHobby>
<MyHobby>
  <MyCode>2</MyCode>
  <MyName>游泳</MyName>
</MyHobby>
<MyHobby>
  <MyCode>3</MyCode>
  <MyName>美食</MyName>
</MyHobby>
‘

UPDATE dbo.CommunicateItem SET [email protected] WHERE CommunicateItemId=1;

 在第一个<MyHobby>节点之前添加一个节点

UPDATE dbo.CommunicateItem SET ItemContentXml.modify(‘insert <MyHobby><MyCode>0</MyCode></MyHobby> as first into(/)‘)
 WHERE CommunicateItemId=1;

在<MyCode>0</MyCode>之后添加 <MyName>第一个</MyName>

 UPDATE dbo.CommunicateItem SET ItemContentXml.modify(‘insert  <MyName>第一个</MyName> as last into(/MyHobby)[1]‘)
 WHERE CommunicateItemId=1;

删除刚添加的节点 <MyHobby><MyCode>0</MyCode><MyName>第一个</MyName></MyHobby>

UPDATE dbo.CommunicateConfig SET ItemContentXml.modify(‘delete  /MyHobby[1]‘)
WHERE CommunicateItemId=1;

3.查询XML类型节点数据

  SELECT  *   FROM CommunicateItem  ci WHERE ci.ItemContentXml.exist(‘(/MyHobby/MyName[text()="第一个"])‘)=1
 AND  ci.ItemContentXml.exist(‘(/MyHobby/MyName[text()="爬山"])‘)=1

4.C#写入和读取Xml类型

在sql server2005以及之后的sql server中引入了Xml数据类型,在C#中使用Xml数据类型需要指定参数类型为SqlDbType,参数值类型需要用SqlXml,如下示例:

假定有一种表A,A表有两个字段:ID 类型 int,Data 类型 Xml,我要用C#往表中插入一行记录:

static void InsertA(int aid, string contentXml)
{
//ConnString是连接字符串,需要额外定义
    using (SqlConnection conn = new SqlConnection(ConnString))
    {
        conn.Open();
        string sql = "INSERT INTO [A] ([ID],[Content])VALUES(@id,@content)";
        using (SqlCommand comm = new SqlCommand(sql, conn))
        {
            using (XmlTextReader rdr = new XmlTextReader(contentXml, XmlNodeType.Document, null))
            {
                SqlXml sqlXml = new SqlXml(rdr);

                SqlParameter parmID = new SqlParameter("@id", aid);
                SqlParameter parmContent = new SqlParameter("@content", SqlDbType.Xml, sqlXml.Value.Length);
                parmContent.Value = sqlXml;

                comm.Parameters.Add(parmID);
                comm.Parameters.Add(parmContent);
                comm.ExecuteNonQuery();
            }
        }
        conn.Close();
    }
}

插入数据时需要用SqlXml数据类型作为参数值,但读出Xml类型数据时的C#数据类型是string。如下示例:

string GetContent(int id)
{
    string sql = "SELECT [Content] FROM [A] WHERE [ID] = " + id;

    using (SqlConnection conn = new SqlConnection(ConnString))
    {
        conn.Open();
        using (SqlCommand comm = new SqlCommand(sql,conn))
        {
            string xml = (string)comm.ExecuteScalar();
            return xml;
        }
    }
}

需要注意的是,在插入数据时Xml字段的参数值类型不可以为string,直接用string会报编码错误异常。

参考文档:

  0.XQuery/XPath应用 

   http://www.cnblogs.com/fuhongwei041/archive/2008/09/23/1297420.html

  1.SQL Server操作XML系列

   http://www.cnblogs.com/leep2007/category/392443.html

  2.Sql Server参数化查询之where in和like实现之xml和DataTable传参

   http://www.cnblogs.com/lzrabbit/archive/2012/04/29/2475427.html 

  3.灵活运用 SQL SERVER FOR XML PATH

   http://www.cnblogs.com/doubleliang/archive/2011/07/06/2098775.html

  4.cross apply & outer apply

   http://blog.csdn.net/htl258/article/details/4537421 

  5.SQL XML类型的查询

   http://www.cnblogs.com/stevenshi/archive/2009/11/26/1611458.html

  6.18个小实例入门SQLServer XML查询

   http://www.cnblogs.com/huyong/archive/2012/01/18/2685599.html

  7.SQL Server2008 XML增删改查

   http://blog.csdn.net/szstephenzhou/article/details/8270116

  8.SQL Server对Xml字段的操作

  http://blog.csdn.net/w174504744/article/details/8200329

  9.SQL Server XML应用实例

  http://blog.csdn.net/liangck/article/details/3335158

时间: 2024-08-04 19:52:44

Sql Server xml 类型字段的增删改查的相关文章

sql server连接oracle并实现增删改查

需要一个软件ODAC112040Xcopy_64bit 我连接的oracle是11g r2  sqlserver 是 2016 软件下载 https://pan.baidu.com/s/1OpYmpReEJcPg4wNESWy61Q 服务器先安装.net 2.0和3.5 安装好以后 解压ODAC112040Xcopy_64bit 最好是放到磁盘跟目录,不要有带中文目录名 打开cmd 进入解压目录 运行命令 install.bat all c:\oracle odac 安装好以后c盘会有一个ora

在SQL Server中对视图进行增删改

原文:在SQL Server中对视图进行增删改 Lesktop开源IM发布以后,有一些网友问及如何在嵌入IM后与自己网站的用户系统整合(即如何让嵌入的IM直接使用网站原有的用户数据库,而不需要将已有的用户数据导入到IM的数据库中).Lesktop对Users表(存储用户登录名,昵称,密码等信息的表)都是在存储过程中进行增删改的,显然,如果直接去改Users表相关的存储过程是比较麻烦的,本文将介绍一种较为简单的方法,在不需要修改存储过程和源代码的情况下整合用户系统. 为实现这个目的,先介绍一下在S

Django静态文件配置、request方法、ORM简介、字段的增删改查

app的创建注意事项: 在Django新创建的app要在seetings.py中添加注册,才会生效 创建app:django-adminapp an startapp app名称 或者 python3 mansge.py startpp名称 手动创建的app不会自带存放html的templates文件夹,需要手动创建 Django静态文件配置 对于前端已经写好了的文件,我们只是拿过来使用,那么这些文件都可以称之为"静态文件"; 静态文件可以是:boostrap一类的前端框架,已经写好了

一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器

一.数据库表中字段的增删改查 ''' 直接在modules中对字段进行增删改查 然后在tools下点击Run manage.py Task执行makemigrations和migrate 注意在执行字段的删除过程中需不需要对数据进行备份 ''' 二.路由基础 ''' # url中含有四个参数 # url(regex, view, kwargs=None, name=None) # 正则路径 视图函数地址 默认关键字参数(了解) 路由别名 # r'index' 只要请求中含有index都可以匹配成

序列类型的方法 增删改查

# 序列类型的方法 # 增删改查 # 列表的方法# 增# 列表添加元素 可以添加任何元素# append 在元素最后位置添加# li = [1,2,3,4]# li.append(5) # 在该列表中最后当成一个整体添加元素,不需要赋值,因为他是可变类型(如赋值:li2 = li.append(5)则打印出来是None空)# li.append('aasasas') # 可添加字符串# li.append([5,6,7]) # 可添加列表# print(li) # insert 指定位置添加#

模拟sql实现对员工列表的增删改查

现需要对这个员工信息文件,实现增删改查操作## 可进行模糊查询,语法至少支持下面3种:# # select * from staff_table where dept = "IT"# select * from staff_table where enroll_date like "2013"# 查到的信息,打印后,最后面还要显示查到的条数# 可创建新员工纪录,以phone做唯一键,staff_id需自增# 可删除指定员工信息纪录,输入员工id,即可删除# 可修改员

sql server datetime类型字段使用isnull返回1900-01-01 00:00:00.000的问题

若字段定义的类型为datetime,插入为''(空),那么会默认值为1900-01-01 00:00:00.000 解决方法查询的时候过滤下cast(nullif('','') as datetime) select cast('' as datetime) , cast(nullif('','') as datetime) , isnull(cast(nullif('','') as datetime),getdate()) 原文地址:https://www.cnblogs.com/hofma

表,字段的增删改查

用SQL语句添加删除修改字段 1.增加字段 alter table docdsp add dspcode char(200) 2.删除字段 ALTER TABLE table_NAME DROP COLUMN column_NAME 3.修改字段类型 ALTER TABLE table_name ALTER COLUMN column_name new_data_type 4.修改表字段 alter table test rename column aa to bb; 5.修改表名 alter

XML基本概念及增删改查操作

一.概念及特征: 1. XML 指可扩展标记语言(Extensible Markup Language),用户可以自己定义标签.XML 被设计用来传输和存储数据,而 HTML 用于格式化并显示数据,并且HTML不能自定义标签. 2. XML 文档形成一种树结构, XML 文档必须包含根元素.该元素是所有其他元素的父元素.XML 文档中的元素形成了一棵文档树.这棵树从根部开始,并扩展到树的最底端. 3. XML中所有元素都必须有关闭标签, XML 必须正确地嵌套, XML 的属性值须加引号, XM