.NET连接金沙国际官网以及基本的增删改查操作教程

 更新时间:2018年01月12日 10:11:18   作者:https://www.cnblogs.com/dichuan/p/8026130.html   我要评论
这篇文章主要给大家介绍了关于.NET连接金沙国际官网以及基本的增删改查操作教程的相关资料,对于刚入门的新手们来说是个很好的入门教程,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。

一、前言

因为这学期选修的 .net 课程就要上机考试了,所以总结下.net 操作 SqlServer 数据的方法。(因为本人方向是 Java,所以对.net 的了解不多,但以下所写代码均是经过测试成功的),下面话不多说了,来一起看看详细的介绍吧。

二、.net 连接金沙国际官网

 在web.config文件中配置金沙国际官网连接,代码写在<configuration></configuration>

 <appSettings>
 <add key="connstring" value="user id=sa; password=sa123456; database=dataset; server=(local)" />
 </appSettings>

其中 sa  为 SqlServer 金沙国际官网账号,sa123456 为金沙国际官网账号密码,dataset 位金沙国际官网名。

通过上面的代码大家不难看出这是通过SqlServer金沙国际官网的账号连接的。那么如果需要通过Windows身份认证连接呢?

 <appSettings>
 <add key="connstring" value="Data Source=.;Initial Catalog=dataset;Integrated Security=True"/>
 </appSettings>

其中,dataset 为金沙国际官网名。

配置好了之后,再在cs后台文件中使用 Connection 对象连接

String constr = ConfigurationManager.AppSettings["connstring"].ToString();  
SqlConnection myconn = new SqlConnection(constr);

很明显,第一个句获取我们在 web.config 中配置的金沙国际官网的信息的字符串,然后 new 一个 SqlConnection 对象。

这个时候也许你会想,既然是获取配置文件中的字符串,那么可不可以直接在cs后台文件中写而不需要再配置文件中配置后再获取呢?答案是肯定的。

String constr = "Data Source=.;Initial Catalog=dataset;Integrated Security=True";
SqlConnection myconn = new SqlConnection(constr);

仔细对比下先前写的配置文件,就知道这两种方式的相同点了。

那么现在简单说下 Connection 对象是个什么。在 ADO.NET 中 Connection 对象的主要用途是打开和关闭金沙国际官网的连接,通过这个对象,可以对金沙国际官网进行访问和操作。

String constr = "Data Source=.;Initial Catalog=dataset;Integrated Security=True";
SqlConnection myconn = new SqlConnection(constr);
myconn.Open();
//相关金沙国际官网操作
myconn.Close();

Open 就是打开金沙国际官网,Close 就是关闭金沙国际官网。

三、.net 操作金沙国际官网

那么通过 Connection 对象打开金沙国际官网后怎么对金沙国际官网操作呢?在 Dao.Net 中提供了Command 对象,主要就是用来对金沙国际官网进行增、删、改、查的操作。

下面我们直接看个查找操作的例子:

String constr = "Data Source=.;Initial Catalog=dataset;Integrated Security=True";
   SqlConnection myconn = new SqlConnection(constr);
   myconn.Open();
   string sql = "select * from custom ";
   SqlCommand cmd = new SqlCommand(sql, sqlConnection);
   SqlDataReader dataReader = cmd.ExecuteReader();
   Show.Text = "<tr><td>学号</td><td>姓名</td><td>学院</td><td>年龄</td><td>昵称</td></tr>";
   while (dataReader.Read())
   {
    Show.Text = Show.Text + "<tr><td>" + dataReader[0].ToString()
     + "</td><td>" + dataReader[1].ToString()
     + "</td><td>" + dataReader[2].ToString()
     + "</td><td>" + dataReader[3].ToString()
     + "</td><td>" + dataReader[4].ToString() + "</td></tr>";
   }
   sqlConnection.Close();

通过上面这段代码,不难发现,在开启Connection对象后,首先我们需要写一段查询的sql语句:

   string sql = "select * from custom ";

然后,new 一个SqlCommand对象,参数是 sql 语句 和 Connection 对象 。

   SqlCommand cmd = new SqlCommand(sql, sqlConnection);

再然后,我们通过 SqlCommand 对象的 ExecuteReader 方法,执行查询语句,并返回一个DataReader 对象。

   SqlDataReader dataReader = cmd.ExecuteReader();

再再然后,就是将 DataReader 对象中的数据(也就是我们查询的数据)读取出来了

while (dataReader.Read())
   {
    Show.Text = Show.Text + "<tr><td>" + dataReader[0].ToString()
     + "</td><td>" + dataReader[1].ToString()
     + "</td><td>" + dataReader[2].ToString()
     + "</td><td>" + dataReader[3].ToString()
     + "</td><td>" + dataReader[4].ToString() + "</td></tr>";
   }

最后,当然是关闭我们的 Connection 对象了。

   sqlConnection.Close();

查询操作是通过 Command 对象的 ExecuteReader 方法来操作,那么增删改呢?

增删改的话就得用到 Command 对象的 ExecuteNonQuery 方法了。这个方法返回的是受影响的行数,也就是说如果操作失败,返回的是0。

还是看个增加数据的例子吧:

