(转)c#利用ado.net进行数据库开发的基本步骤

1。创建和数据库连接的connection 对象。
2。配置DataAdapter对象并创建和操作数据集DataSet。
3。将数据库中的表添加到DataSet中。
4。把数据集DataSet帮定到DataGrid上。利用DataAdapter 的Fill方法把数据填充到DataSet,最终的数据库中的数据显示在用户界面的DataGrid中。


c#中浮点数无法精确表达很多实数,它们表达的只是近似值。
为了解决这个问题,c#中提供了一种特殊的数据类型decimal.它可以精确到小数点后面28位。但范围却没有double那么大。
char类型范围为:65535个字符。

c#中从数据库查询记录的方法分类:c#开发研究
     一般使用两种方法:

     一种是通过DataReader对象直接访问;另一种则是通过数据集Dataset和Dataadapter对象访问.

  使用ADO.NET的Datareader对象能从数据库中检索数据。检索出来的数据形成一个只读只进的数据流,存储在客户端的网络缓冲区内。Datareader对象的read方法可以前进到一下条记录。在默认情况下,每执行一次read方法只会在内存中存储一条记录系统的开销非常少。

  创建datareader之前必须先创建sqlcommand对象,然后调用该对象的executereader方法来构造sqldatareader对象,而不是直接使用构造函数。

  下面的示例程序完成的功能是访问sqlserver数据库,并使用datareader从northwind数据中读取记录,并将查询结果通过控制台输出。

程序代码
  
代码
using System;

  
using System.Data;

  
using System.Data.SqlClient;

  
namespace ReadDataFromDB{

  
class Class1{

  
static void Main(string[] args){

  
string myconn="Data Source=localhost;Integrated Security=SSPI;Initial Catalog=Northwind";

  
//需要执行的SQL语句

  
string mysql="select orderID,CustomerID from orders where CustomerID='CHOPS'";

  
//打开数据库连接。
     SqlConnection myconnection=new SqlConnection(myconn);
  myconnection.Open();

     
//创建SqlCommand 对象
  SqlCommand mycommand=new(mysql,myconnection);

     
//通过SqlCommand的ExecuteReader()方法构造DataReader 对象。
  SqlDataReader myreader=mycommand.ExecuteReader();

  
while(myreader.read()){

  Console.WriteLine(myreader.GetInt32(
0)+","+myreader.GetString(1));

  }

  myreader.Close();

  myconnection.Close();

  }

  }

  }

 

  从数据库中读取纪录的另一种方法是使用Dataset对象和Dataadapter对象.Dataset是ADO.NET的主要组件之一,

它用于缓存从数据源检索到的数据信息。Dataadapter作为Dataset和数据源之间的桥接器,用于检索和保存数据。

  Dataadapter从数据库中获取数据后使用Fill方法把数据填充到Dataset中。下面以Sqldataadapter为例说明如何使用Dataset对象和Dataadapter对象从数据库中读取记录。执行查询的关键步骤如下:

  一、创建与数据库建立连接的Sqlconnection,传递连接字符串。

  二、构造包含查询语句的Sqldataadapter对象;

  三、若要使用查询结果填充Dataset对象,则调用命令Fill方法。

  示例:

程序代码
  
代码
using System;

  
using System.Data;

  
using System.SqlClient;

  
namespace ReadDataFromDB2{

  
class Class2{

  
static void Main(string[] args){

  
    
     
string myconn="Data Source=localhost;Integrated Security=SSPI;Initial Catalog=Northwind";

     
//Initialize sql statement.
  string mysql="select CompanyName,ContactName from Customers";
   
     
//Initialize connection string.
  SqlConnection myconnection=new SqlConnection(myconn);

     
//Execute sql.
  SqlDataAdapter mydataadapter=new SqlCommand(mysql,myconnection);

  myconnection.Open();

  DataSet ds
=new DataSet();

  mydataadapter.Fill(ds,
"Customers");

  
for(int i=0;i<ds.Tables["Customers"].Rows.Count;i++){

  Console.WriteLine(ds.Tables[
"Customers"].Row[i][0].ToString()+","+ds.Table["customers"].Row[i][1].ToString());

 


取出DataGrid中某一行中的值
DataGrid.Item(i).cells[j].text;

DataGridView1.DataSource = dataset.Tables["company"].Defaultvies;
与下面两句等效
DataGridView1.DataSource = dataset;
DataGridView1.Datamumber = "company";
posted @ 2009-12-12 23:36  vindy  阅读(847)  评论(0编辑  收藏  举报