⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 adosample6.cs

📁 Professional C# 2nd Edition
💻 CS
字号:

using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.Xml;
using System.Data.SqlClient;
using System.IO;


namespace Wrox.ProCSharp.Xml.ADOSample6
{
	/// <summary>
	///		Summary description for Form1.
	/// </summary>
	public class Form1 : System.Windows.Forms.Form
	{
		private System.Windows.Forms.ListBox listBox1;
		private System.Windows.Forms.Button button1;
		private System.Windows.Forms.DataGrid dataGrid1;
		/// <summary>
		///		Required designer variable.
		/// </summary>
		private System.ComponentModel.Container components = null;
		private XmlDocument doc=new XmlDocument();
		public Form1()
		{
			//
			// Required for Windows Form Designer support
			//
			InitializeComponent();

			//
			// TODO: Add any constructor code after InitializeComponent call
			//
		}

		/// <summary>
		///		Clean up any resources being used.
		/// </summary>
		protected override void Dispose( bool disposing )
		{
			if( disposing )
			{
				if (components != null) 
				{
					components.Dispose();
				}
			}
			base.Dispose( disposing );
		}


		#region Windows Form Designer generated code
		/// <summary>
		///		Required method for Designer support - do not modify
		///		the contents of this method with the code editor.
		/// </summary>
		private void InitializeComponent()
		{
			this.dataGrid1 = new System.Windows.Forms.DataGrid();
			this.button1 = new System.Windows.Forms.Button();
			this.listBox1 = new System.Windows.Forms.ListBox();
			((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).BeginInit();
			this.SuspendLayout();
			// 
			// dataGrid1
			// 
			this.dataGrid1.Anchor = (((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) 
				| System.Windows.Forms.AnchorStyles.Left) 
				| System.Windows.Forms.AnchorStyles.Right);
			this.dataGrid1.DataMember = "";
			this.dataGrid1.HeaderForeColor = System.Drawing.SystemColors.ControlText;
			this.dataGrid1.Location = new System.Drawing.Point(0, 248);
			this.dataGrid1.Name = "dataGrid1";
			this.dataGrid1.Size = new System.Drawing.Size(392, 176);
			this.dataGrid1.TabIndex = 2;
			// 
			// button1
			// 
			this.button1.Anchor = System.Windows.Forms.AnchorStyles.Bottom;
			this.button1.Location = new System.Drawing.Point(164, 432);
			this.button1.Name = "button1";
			this.button1.TabIndex = 1;
			this.button1.Text = "Load Data";
			this.button1.Click += new System.EventHandler(this.button1_Click);
			// 
			// listBox1
			// 
			this.listBox1.Anchor = ((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Left) 
				| System.Windows.Forms.AnchorStyles.Right);
			this.listBox1.Name = "listBox1";
			this.listBox1.Size = new System.Drawing.Size(392, 238);
			this.listBox1.TabIndex = 0;
			// 
			// Form1
			// 
			this.AutoScaleBaseSize = new System.Drawing.Size(5, 13);
			this.ClientSize = new System.Drawing.Size(395, 488);
			this.Controls.AddRange(new System.Windows.Forms.Control[] {
																		  this.dataGrid1,
																		  this.button1,
																		  this.listBox1});
			this.Name = "Form1";
			this.Text = "Form1";
			((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).EndInit();
			this.ResumeLayout(false);

		}
		#endregion

		/// <summary>
		/// 	The main entry point for the application.
		/// </summary>
		[STAThread]
		static void Main() 
		{
			try
			{
				Application.Run(new Form1());
			}
			catch(System.IO.FileNotFoundException){}
		}

		  //ADOSample6\form.cs
		    private void button1_Click(object sender, System.EventArgs e)
		    {
		      //new DataSet
		      DataSet ds=new DataSet("XMLProducts");
		      //Make connection and load products rows

		      string source=Login.Connection;
		      
		      SqlConnection conn=new SqlConnection(source);
		      
				
		      SqlDataAdapter da=new SqlDataAdapter("select * from products",conn);
		      //fill the DataSet
		      da.Fill(ds,"products");
		      //edit first row
		      ds.Tables["products"].Rows[0]["ProductName"]="NewProdName";
		      //add new row
		      DataRow dr=ds.Tables["products"].NewRow();;
		      dr["ProductId"]=100;
		      dr["CategoryId"]=2;
		      dr["Discontinued"]=false;
		      dr["ProductName"]="This is the new product";
		      dr["QuantityPerUnit"]=12;
		      dr["ReorderLevel"]=1;
		      dr["SupplierId"]=12;
		      dr["UnitPrice"]=23;
		      dr["UnitsInStock"]=5;
		      dr["UnitsOnOrder"]=0;
		      
		      ds.Tables["products"].Rows.Add(dr);
		      //Write the Schema 
		      ds.WriteXmlSchema("..\\diffgram.xsd");
		      //generate the DiffGram
		      ds.WriteXml("..\\diffgram.xml",XmlWriteMode.DiffGram);
		      ds.AcceptChanges();          
		      
		      //load data into grid
		      dataGrid1.DataSource=ds;
		      dataGrid1.DataMember="products";
		      //new XmlDataDocument
		      doc=new XmlDataDocument(ds);
		      //load the productnames in the list
		      XmlNodeList nodeLst=doc.SelectNodes("//ProductName");
		         
		      foreach(XmlNode nd in nodeLst)
		        listBox1.Items.Add(nd.InnerXml);
		    
		    }
		    
		    private void listBox1_SelectedIndexChanged(object sender, System.EventArgs e)
		    {
		      string srch="XMLProducts/products[ProductName=" + '"' + listBox1.SelectedItem.ToString() + '"' + "]";
		      XmlNode foundNode=doc.SelectSingleNode(srch);
		      if(foundNode!=null)
		        MessageBox.Show(foundNode.SelectSingleNode("UnitPrice").InnerText);
		      else
		        MessageBox.Show("Not found");
		      
    }

	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -