数据库的访问是所有编程语言中最重要的部分,C#提供了ADO.Net部件用于对数据库进行访问。我们将从最简单易用的微软Access数据库入手讨论在C#中对数据库的访问。
汉台网站建设公司创新互联建站,汉台网站设计制作,有大型网站制作公司丰富经验。已为汉台成百上千家提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的汉台做网站的公司定做!
C# Connection对象和Command对象与Access类似,但在这里我们还将使用其另一个与RecordSet类似的被称作ADODataReader的对象,它负责处理与查询有关的RecordSet对象。
首先,必须使用微软的Access创建一个数据库。运行Access,创建一个数据库,但不要创建任何表(我们将在下面的程序中创建表。),保存创建的数据库。
打开控制面板中的ODBC图标,点击System DNS标签,依次选择Add>Microsoft Access,并点击Finish按钮。在拉下来的对话框中输入数据源的名字,比如是mymdb,然后创建数据源,双击OK按钮。
在下面的程序中,我们将创建一个表,并在其中插入一些值。
程序非常地简单和直观。在Main()函数中,C# Connection对象将数据源的名字取到构造器中,然后使用ADOConenction的Open()方法打开该连接。
在连接建立后,程序将创建包含二个字段的表a1,其中字段name的类型为字符型,vno的类型为整型。Create table命令已经放在ADOCommand的构造器中,ExecuteNonQuery()方法用于执行这一查询,该方法不会返回任何记录集。同样,Insert和Delete查询也可以放到ADOCommand的Constructor中,因此可以象在VB中那样传递任何SQL查询。
ADODataReader是新出现的,它是本段程序中主要的对象,负责处理ADOCommand返回的记录集。使用xecute()方法,就可以看到从数据库中返回的数据。ADODataReader的Read()方法则返回布尔型的值,TRUE标志着数据在ADODataReader对象中,而且将当前指针移动到了ADODataReader对象的下一条记录上。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结束
- }// 名字空间结束
以上介绍C# Connection对象
分享标题:浅谈C#Connection对象
网站路径:http://www.shufengxianlan.com/qtweb/news34/159984.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联