Green 发表于 2021-7-26 16:14:54

Asp.Net就业课之案例实践第二次课

一.测试连接是否成功

//String str = "server=(local);database=MyDb;uid=asp;pwd=asp";
            String str = "server=.;database=MyDb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);

            conn.Open();
            Response.Write(conn.State);

二.增删改实现
代码实践:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;

namespace demo01
{
    public partial class SqlCommandOne : System.Web.UI.Page
    {
      protected void Page_Load(object sender, EventArgs e)
      {

      }
      //新增
      protected void Button1_Click(object sender, EventArgs e)
      {
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);
            conn.Open(); //记得打开;
            //创建命令对象;
            SqlCommand cmd = new SqlCommand();
            cmd.CommandText = "insert student values(4,'王帅',19,'男',1)";//指定的是cmd的要执行的sql语句
            cmd.Connection = conn;//命令对象与哪个连接对象关联;

            //要执行了;
            int result = cmd.ExecuteNonQuery();
            if (result > 0)
                Response.Write("增加数据成功!");
            else
                Response.Write("增加数据失败!");

            //最后需要关闭连接对象
            conn.Close();
      }

      protected void btnDel_Click(object sender, EventArgs e)
      {
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);
            conn.Open(); //记得打开;
            //创建命令对象;
            SqlCommand cmd = new SqlCommand();
            //from可以省略,但是一般不省略;
            cmd.CommandText = "deletestudent where stuid=1";//指定的是cmd的要执行的sql语句
            cmd.Connection = conn;//命令对象与哪个连接对象关联;

            //要执行了;
            int result = cmd.ExecuteNonQuery();
            if (result > 0)
                Response.Write("删除数据成功!");
            else
                Response.Write("删除数据失败!");

            //最后需要关闭连接对象
            conn.Close();
      }

      protected void btnEdit_Click(object sender, EventArgs e)
      {
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);
            conn.Open(); //记得打开;
            //创建命令对象;
            SqlCommand cmd = new SqlCommand();
            cmd.CommandText = "update student set deptId=1,stuName='王亚亚' where stuId=3";//指定的是cmd的要执行的sql语句
            cmd.Connection = conn;//命令对象与哪个连接对象关联;

            //要执行了;
            int result = cmd.ExecuteNonQuery();
            if (result > 0)
                Response.Write("修改数据成功!");
            else
                Response.Write("修改数据失败!");

            //最后需要关闭连接对象
            conn.Close();
      }
    }
}

三.参数化的增删改实践
参考代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
//引用命名空间;
using System.Data.SqlClient;

namespace demo01
{
    public partial class SqlCommandTwo : System.Web.UI.Page
    {
      protected void Page_Load(object sender, EventArgs e)
      {

      }

      protected void btnAdd_Click(object sender, EventArgs e)
      {
            //定义了一个变量,来表示连接数据库的字符串;
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn=new SqlConnection(str);
            conn.Open();
            //命名对象,由conn创建,就不用写连接属性了;
            SqlCommand cmd = conn.CreateCommand();
            //cmd.CommandText = "insert student values(5,'胡鲁瓦',8,'男',1)";
            //cmd.CommandText = "insert student values("+txtStuId.Text+",'胡鲁瓦',8,'男',1)"; 不拼接了
            string gender=RadioButton1.Checked?"男":"女";
            //StringBuilder,追加;
            String sql = string.Format(@"insert student values({0},'{1}',{2},'{3}',{4})",txtStuId.Text,txtStuName.Text,txtAge.Text,gender,txtDeptID.Text);
            cmd.CommandText = sql;
            //执行
            int result = cmd.ExecuteNonQuery();
            if (result > 0)
                Response.Write("成功");
            else
                Response.Write("失败");
            //关闭
            conn.Close();
            

      }

