Sql2005中对XML类型字段的运用

sql2005|xml

在SQL2005中增加了xml类型数据。这样,我们可以将我们应用程序中的实体对象直接保存到数据库中。下次要取的时候就可以直接将XML反序列化成实体对象。对于数据量不是很大的情况下,可以考虑使用。

select * from Employee
 where [content].exist('//Age[text()>9000]')=1

此SQL语句中带有xpath的查询,可以找出employee表中content为XML类型列中子节点>9000的所有记录

看一下,运用.

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.Xml.Serialization;
using System.IO;
namespace DevTest
{
    public partial class Form3 : Form
    {
        SqlConnection cn = new SqlConnection("server=192.168.1.100\\SqlExpress;uid=hpasc;pwd=9637004;database=filemanager");
        public Form3()
        {
            InitializeComponent();
            cn.Open();
        }
       
        private void button1_Click(object sender, EventArgs e)
        {
            DataTable dt = cn.GetSchema();
            this.dataGridView1.DataSource = dt;
        }

        private void button2_Click(object sender, EventArgs e)
        {
            DataTable dt = cn.GetSchema("Tables",null);
            this.dataGridView1.DataSource = dt;
        }

        private void button3_Click(object sender, EventArgs e)
        {
            //this.dataGridView1.DataSource = cn.GetSchema("IndexColumns", new string[] { "FileManager", "dbo", "Creers" });
            SqlCommand cmd = new SqlCommand();
            List<Employee> Emps = new List<Employee>();
            cmd.CommandText = "insert into Employee values(@OID,@Name,@Age,@City,@Address,@Birthday,@Content)";
            XmlSerializer ser = new XmlSerializer(typeof(Employee));
          
            cmd.Connection = cn;
            cmd.Prepare();
            this.textBox1.AppendText("生成对象时间" + System.DateTime.Now.ToString());
            for(int i=0;i<10000;i++)
            {
                System.IO.MemoryStream ms = new System.IO.MemoryStream();
                Employee emp=new Employee();
                emp.Address="emp.Address"+i.ToString();;
                emp.Age=i;
                emp.Name="Name"+i.ToString();
                emp.OID=Guid.NewGuid();
                emp.Birthday=DateTime.Now.AddHours(-i);
                emp.City="City"+i.ToString();
                ser.Serialize(ms,emp);
                ms.Position = 0;
               
                StreamReader sr = new StreamReader(ms);
                emp.Content = sr.ReadToEnd();
                sr.Close();
                Emps.Add(emp);
            }
            this.textBox1.AppendText("\r\n结束生成对象时间" + System.DateTime.Now.ToString());
            this.textBox1.AppendText("\r\n开始数据插入" + System.DateTime.Now.ToString());
            foreach(Employee emp in Emps)
            {
                cmd.Parameters.Clear();
                cmd.Parameters.Add("@OID", SqlDbType.UniqueIdentifier).Value = emp.OID;
                cmd.Parameters.Add("@Name", SqlDbType.NVarChar, 50).Value = emp.Name;
                cmd.Parameters.Add("@City", SqlDbType.NVarChar, 50).Value = emp.City;
                cmd.Parameters.Add("@Address", SqlDbType.NVarChar, 50).Value = emp.Address;
                cmd.Parameters.Add("@Age", SqlDbType.Int).Value = emp.Age;
                cmd.Parameters.Add("@Birthday", SqlDbType.DateTime).Value = emp.Birthday;
                cmd.Parameters.Add("@Content", SqlDbType.Xml).Value = emp.Content;
                cmd.ExecuteNonQuery();
            }
            this.textBox1.AppendText("\r\n结否数据插入" + System.DateTime.Now.ToString());
           
        }

        private void button4_Click(object sender, EventArgs e)
        {
             List<Employee> Emps = new List<Employee>();
          
            XmlSerializer ser = new XmlSerializer(typeof(Employee));
            this.textBox1.AppendText("\r\n开始取出数据对象时间" + System.DateTime.Now.ToString());
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = cn;
            cmd.CommandText = "select Content from Employee";
            SqlDataAdapter da = new SqlDataAdapter();
            da.SelectCommand = cmd;
            DataSet ds = new DataSet();
            da.Fill(ds);
          
            foreach (DataRow dr in ds.Tables[0].Rows)
            {
                MemoryStream ms = new MemoryStream();
                StreamWriter sr = new StreamWriter(ms);
                sr.WriteLine(dr[0].ToString());
                sr.Flush();
                ms.Position = 0;
                Employee emp=(Employee)ser.Deserialize(ms);
                Emps.Add(emp);
                sr.Close();
                //Employee emp=(Emp)
            }
            this.textBox1.AppendText("\r\n结束反序列生成对象时间" + System.DateTime.Now.ToString());
            this.dataGridView1.DataSource = Emps;
        }
    }

    [Serializable]
    public class Employee
    {
        Guid _OID;

        public Guid OID
        {
            get { return _OID; }
            set { _OID = value; }
        }

         string _Name;

        public string Name
        {
            get { return _Name; }
            set { _Name = value; }
        }
        int _Age;

        public int Age
        {
            get { return _Age; }
            set { _Age = value; }
        }
      
        string _Address;

