using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.Data.SqlClient;namespace WindowsApplication3
{
/// <summary>
/// Form1 的摘要说明。
/// </summary>
public class Form1 : System.Windows.Forms.Form
{
private SqlConnection sqlcon;
private SqlDataAdapter sqlDA = new SqlDataAdapter();
private DataSet ds=new DataSet();

private System.Windows.Forms.MainMenu mainMenu1;
private System.Windows.Forms.MenuItem menuItem1;
private System.Windows.Forms.MenuItem menuItem2;
private System.Windows.Forms.DataGrid dataGrid1;
private System.Windows.Forms.MenuItem menuItem3;
private System.Windows.Forms.MenuItem menuItem4;
/// <summary>
/// 必需的设计器变量。
/// </summary>
private System.ComponentModel.Container components = null; public Form1()
{
//
// Windows 窗体设计器支持所必需的
//
InitializeComponent(); //
// TODO: 在 InitializeComponent 调用后添加任何构造函数代码
//
} /// <summary>
/// 清理所有正在使用的资源。
/// </summary>
protected override void Dispose( bool disposing )
{
if( disposing )
{
if (components != null) 
{
components.Dispose();
}
}

if(sqlcon!=null)
sqlcon.Close();

base.Dispose( disposing );
} #region Windows 窗体设计器生成的代码
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.mainMenu1 = new System.Windows.Forms.MainMenu();
this.menuItem1 = new System.Windows.Forms.MenuItem();
this.menuItem2 = new System.Windows.Forms.MenuItem();
this.menuItem3 = new System.Windows.Forms.MenuItem();
this.menuItem4 = new System.Windows.Forms.MenuItem();
this.dataGrid1 = new System.Windows.Forms.DataGrid();
((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).BeginInit();
this.SuspendLayout();
// 
// mainMenu1
// 
this.mainMenu1.MenuItems.AddRange(new System.Windows.Forms.MenuItem[] {
  this.menuItem1});
// 
// menuItem1
// 
this.menuItem1.Index = 0;
this.menuItem1.MenuItems.AddRange(new System.Windows.Forms.MenuItem[] {
  this.menuItem2,
  this.menuItem3,
  this.menuItem4});
this.menuItem1.Text = "文件";
// 
// menuItem2
// 
this.menuItem2.Index = 0;
this.menuItem2.Text = "连接";
this.menuItem2.Click += new System.EventHandler(this.menuItem2_Click);
// 
// menuItem3
// 
this.menuItem3.Index = 1;
this.menuItem3.Text = "读取";
this.menuItem3.Click += new System.EventHandler(this.menuItem3_Click);
// 
// menuItem4
// 
this.menuItem4.Index = 2;
this.menuItem4.Text = "保存";
this.menuItem4.Click += new System.EventHandler(this.menuItem4_Click);
// 
// dataGrid1
// 
this.dataGrid1.ColumnHeadersVisible = false;
this.dataGrid1.DataMember = "";
this.dataGrid1.Dock = System.Windows.Forms.DockStyle.Fill;
this.dataGrid1.HeaderForeColor = System.Drawing.SystemColors.ControlText;
this.dataGrid1.Location = new System.Drawing.Point(0, 0);
this.dataGrid1.Name = "dataGrid1";
this.dataGrid1.Size = new System.Drawing.Size(292, 266);
this.dataGrid1.TabIndex = 0;
// 
// Form1
// 
this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
this.ClientSize = new System.Drawing.Size(292, 266);
this.Controls.Add(this.dataGrid1);
this.Menu = this.mainMenu1;
this.Name = "Form1";
this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen;
this.Text = "Form1";
((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).EndInit();
this.ResumeLayout(false); }
#endregion /// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main() 
{
Application.Run(new Form1());
} public void con(){
string s ="Database=mysql;server=(local);uid=sa;pwd=123";
sqlcon = new SqlConnection(s);
sqlcon.Open();
}
private void menuItem2_Click(object sender, System.EventArgs e)
{
con();
}
private void menuItem3_Click(object sender, System.EventArgs e)
{
if(sqlcon!=null)
readata();
else MessageBox.Show("Error!");
}
public void readata(){
sqlDA.SelectCommand = new SqlCommand("select name,userid from test",sqlcon);
ds.Clear();
sqlDA.Fill(ds);
dataGrid1.DataSource=ds;
} private void menuItem4_Click(object sender, System.EventArgs e)
{
save();
}
public void save()
{
sqlDA=null;
sqlDA=new SqlDataAdapter();
sqlDA.SelectCommand = new SqlCommand("select name,userid from test",sqlcon);
sqlDA.UpdateCommand = new SqlCommand("update test set userid=@userid where name=@name");
sqlDA.UpdateCommand.Parameters.Add("@userid",SqlDbType.Int,4,"userid");
sqlDA.UpdateCommand.Parameters.Add("@name",SqlDbType.Int,4,"name");
sqlDA.UpdateCommand.Connection = sqlcon;
sqlDA.Update(ds);
}
}
}
请问一下这些代码要怎么改才能更新数据库呢,老是保存不了啊!