五大对象:
1.Connection(连接数据库)
2、Command(执行T-SQL语句)
3、DataAdapter(用户填充DataSet,断开模式)
4、DataReader(读取数据库,一种只读模式,只向前的)
5、DataSet(数据集,好比电脑的内存)
需要引用的命名空间
System.Data
System.Data.SqlClient
1.Connection
string connectionString="data source=.;initial catalog=Northwind;persist security info=True;user id=sa;password=abcd1234";
using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); }
2.commnd
(1)ExecuteNonQuery(),执行非 SELECT 语句,如增、删、改。返回受影响的行数,int型。
string connectionString="data source=.;initial catalog=Northwind;persist security info=True;user id=sa;password=abcd1234"; using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); //在执行ExecuteNonQuery之前打开就行 string sql="update Employees set name='zhangsan'"; SqlCommand cmd = new SqlCommand(sql, connection);
int result=Convert.ToInt32(cmd.ExecuteNonQuery());
connection.Close(); //在执行ExecuteNonQuery之后关闭就行
}
(2)ExecuteScalar() ,执行 SELECT 查询,返回第一行第一列的值,类型为 Object,常用语执行聚合函数
string connectionString="data source=.;initial catalog=Northwind;persist security info=True;user id=sa;password=abcd1234"; using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); //在执行ExecuteNonQuery之前打开就行 string sql="SELECT * FROM Employees"; SqlCommand cmd = new SqlCommand(sql, connection); int result=Convert.ToInt32(cmd.Executescalar()); //返回的是object类型,需要转成int型 connection.Close(); //在执行ExecuteNonQuery之后关闭就行 }
(3)ExecuteReader(),执行 SELECT 查询,返回一个封装了只读,只进游标的 DataReader 对象
3.DateSet
private static DataSet getDataset() { string connectionString = "Data Source=192.168.0.245;User ID=sa;Password=123456;Persist Security Info=True;Initial Catalog=MES928"; using (SqlConnection connection = new SqlConnection(connectionString)) { string sql = "SELECT * FROM Employees"; SqlDataAdapter adapter = new SqlDataAdapter(); DataSet ds = new DataSet(); adapter.SelectCommand = new SqlCommand(sql, connection); adapter.Fill(ds); return ds; } }
常用方法:
- 计算行数:dt.Rows.Count