C# 数据库操作相关命令和语法

3 篇文章 0 订阅
2 篇文章 0 订阅

首先介绍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  如有不懂可以去观看大神解释




                
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值