C#+Access数据库操作全部用DataSet

aaa2742 2013-10-06 10:40:57
最近一直在网上查找关于C#访问数据的资料,根据这几天的思考整理,现琢磨出一套操作之法,获取早已有别人用过了,但网上资料大多零散,且方法相互交杂,没有完整的描述。现把这几天的所得写写,也希望得到进一步改善。谢谢!
先说一下平台:VS2010,语言:C#。我采用的方式先连接数据库后,把数据库内容全部填充到DataSet,然后全部的数据操作都是对DataSet,操作玩之后在更新到数据库,像增加、修改等操作,像查询就不用查数据库了。
数据库的学号是主键。
首先建了一个全局类:
namespace Acess
{
public class GlobalValue
{
public static OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + Application.StartupPath + @"\student.mdb");
public static OleDbDataAdapter da = new OleDbDataAdapter("select * from student_info", conn);
//public static OleDbDataAdapter da;
public static DataSet ds = new DataSet();
public static DataSet queryDs = new DataSet();
public static OleDbCommandBuilder cmd = new OleDbCommandBuilder(da);

//public static void UpDataSrc()
//{
// conn.Open();
// da = new OleDbDataAdapter("select * from student_info", conn);
// da.InsertCommand = GlobalValue.cmd.GetInsertCommand();
// da.UpdateCommand = GlobalValue.cmd.GetUpdateCommand();
// da.DeleteCommand = GlobalValue.cmd.GetDeleteCommand();
// da = new OleDbDataAdapter("select * from student_info", conn);
// //da.Fill(GlobalValue.ds);
// conn.Close();
//}
//public static void InitGloVa()
//{
// conn.Open();
// da = new OleDbDataAdapter("select * from student_info", conn);
// da.InsertCommand = GlobalValue.cmd.GetInsertCommand();
// da.UpdateCommand = GlobalValue.cmd.GetUpdateCommand();
// da.DeleteCommand = GlobalValue.cmd.GetDeleteCommand();
// da = new OleDbDataAdapter("select * from student_info", conn);
// da.Fill(GlobalValue.ds);
// conn.Close();
//}
}
}

这样都能访问。
窗体有一个DataGridView的控件,还有几个菜单。
在主场体加载的时候
        private void Form1_Load(object sender, EventArgs e)
{
try
{
GlobalValue.conn.Open();
GlobalValue.da = new OleDbDataAdapter("select * from student_info", GlobalValue.conn);
GlobalValue.da.InsertCommand = GlobalValue.cmd.GetInsertCommand();
GlobalValue.da.UpdateCommand = GlobalValue.cmd.GetUpdateCommand();
GlobalValue.da.DeleteCommand = GlobalValue.cmd.GetDeleteCommand();
GlobalValue.da.MissingSchemaAction = MissingSchemaAction.AddWithKey;
GlobalValue.da.Fill(GlobalValue.ds);
GlobalValue.conn.Close();
dataGridView1.DataSource = GlobalValue.ds.Tables[0];
}
catch (System.Exception ex)
{
throw ex;
}


}

这样运行后就能看到数据库里的数据了。
主界面的“显示数据”按钮是重新连接数据库,更新显示。
下面说一下,各项操作。
1、增加
主窗体调用一个增加窗口,点击增加窗口的按钮时就可以增加。
    private void button1_Click(object sender, EventArgs e)
{

try
{

//string strFilter = "Sno = " + textBox1.Text;
//DataView dv = GlobalValue.ds.Tables[0].DefaultView;
//dv.RowFilter = strFilter;
if (textBox1.Text == string.Empty)
{
MessageBox.Show("学号不能为空!");
this.Close();
return;
}
object key = textBox1.Text;
DataRow dr = GlobalValue.ds.Tables[0].Rows.Find(key);

if (dr != null)
{
MessageBox.Show("已有该学号!");
this.Close();
//GlobalValue.conn.Close();
return;
}
GlobalValue.conn.Open();//打开数据库,建立连接
DataRow drx = GlobalValue.ds.Tables[0].NewRow(); //创建一条新记录行
drx["Sno"] = Convert.ToInt32(textBox1.Text);
drx["Sname"] = textBox2.Text;
drx["Sage"] = Convert.ToInt32(textBox3.Text);
drx["Ssex"] = textBox4.Text;
GlobalValue.ds.Tables[0].Rows.Add(drx); //在表中追加记录

int i = GlobalValue.da.Update(GlobalValue.ds); //更新数据库
if (i > 0)
MessageBox.Show("插入成功!");
else
MessageBox.Show("插入失败!");

GlobalValue.conn.Close();//最后 关闭 数据库 连接
this.Close();
}
catch(Exception a)
{
throw a;
}


}