myconn.Open();
   String sql = "insert into custom values('" + uid.Text + "','" + uname.Text + "','" + udepart.Text
    + "'," + uage.Text + ",'" + uename.Text + "','" + upassword.Text + "')";
   SqlCommand cmd = new SqlCommand(sql, myconn);
   if (cmd.ExecuteNonQuery() > 0)
   {
    this.Response.Write("<script language='javascript'>alert('增加成功!')</script>");
   }
   else
   {
    this.Response.Write("<script language='javascript'>alert('添加失败!')</script>");
   }
   myconn.Close();

通过上面代码,不难发现,其实套路和我们写的查询差不多,就是sql语句不同和调用的Command对象不同而已。

但是,仔细看会发现这段代码是使用了 sql 语句拼接的。这种方式写起来比较乱(又是双引号又是单引号的),还有可能被 sql 注入。这个时候就会想,能不能有占位符呢?答案是肯定的。

myconn.Open();
   SqlCommand cmd = myconn.CreateCommand();
   cmd.CommandText = "insert into custom values(@uid,@uname,@udepart,@uage,@uename,@upassword)";
   cmd.Parameters.AddWithValue("@uid", uid.Text);
   cmd.Parameters.AddWithValue("@uname", uname.Text);
   cmd.Parameters.AddWithValue("@udepart", udepart.Text);
   cmd.Parameters.AddWithValue("@uage", uage.Text);
   cmd.Parameters.AddWithValue("@uename", uename.Text);
   cmd.Parameters.AddWithValue("@upassword", upassword.Text);
   if (cmd.ExecuteNonQuery() > 0)
   {
    this.Response.Write("<script language='javascript'>alert('增加成功!')</script>");
   }
   else
   {
    this.Response.Write("<script language='javascript'>alert('添加失败!')</script>");
   }
   myconn.Close();
   ShowAll();

这段代码与之前代码的不同之处在于:

1.使用 Connection 对象的 CreateCommand 方法创建了一个SqlCommand 对象。

   SqlCommand cmd = myconn.CreateCommand();

2.使用了Command 对象的 CommandText 属性写 sql 语句文本,当然也可以是存储过程的名称。

   cmd.CommandText = "insert into custom values(@uid,@uname,@udepart,@uage,@uename,@upassword)";

3.使用了Command 对象的 Parameters 属性 输入参数。

cmd.Parameters.AddWithValue("@uid", uid.Text);
   cmd.Parameters.AddWithValue("@uname", uname.Text);
   cmd.Parameters.AddWithValue("@udepart", udepart.Text);
   cmd.Parameters.AddWithValue("@uage", uage.Text);
   cmd.Parameters.AddWithValue("@uename", uename.Text);
   cmd.Parameters.AddWithValue("@upassword", upassword.Text);

嗯这样一改看起来就很舒服了^_^

修改、删除和增加的套路是差不多的。这里就不贴代码了。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对澳门金沙网上娱乐的支持。

相关文章

  • ASP.NET MVC分页问题解决

    ASP.NET MVC分页问题解决

    这篇文章主要为大家详细介绍了ASP.NET MVC分页问题的解决方法,Ajax.Pager分页的使用注意事项,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • asp.net下Repeater使用 AspNetPager分页控件

    asp.net下Repeater使用 AspNetPager分页控件

    AspNetPager针对ASP.NET分页控件的不足,提出了与众不同的解决asp.net中分页问题的方案
    2010-03-03
  • asp.NET连接数的设置方法

    asp.NET连接数的设置方法

    asp.NET连接数的设置方法,需要的朋友可以参考下
    2012-12-12
  • ASP.NET比较常用的26个性能优化技巧

    ASP.NET比较常用的26个性能优化技巧

    这篇文章主要给大家介绍asp.net中比较常用的26个性能优化技巧,主要设计到asp.net中常用的26个性能优化方面的内容,对于asp.net中常用的26个性能优化技巧感兴趣的朋友可以参考下本篇文章
    2015-10-10
  • ASP.NET Core与NLog集成的完整步骤

    ASP.NET Core与NLog集成的完整步骤

    NLog是一个免费的日志记录框架,专门为.net平台下的框架提供日志功能,下面这篇文章主要给大家介绍了关于ASP.NET Core与NLog集成的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2018-07-07
  • 浅析ASP.NET万能JSON解析器

    浅析ASP.NET万能JSON解析器

    这篇文章主要是对ASP.NET万能JSON解析器进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-12-12
  • ASP.NET中的参数与特殊类型和特性

    ASP.NET中的参数与特殊类型和特性

    这篇文章主要介绍了ASP.NET中的参数与特殊类型和特性,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-06-06
  • mvc重定向方式详解

    mvc重定向方式详解

    这篇文章主要为大家详细介绍了mvc重定向的几种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • ASP.NET使用My97DatePicker日期控件实例

    ASP.NET使用My97DatePicker日期控件实例

    这篇文章主要为大家详细介绍了ASP.NET使用My97DatePicker日期控件实例,如何使用My97DatePicker日期控件,本文为大家介绍,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • 详解Asp.Net MVC——控制器与动作(Controller And Action)

    详解Asp.Net MVC——控制器与动作(Controller And Action)

    这篇文章主要介绍了详解Asp.Net MVC——控制器与动作(Controller And Action) ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-03-03

最新评论