        public string Address
        {
            get { return _Address; }
            set { _Address = value; }
        }
        DateTime _Birthday;

        public DateTime Birthday
        {
            get { return _Birthday; }
            set { _Birthday = value; }
        }
        string _City;

        public string City
        {
            get { return _City; }
            set { _City = value; }
        }
        string _Content;

        public string Content
        {
            get { return _Content; }
            set { _Content = value; }
        }

      
    
    }
}

 

时间: 2024-10-11 23:12:14

Sql2005中对XML类型字段的运用的相关文章

SQL查询语句中的bool类型字段值的写法

  SQL查询语句中的bool类型字段值的写法 没有系统地看过SQL语句的写法说明,只是看了一些常用SQL语句的例子.今天写了条select * from table where sex='true',老是提示标准数据类型不匹配(我用的Access),检查了半天,原来sex字段作为bool(是/否)类型,在SQL语句中其值不需要用''引起来.

postgresql-PostgreSQL 中的json类型字段查询

问题描述 PostgreSQL 中的json类型字段查询 PostgreSQL 中的json类型字段查询,该字段只有 '[]',就是空值,怎么查询是这些的数据 解决方案 这不是空值,是个空数组,判断该数组的 length为零即可.

数据库中取Clob类型字段出现乱码

数据|数据库 DataReader 的默认行为是在整个数据行可用时立即以行的形式加载传入数据.但是,对于二进制大对象 (BLOB) 则需要进行不同的处理,因为它们可能包含数十亿字节的数据,而单个行中无法包含如此多的数据.Command.ExecuteReader 方法具有一个重载,它将采用 CommandBehavior 参数来修改 DataReader 的默认行为.您可以将 CommandBehavior.SequentialAccess 传递到 ExecuteReader 方法来修改 Dat

SQL2005中利用xml拆分字符串序列

该问题来自社区提问. 效率不一定很高,但是肯定比替换为select union all好些,起码不用考虑因为字符串过长而导致动态sql语句过长 代码如下: DECLARE @str varchar(1000) DECLARE @idoc int; DECLARE @doc xml; set @str='1¦3¦4¦25' set @doc=cast('<Root><item><ID>'+replace(@str,'¦','</ID></item>

将string插入sql srver表中text类型字段,太长时无法插入,怎么办?

问题描述 现在想把一个很长的string插入到sqlserver数据表中的text类型字段,但当string非常大时无法插入,请问有什么解决办法,谢谢! 解决方案 解决方案二:不会吧,text型都放不下?你的string有多大呀.解决方案三:按住,狠插~解决方案四:text也放不下,那你就不要放了解决方案五:不要使用拼串的Sql,而是使用数据库命令对象如SqlCommand,为其添加Text类型的参数就可以了,比如SqlParameter.解决方案六:请问hbxtlhx能帮我举个例子么?不太明白

使用JDBC4.0操作XML类型的字段(保存获取xml数据)的方法_java

在 Java SE 6 所提供的诸多新特性和改进中,值得一提的是为 Java 程序提供数据库访问机制的 JDBC 版本升级到了 4.0, 这个以 JSR-221 为代号的版本 , 提供了更加便利的代码编写机制及柔性 , 并且支持更多的数据类型 . JDBC 4.0 的新特性分为下述四类: 1. 驱动及连接管理 2. 异常处理 3. 数据类型支持 4. API 的变化 以上说这么都不是本文要讲的重点内容,下面给大家介绍jdbc4.0操作xml类型数据的方法,具体详情如下所示: 在JDBC4.0推出

对象-数据库时间类型字段在jsp页面中显示

问题描述 数据库时间类型字段在jsp页面中显示 我通过js向后台发送请求,查询数据库中的字段.其中有一个字段是date时间类型的, 查询结果在jsp页面中显示的不是时间而是Object. 解决方案 在JSP页面中显示动态时间jsp页面显示动态时间如何在JSP页面中显示当前时间 解决方案二: 前台现实的是object格式的吗? 你可以Tostring()啊 解决方案三: 格式化日期的值,或者直接Tostring 解决方案四: 吧他转为字符串在进行输出 解决方案五: 建议数据库里吧date类型转化成

SQL Server 中BIT类型字段增删查改那点事

原文:SQL Server 中BIT类型字段增删查改那点事 话说BIT类型字段之前,先看"诡异"的一幕,执行Update成功,但是查询出来的结果依然是1,而不是Update的2 当别人问起我来的时候,本人当时也是处于懵逼状态的,后面联想具体的业务突然想起来这个字段是bit类型的 如果把这个现象跟BIT类型字段连续起来就不觉得奇怪了. 废话不多,直接上代码看结果就好了. 先建一个测试表 CREATE TABLE TestBIT ( Id INT IDENTITY(1,1), BitCol

从数据库中导出image类型到XML,如何再导入到数据库

问题描述 小弟使用ds.writeXML("c:/new.xml");讲表中的数据写入new.xml文件,其中包含数据表中包含IMAGE类型数据(使用的是SQLserver数据库),现在想将new.xml文件中的IMAGE类型数据导入到数据库中如何操作. 解决方案 解决方案二:用dataset控件解决方案三:楼主,我将SQLserver中存的图像数据文件取出后提示无效,这是什么原因?解决方案四:自己顶一下大家帮忙啊