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; }
        }

      
    
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值