c#中的connection对象和command对象与access类似,但在这里我们还将使用其另一个与recordset类似的被称作adodatareader的对象,它负责处理与查询有关的recordset对象。
首先,必须使用微软的access创建一个数据库。运行access,创建一个数据库,但不要创建任何表(我们将在下面的程序中创建表。),保存创建的数据库。
打开控制面板中的odbc图标,点击system dns标签,依次选择add>microsoft access,并点击finish按钮。在拉下来的对话框中输入数据源的名字,比如是mymdb,然后创建数据源,双击ok按钮。
在下面的程序中,我们将创建一个表,并在其中插入一些值。
程序非常地简单和直观。在main()函数中,adoconnection对象将数据源的名字取到构造器中,然后使用adoconenction的open()方法打开该连接。
在连接建立后,程序将创建包含二个字段的表a1,其中字段name的类型为字符型,vno的类型为整型。create table命令已经放在adocommand的构造器中,executenonquery()方法用于执行这一查询,该方法不会返回任何记录集。同样,insert和delete查询也可以放到adocommand的constructor中,因此可以象在vb中那样传递任何sql查询。
adodatareader是新出现的,它是本段程序中主要的对象,负责处理adocommand返回的记录集。使用xecute()方法,就可以看到从数据库中返回的数据。adodatareader的read()方法则返回布尔型的值,true标志着数据在adodatareader对象中,而且将当前指针移动到了adodatareader对象的下一条记录上。
使用visual studio.net β1编译下面的程序代码。
namespace database1
{
using system;
using system.data.ado;
public class class1
{
public class1()
{
//
// 在这里添加constructor的逻辑
//
}
public static int main(string[] args)
{
try
{
adoconnection s = new adoconnection("data source=mymdb");
s.open();
console.writeline("connection established");
//创建表
console.write("want to create a table?(y/n) ");
string ch = console.readline();
if (ch == "y")
{
adocommand createtable = new adocommand("create table a1(vno integer,name char(20))", s);
createtable.executenonquery();
console.writeline("aocommand executed / table created");
}
//在表中插入值
console.write("want to insert some values in a table?(y/n) ");
ch = console.readline();
if (ch == "y")
{
adocommand instable = new
adocommand("insert into a1 values(1, hi)", s);
instable.executenonquery();
console.writeline("values inserted");
}
//删除整个表
console.write("want to delete all records present in the table?(y/n) ");
ch = console.readline();
if (ch == "y")
{
adocommand deletetable = new adocommand("delete from a1", s);
deletetable.executenonquery();
console.writeline("all records deleted from the table");
}
//看所有记录
console.write("want to see all the records present in the table /database (y/n)? ");
ch = console.readline();
if (ch == "y")
{
adocommand allrecs = new adocommand("select * from a1", s);
adodatareader r;
allrecs.execute(out r);
while(r.read())
{
for(int i=0; i < r.fieldcount;i++)
{
console.write(r.getvalue(i)+ " ");
}
console.writeline();
}
console.writeline("all records displayed");
r.close();
}
s.close();
console.readline();
}
catch(system.exception e)
{
console.writeline(e.tostring());
console.readline();
}
return 0;
} // main函数结束
} // class结束
}// 名字空间结束
文章整理:西部数码--专业提供域名注册、虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!


