使用C#对SqlServer数据库登录并执行增删改查操作简单实例

ADO.NET:

是微软最强大的数据库访问技术,应用程序可以通过ADO.NET可以非常方便的访问并处理存储在各种数据库的中的数据。ADO.NET集成于.NetFrameWork之中,可用于任何支持.Net的程序设计语言。
ADO.NET结构
命名空间:System.Data.SqlClient;

1. 创建一个数据库:

  1. VS中选择:视图——服务器资源管理器
    右击“数据连接”,选择“创建新的SqlServer数据库”,然后选择服务器名,并在下面创建一个名称为“MySchool”的数据库。
    添加数据库

  2. 新建数据表:
    拆开刚刚新建的数据库MySchool,然后在下拉中右击“表”,选择”添加新表”,然后分别键入UserID,UserName,PassWord作为列名。
    新建数据表
    然后保存数据表名称为“User”。

  3. 添加表数据:右击User数据表,选择“显示表数据”。然后添加3个用户。添加表数据

2. 使用SqlConnection对象连接数据库,并执行【增、删、改、查】

连接方式有两种:Windows & SqlServer
Windows连接字符串: “server=服务器名称;database=数据库名称;Trusted_Connection=SSPI”;
SqlServer连接字符串: “server=服务器名称;uid=登录名称;pwd=登录密码;database=数据库名称”;

  1. 在此之前我们需要将连接字符串添加到配置xml文件中,防止软件首次打开时连接不上数据库。
    连接字符串
  2. 【修改数据】 打开数据库并执行修改表内容的操作:
 public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString(); //从配置文件中读取连接字符串
 string upDateStr ="UPDATE User SET PassWord='abc' WHERE UserName=Admin"; //修改User表中Admin用户的密码为“abc”
 try
 {
 	 //SqlConnection对象在每一次执行命令后销毁
     using (SqlConnection con = new SqlConnection(connStr))
     {
         con.Open();
         SqlCommand cmd = new SqlCommand(upDateStr, con);
         int result = cmd.ExecuteNonQuery(); //这里返回受影响的行数,用于验证执行是否成功
     }
 }
 catch(Exception ex)
 {
     throw ex;
 }
  1. 【新增数据】打开数据库并执行添加表内容的操作:
 public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
 string addDateStr =string.Format("INSERT INTO User(UserID,UserName,PassWord) VALUES('{0}','{1}','{2}')",4,"Teacher","321"); //添加一个用户名为Teacher的新用户,密码321。
 try
 {
     using (SqlConnection con = new SqlConnection(connStr))
     {
         con.Open();
         SqlCommand cmd = new SqlCommand(addDateStr , con);
         int result = cmd.ExecuteNonQuery(); //这里返回受影响的行数,用于验证执行是否成功。
         if(result>0) MessageBox.Show("添加成功!");
         else MessageBox.Show("添加失败!");
     }
 }
 catch(Exception ex)
 {
     throw ex;
 }
  1. 【查询数据】打开数据库并查询表内容的操作:
 public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
 string queryDateStr =string.Format("SELECT *FROM User WHERE UserID='{0}'", 1); //查询User表中用户ID为1的数据源
 try
 {
 	 //SqlConnection对象在每一次执行命令后销毁
     using (SqlConnection con = new SqlConnection(connStr))
     {
         con.Open();
         SqlCommand cmd = new SqlCommand(queryDateStr , con);
         SqlDataReader reader= cmd.ExecuteReader(); //这里返回一个reader对象
         if(reader.Read())
         {
         	string userName=reader.GetString(1); 
         	//这里GetString(index)中: 0=UserID,1=UserName,2=PassWord
         }
         reader.Close();
     }
 }
 catch(Exception ex)
 {
     throw ex;
 }
  1. 【删除数据】打开数据库并删除表内容的操作:
 public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
 string delDateStr =string.Format("DELETE FROM User WHERE UserName='{0}'", "Teacher"); //删除用户名为Teacher的数据
 try
 {
 	 //SqlConnection对象在每一次执行命令后销毁
     using (SqlConnection con = new SqlConnection(connStr))
     {
         con.Open();
         SqlCommand cmd = new SqlCommand(delDateStr, con);
         int result = cmd.ExecuteNonQuery();
         if(result>0) MessageBox.Show("删除成功!");
         else MessageBox.Show("删除失败!");
     }
 }
 catch(Exception ex)
 {
     throw ex;
 }

3. 使用DataSet和DataAdapter显示数据集

  SqlDataAdapter adapter = new SqlDataAdapter();
  DataSet dataSet = new DataSet();
  string sql = "SELECT UserID as 用户编号,UserName as 用户名,PassWord as 密码 FROM User";
  SqlConnection con = new SqlConnection(conStr);
  con.Open();
  SqlCommand com = new SqlCommand(sql, con);
  adapter.SelectCommand = com;
  SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
  adapter.Fill(dataSet, "User");
  object table = dataSet.Tables["User"];
  foreach (DataRow row in dataSet.Tables["User"].Rows)
  {       
       row[0]; //表示当前遍历的行的第0列。
  }
  con.Close();

【如有错误,欢迎指正】

  • 9
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值