这里判断是了主键是否重复,也就是主键,不知道还有没有别的好的方法在插入之前判断一下有没有重复的记录?哪位简单说一下
2、删除记录
在DataGridView里选中一行或多行,然后点击菜单里的删除即可。
private void 删除学生信息ToolStripMenuItem_Click(object sender, EventArgs e)
{
try
{
GlobalValue.conn.Open();
foreach (DataGridViewRow row in dataGridView1.SelectedRows)
{
dataGridView1.Rows.Remove(row);
}
GlobalValue.da.Update(GlobalValue.ds);
GlobalValue.conn.Close();

}
catch (System.Exception ex)
{
throw ex;
}


}

说来奇怪,直接用DataGridView的方法删除就可以了,然后更新数据库就可以了。我之前在网上看到的方法有先查看选中DataGridView选中的是哪一行,然后再在DataSet里删除,那样倒也可行,但是不能在DataGridView不能使用的它的排序功能,否则再删除时,删除的不是你选中的那一个。但是直接用我上述的方法倒是弥补刚才方法的缺陷,随便排序,且删除没有错乱。我也是在网上看到的,具体还不是很清除是什么机制,不知道哪位能具体说一说。
3、修改
修改首先是先把DataSet里的内容更新到控件上,即显示你选择的记录。现在做到的是,弹出一个窗体修改,在下拉框选择一个学号,然后修改其他字段。先根据主键找到要修改的记录,然后修改,最后更新到数据库。

private void button1_Click(object sender, EventArgs e)
{

try
{

GlobalValue.conn.Open();
object key = textBox1.Text;
DataRow dr = GlobalValue.ds.Tables[0].Rows.Find(key);
//dr.ItemArray[1] = textBox2.Text;
//dr.ItemArray[2] = textBox3.Text;
//dr.ItemArray[3] = textBox4.Text;
//GlobalValue.ds.Tables[0].Rows.
dr["Sname"] = textBox2.Text;
dr["Sage"] = textBox3.Text;
dr["Ssex"] = textBox4.Text;
GlobalValue.da.Update(GlobalValue.ds);
GlobalValue.conn.Close();
}

catch(Exception a)
{
throw a;
}

}

这个工程是在被人的底子上改的,所以现在感觉到这种方式不太好。最好是在DataGridView里选中,然后弹出窗体修改,下一步打算这么改。
4、查询
查询只查DataSet就行了,输入学号,会查找大于等于该学号的记录。
private void button1_Click(object sender, EventArgs e)
{
try
{
string strFilter = "Sno >= " + textBox1.Text;
//DataRow[] newDataRow = GlobalValue.ds.Tables[0].Select(strFilter);
//foreach (DataRow tempRow in newDataRow)
//{
// GlobalValue.queryDs.Tables[0].Rows.Add(tempRow);
//}
//f1.dataGridView1.DataSource = GlobalValue.queryDs.Tables[0];

//*******DataView只是一个视图,所以其过滤掉的数据只是不显示出来而已。因此,如果认为当前的数据集只剩过滤出来的数据,然后企图用此数据源来更新原始数据库会出现问题。
DataView dv = GlobalValue.ds.Tables[0].DefaultView;
dv.RowFilter = strFilter;
f1.dataGridView1.DataSource = dv;

}
catch(Exception a)
{
throw a;
}

this.Close();

}

以上就是几个方面的内容。例程只是一个简单的模型,本人也是初学者,希望能与大家探讨。
我还有几个想法,在怎么在程序运行的过程中加载(读取)另外一个数据库(当然字段都是符合要求的,主要是考虑一个数据库记录多了,保存到另外一个)?另外在程序运行中怎么新建一个数据库,把数据保存到里面,而不是一上来先连接个已有的数据库然后在存?