      protected void btnEdit_Click(object sender, EventArgs e)
      {
            //定义了一个变量,来表示连接数据库的字符串;
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);
            conn.Open();
            //命名对象,由conn创建,就不用写连接属性了;
            SqlCommand cmd = conn.CreateCommand();
            //获取数据;
            string gender = RadioButton1.Checked ? "男" : "女";
            //**************************SqlCommand的参数化设置,比较流行;
            //sql语句的变化
            String sql = "update student set stuName=@stuName,age=@age,gender=@gender,deptid=@deptId where stuId=@stuId";
            //@stuId等,是动态参数;需要我们给它赋值;
            cmd.CommandText = sql;
            //SqlCommand,有参数化的属性;
            //Add("动态参数",值);
            cmd.Parameters.Add("@stuId",txtStuId.Text.Trim());
            cmd.Parameters.Add("@stuName", txtStuName.Text.Trim());
            cmd.Parameters.Add("@age", txtAge.Text);
            cmd.Parameters.Add("@gender", gender);
            cmd.Parameters.Add("@deptId", txtDeptID.Text.Trim());
            //**************************
            //执行
            int result = cmd.ExecuteNonQuery();
            if (result > 0)
                Response.Write("成功");
            else
                Response.Write("失败");
            //关闭
            conn.Close();

      }
    }
}

四.聚合函数查询
参考代码:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;

namespace demo01
{
    public partial class selectOne : System.Web.UI.Page
    {
      protected void Page_Load(object sender, EventArgs e)
      {

      }

      protected void btnSelectAll_Click(object sender, EventArgs e)
      {
            //定义了一个变量,来表示连接数据库的字符串;
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);
            conn.Open();
            //命名对象,由conn创建,就不用写连接属性了;
            SqlCommand cmd = conn.CreateCommand();

            //查看总条数的命令语句
            //string sql = "select count(*) from student";
            string sql = "select MIN(age),max(age) from student";
            cmd.CommandText = sql;

            //执行查询只能得到第一行,一列的值;返回类型:object-->int            
            //int num = Convert.ToInt32(cmd.ExecuteScalar());
            //int num = (int)cmd.ExecuteScalar();
            string num = (String)cmd.ExecuteScalar();
            Response.Write("最小年龄:" + num);
      }
    }
}

五.查询所有学生信息显示到页面
参考代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data.SqlClient;
using System.Data;
using System.Text;//扩充

namespace demo01
{
    public partial class selectTwo : System.Web.UI.Page
    {
      protected void Page_Load(object sender, EventArgs e)
      {

      }

      protected void btnSelect_Click(object sender, EventArgs e)
      {

            //定义了一个变量,来表示连接数据库的字符串;
            string str = "server=.;database=mydb;uid=asp;pwd=asp";
            SqlConnection conn = new SqlConnection(str);
            conn.Open();

            string sql = "select * from student";
            //命令对象;
            SqlCommand cmd = new SqlCommand(sql, conn);
            //查询,查询完毕之后要存放到某个地方;数据集对象,包含若干数据表对象;

            SqlDataAdapter sda = new SqlDataAdapter();
            sda.SelectCommand = cmd;

            DataSet ds = new DataSet();
            sda.Fill(ds, "student");

            DataTable dt=ds.Tables;//获取第一个数据表对象

            //这时候就填充过去了;
            //查看一下列名;
            for (int i = 0; i < dt.Columns.Count; i++) {
                Response.Write(dt.Columns.ColumnName+" ");
            }
            Response.Write("<br/>");

            //最终想要的是数据
            for (int i = 0; i < dt.Rows.Count; i++) {
                //老的方式,参考教材;

                //最新方式
                StringBuilder sb = new StringBuilder();
                sb.Append(dt.Rows["stuId"].ToString()+" ");
                sb.Append(dt.Rows["stuName"].ToString() + " ");
                sb.Append(dt.Rows["age"].ToString() + " ");
                sb.Append(dt.Rows["gender"].ToString() + " ");
                sb.Append(dt.Rows["deptId"].ToString() + "<br/>");

                Response.Write(sb.ToString());
                     
            }

            //关闭
            conn.Close();
      }
    }
}




文档来源:51CTO技术博客https://blog.51cto.com/u_2096101/3188111
页: [1]
查看完整版本: Asp.Net就业课之案例实践第二次课