zoukankan      html  css  js  c++  java
  • C#访问数据库

    C#访问数据库无疑是非常方便的,下面给出了C#访问MSSQL的基本方法。

     

    首先声明命名空间using System.Data.SqlClient;

    再使用SqlConnection类连接,SqlCommand类执行SQL命令,结果返回给SqlDataReader类或其它类。

     

    各类的基本用法介绍:

    SqlConnection类

    在构造时传入连接数据库字符串,也可以定义后通过ConnectionString属性来设置。

    用Open()连接数据库,用Close()关闭连接。

     

    SqlCommand类

    在构造时传入SQL命令和SqlConnection类对象,也可以定义后通过CommandText属性和Connection属性来设置。

    执行SQL命令并得到结果                 SqlDataReader ExecuteReader()

    执行SQL命令并得到受影响的行数    int ExecuteNonQuery()

     

    SqlDataReader类

    得到共有多少列          FieldCount属性

    得到第i列的列名         string GetName(int i)

    得到第i列的数据类型  Type GetFieldType(int i)

    判断第i列是否为空     bool IsDBNull(int i)

    得到第i列的数据        Object GetValue(int i)也可以直接sr[i].ToString()

    前进到下一列            bool Read()

    关闭                         void Close()

     

     

    对 于每个关联的 SqlConnection,一次只能打开一个 SqlDataReader,在第一个关闭之前,打开另一个的任何尝试都将失败。类似地,在使用 SqlDataReader 时,关联的 SqlConnection 正忙于为它提供服务,直到调用 Close()时为止。

     1     //连接数据库  
     2     string SQLCONNECT = @"server=PC-200907281720SQLEXPRESS;database=master;uid=morewindows;pwd=12345";  
     3     SqlConnection conn = new SqlConnection(SQLCONNECT);  
     4     conn.Open();  
     5       
     6     //连接数据库之后就可以执行SQL命令了  
     7     //使用SqlCommand类的ExecuteReader()返回执行的结果  
     8     string SQLCOMMAND = "select CName, names, C4.LastLogin from C4, S4 where C4.LastLogin = S4.LastLogin order by CName, names";  
     9     SqlCommand sqlcmd = new SqlCommand(SQLCOMMAND, conn);  
    10     SqlDataReader sr = sqlcmd.ExecuteReader();  
    11       
    12     Console.WriteLine("列数:" + sr.FieldCount);     
    13               
    14     Console.WriteLine("列类型分别为:");   
    15     int nSqlCol = sr.FieldCount;  
    16     for (int i = 0; i < nSqlCol; ++i)  
    17     Console.Write(sr.GetFieldType(i) + " ");  
    18     Console.WriteLine();  
    19       
    20     while (sr.Read())  
    21     {  
    22     for (int i = 0; i < nSqlCol; i++)  
    23     Console.Write(sr[i].ToString() + " ");  
    24     Console.WriteLine();  
    25     }  
    26     sr.Close();  
    27       
    28     //通过SqlCommand 类的ExecuteNonQuery()来返回受影响的行数。  
    29     string SQLCOMMAND2 = "update dbo.Messages set MessageNum='15' where MessageID='2'";  
    30     SqlCommand sqlcmd2 = new SqlCommand(SQLCOMMAND2, conn);//也可以用sqlcmd. ConnectionString = SQLCOMMAND2 代替  
    31     int nResult = sqlcmd2.ExecuteNonQuery();  
    32     Console.WriteLine("受影响行数:" + nResult);  
    33       
    34     conn.Close();  
  • 相关阅读:
    Spring中的AOP
    P2782 友好城市
    1576 最长严格上升子序列
    1058 合唱队形 2004年NOIP全国联赛提高组
    5294 挖地雷
    1643 线段覆盖 3
    4768 跳石头
    1026 逃跑的拉尔夫
    2727:仙岛求药
    codevs 4888 零件分组
  • 原文地址:https://www.cnblogs.com/lovesy2413/p/4478449.html
Copyright © 2011-2022 走看看