...全文
2378 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
DL爱好者 2016-02-18
  • 打赏
  • 举报
回复
正好在学习Access,受用了!
aaa2742 2013-10-10
  • 打赏
  • 举报
回复
如果不用我说的方式,怎么让DataGridView及时更新呢,在重新连接一次重新读取吗?
糊泥巴 2013-10-07
  • 打赏
  • 举报
回复
楼主可以参考一下:DBHelper.cs这个文件看看,网上到处都有!
paopaozhu8899 2013-10-07
  • 打赏
  • 举报
回复
加载读取另一个数据库,只要改变下连接字符串中的access数据库的路劲就行了,比如GlobalValue增加一个方法,传入另一个数据库的路径,然后创建GlobalValue的另一个实例或者把当前GlobalValue的连接更改。 程序在运行中创建另一个数据库,可以用ADO或者ADOX,都有相关的方法的。再或者把当前的access文件里的数据清空,然后把这个文件做资源文件嵌到程序中,创建数据库时只需要从资源文件中还原一个出来
  • 打赏
  • 举报
回复
对于好学习的人,“费心思”是不会白白付出的。所以没有指责任何东西。
aaa2742 2013-10-07
  • 打赏
  • 举报
回复
白费心思了
flashposition 2013-10-06
  • 打赏
  • 举报
回复
觉得没必要主这么做
aaa2742 2013-10-06
  • 打赏
  • 举报
回复
怎么添加附件啊
本文介绍C#访问操作Access数据库的基础知识,并提供一个相关的例程。 1.通过ADO.NET的OleDb相关类来操作Access 主要知识点如下: using System.Data.OleDb; using System.Data; 连接字符串:String connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=product.mdb"; 建立连接:OleDbConnection connection = new OleDbConnection(connectionString); 使用OleDbCommand类来执行Sql语句: OleDbCommand cmd = new OleDbCommand(sql, connection); connection.Open(); cmd.ExecuteNonQuery(); 2.取得Access自增标识字段在插入数据后的id值 cmd.CommandText = @"select @@identity"; int value = Int32.Parse(cmd.ExecuteScalar().ToString()); return value; 3.执行事务 需要用到OleDbTransaction,关键语句如下: OleDbConnection connection = new OleDbConnection(connectionString); OleDbCommand cmd = new OleDbCommand(); OleDbTransaction transaction = null; cmd.Connection = connection; connection.Open(); transaction = connection.BeginTransaction(); cmd.Transaction = transaction; cmd.CommandText=sql1; cmd.ExecuteNonQuery(); cmd.CommandText=sql2; cmd.ExecuteNonQuery(); transaction.Commit(); 4.执行查询,返回DataSet OleDbConnection connection = new OleDbConnection(connectionString); DataSet ds = new DataSet(); connection.Open(); OleDbDataAdapter da = new OleDbDataAdapter(sql, connection); da.Fill(ds,"ds"); 5.分页查询 分页查询使用OleDbDataReader来读取数据,并将结果写到一个DataSet中返回。 以上内容封装为三个可重用的类:AccessDBUtil,AccessPageUtil,Page 代码这里下载AccessDBUtilDemo.rar (191.37 KB , 下载:999次) 本例程是一个c#的winform程序,但是数据访问类可以在Web环境下使用。 本例程演示了: 1.Access数据库的插入,更新,修改,查询; 2.带参数的sql语句的使用,而不是拼SQL; 3.使用DataReader的分页查询,而不是用嵌套的SQL语句来分页; 4.用事务同时执行多个SQL语句; 5.在插入数据的同时返回最新的ID值; 6.整型,实型,字符串,日期型,布尔型五种数据类型的操作; 7.使用正则表达式来验证整数和实数; 8.listview用来显示数据的一些基本用法。 本示例不包括: 1.高效的分页查询,仅仅是提供了一种分页的方法,但我认为DataReader应该比嵌套的SQL语句快(未测试)。 2.完善的分页封装,只提供了分页的简单包装。 3.嵌套的事务处理,提供了同时执行多个sql语句的事务处理,但不支持嵌套事务。 4.listview的使用,只是利用winform控件来演示数据访问,因此不能作为winform编程的良好示例,例如添加数据时界面并没有很好地更新。

110,538

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