首先介绍ADO.NET中的几个常用的对象,介绍的很简单。
1.SqlConnection 这是数据库连接对象,通过对其进行实例化来创建针对数据库的连接,其参数为数据库连接字符串。如下:
SqlConnection conn = new SqlConnection(strConnection)
上面SqlConnection代表连接字符串
上面建立了连接,这个连接的名称为conn,这就相当于建立了一个从程序连接到数据库的水管,水管拉好了,但是要想从数据库中取出数据,还得拧开水龙头才可以,所以使用下面的语句打开水龙头(打开连接)
conn.Open();
OK.,连接打开了,下面就可以取数据了,也就是可以接水了。但是需要注意的是水接完后,还得把水龙头关掉,这就需要下面的语句来执行
conn.close(); //这两句形容的很贴切
1、查询:
最常用的有三种查询数据的方式,我们先介绍SqlCommand对象的ExecuteReader方法,此方法的返回值为SqlDataReader对象,这个对象也是ADO,NET中一个非常重要的对象,这个对象在程序和数据库之间建立了一个流,也可以理解为在程序和数据库之间划了一条线,这条线最开始指向数据库中查询出来的结果集的第1行的上面
SqlDataAdapter和DataSet,DataTable
首先说一下DataTable对象,大家都知道HTML中的Table标签,其是由行和列组成的一个表格,同样DataTable也是有行和列组成的一个表格,每个单元格中存储的都是数据。
然后是DataSet对象,此对象就是一个DataTable的集合,可以通过下标来访问其中特定的DataTable。
重点是SqlDataAdapter对象,此对象的作用是从数据库中查询出数据,然后填充到DataTable或者DataSet中(填充DataSet,其实还是填充到DataTable中,我们以后就直接使用DataTable,而不再重复DataSet
如下:
将SqlDataAdapter对象和SqlCommand对象产生关联。
使用SqlDataAdapter对象的Fill方法来填充DataTable,
SqlDataAdapter adapter=new SqlDataAdapter(cmd);
DataTable dt=new DataTable();
adapter.Fill(dt);
2、delete,update,insert
ExecuteNonQuery()方法就是执行一条插入语句或者一条更改语句或者一条删除语句,其返回的是受影响的行数,只要其返回值>1,就表明执行成功。至于其为什么不能执行查询语句呢?因为查询语句要返回的是数据,而不是查询出了几行,所以不能使用这个方法。
代码示例:
自己写的一些代码:调用存储过程
SqlConnection conn = new SqlConnection(connStr);
conn.Open();
SqlCommand comm = new SqlCommand("DeleteGroup", conn);
comm.CommandType = CommandType.StoredProcedure;
comm.Parameters.Add("@groupid", SqlDbType.Int).Value = groupid;
comm.Parameters.Add("@return", SqlDbType.Int).Direction = ParameterDirection.ReturnValue;//获取存储过程的返回值
//comm.Parameters.Add("@return", "").Direction = ParameterDirection.ReturnValue;//获取存储过程的返回值 这种方法会有警告
//comm.Parameters.Add("@outname", SqlDbType.Int).Direction = ParameterDirection.Output;//获取存储过程的Output输出参数值
//comm.Parameters.Add("@outname", SqlDbType.Decimal).Direction = ParameterDirection.Output;//也可以这么写
comm.ExecuteNonQuery();
string value = comm.Parameters["@return"].Value.ToString();//把返回值赋值给value
if (value == "1")
{
return true;
}
else
{
return false;
}
1、注册:
string strConnection = "user id=sa;password=sa;initial catalog=MyTest;Server=YHB;Connect Timeout=30";
//实例化数据库连接对象
using (SqlConnection conn = new SqlConnection(strConnection))
{
//实例化命令对象
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "insert into Users(username,password,email) values(@username,@password,@email)";
//实例化SqlParameter对象,为@username等建立映射关系
SqlParameter username = new SqlParameter("@username", this.txt_username.Text);
SqlParameter password = new SqlParameter("@password", this.txt_username.Text);
SqlParameter email = new SqlParameter("@email", this.txt_username.Text);
//将映射关系添加到cmd中
cmd.Parameters.Add(username);
cmd.Parameters.Add(password);
cmd.Parameters.Add(email);
//打开数据连接
conn.Open();
//执行插入操作
if (cmd.ExecuteNonQuery() >0)
{
Response.Redirect("Login.aspx");
}
else
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('注册失败')</script>", false);
}
}
}
2、登录
//连接字符串
string strConnection = "user id=sa;password=sa;initial catalog=MyTest;Server=YHB;Connect Timeout=30";
//实例化数据库连接对象
using (SqlConnection conn = new SqlConnection(strConnection))
{
//实例化命令对象
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select password from users where username=@username";
//实例化SqlParameter对象,为@username等建立映射关系
SqlParameter username = new SqlParameter("@username", this.txt_username.Text);
//将映射关系添加到cmd中
cmd.Parameters.Add(username);
//打开数据连接
conn.Open();
object obj = cmd.ExecuteScalar();
if (obj == null)
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('用户名不存在')</script>", false);
}
else
{
string password = Convert.ToString(obj);
//比较从数据库获取的密码和用户输入的密码是否一致
if (password != this.txt_password.Text)
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('密码不正确')</script>", false);
}
else
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('登陆成功')</script>", false);
}
}
}
}
上面使用的是cmd.ExecuteScalar()方法来获取查询结果。下面我们改成使用SqlDataReader对象来操作数据
//连接字符串
string strConnection = "user id=sa;password=sa;initial catalog=MyTest;Server=YHB;Connect Timeout=30";
//实例化数据库连接对象
using (SqlConnection conn = new SqlConnection(strConnection))
{
//实例化命令对象
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select password from users where username=@username";
//实例化SqlParameter对象,为@username等建立映射关系
SqlParameter username = new SqlParameter("@username", this.txt_username.Text);
//将映射关系添加到cmd中
cmd.Parameters.Add(username);
//打开数据连接
conn.Open();
SqlDataReader reader = cmd.ExecuteReader();
//判断是否有查询结果
if (reader.HasRows)
{
//读取下一行
while (reader.Read())
{
<span style="color:#ff0000;">string password =Convert.ToString(reader.GetSqlString(reader.GetOrdinal("password")));</span>
if (string.IsNullOrEmpty(password))
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('用户名不存在')</script>", false);
}
else
{
//比较从数据库获取的密码和用户输入的密码是否一致
if (password != this.txt_password.Text)
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('密码不正确')</script>", false);
}
else
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('登陆成功')</script>", false);
}
}
}
}
}
}
下面解释一下红色的那句代码。可以将其拆解开来。
reader.GetOrdinal("password"):获取指定列的序号,也就是说SqlDataReader对象每次只读取1行,这个方法获取的是“password”这一列在这1行的序号,也就是索引
reader.GetSqlString(reader.GetOrdinal("password")):GetSqlString方法根据列的序号获取列的值
最后将返回值转换成string类型
最后使用第三种方式,代码如下:
//连接字符串
string strConnection = "user id=sa;password=sa;initial catalog=MyTest;Server=YHB;Connect Timeout=30";
//实例化数据库连接对象
using (SqlConnection conn = new SqlConnection(strConnection))
{
//实例化命令对象
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select password from users where username=@username";
//实例化SqlParameter对象,为@username等建立映射关系
SqlParameter username = new SqlParameter("@username", this.txt_username.Text);
//将映射关系添加到cmd中
cmd.Parameters.Add(username);
//声明SqlDataAdapter对象
SqlDataAdapter adapter = new SqlDataAdapter(cmd);
DataTable dt = new DataTable();
adapter.Fill(dt);
//判断是否有查询结果
if (dt.Rows.Count>0)
{
//因为最多只返回一行数据(因为用户名是唯一的),所以可以直接使用dt.Rows[0]标示第1行,使用dt.Rows[0]["password"]来获取第1行中列名称为"password"的字段的值。
string password = Convert.ToString(dt.Rows[0]["password"]);
if (string.IsNullOrEmpty(password))
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('用户名不存在')</script>", false);
}
else
{
//比较从数据库获取的密码和用户输入的密码是否一致
if (password != this.txt_password.Text)
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('密码不正确')</script>", false);
}
else
{
ClientScript.RegisterStartupScript(GetType(), "提示", "<script>alert('登陆成功')</script>", false);
}
}
}
}
}
部分内容摘自:http://blog.csdn.net/mynewdays/article/details/6780533 如有不懂可以去观看大神解释