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

📄 adosample1.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.ADOSample1 
{
	/// <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;
			this.listBox1.SelectedIndexChanged += new System.EventHandler(this.listBox1_SelectedIndexChanged);
			// 
			// 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){}
		}

		// ADOSample1/form.cs
		private void button1_Click(object sender, System.EventArgs e)
		{
			//create a dataset
			DataSet ds=new DataSet("XMLProducts");
			//connect to the northwind database and 
			//select all of the rows from products table
            
			// We use the connection string from the file Login.cs

            string source = Login.Connection;
			SqlConnection conn=new SqlConnection(source);


			SqlDataAdapter da=new SqlDataAdapter("SELECT * FROM Products" , conn);
      
			//use memory stream so we don't have to create temp files
      
			MemoryStream memStrm=new MemoryStream();
			StreamReader strmRead=new StreamReader(memStrm);
			StreamWriter strmWrite=new StreamWriter(memStrm);
			//fill the dataset
			da.Fill(ds,"Products");
		  //load data into grid
			dataGrid1.DataSource=ds;
			dataGrid1.DataMember="Products";
			//write the xml from the dataset to the memory stream
			ds.WriteXml(strmWrite,XmlWriteMode.IgnoreSchema);
			memStrm.Seek(0,SeekOrigin.Begin);
			//read from the memory stream to a XmlDocument object
			doc.Load(strmRead);
			//get all of the products elements
			XmlNodeList nodeLst=doc.SelectNodes("//ProductName");
			//load them into the list box
			foreach(XmlNode nd in nodeLst)
				listBox1.Items.Add(nd.InnerText);
		}

		private void listBox1_SelectedIndexChanged(object sender, System.EventArgs e)
		{
			//when you click on the listbox.
			//a message box appears with unit price
			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 + -