C# 连接SQLServer数据库及登录验证知识

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

最近在做联系数据库的系统项目,这里重新回顾了一些数据库的知识,主要是使用VS2012与SQL Server 2012简单的做了下面两个数据库的应用,虽然比较简单,但我认为这是非常有用的知识,尤其对刚接触这样的系统知识的同学,同时也巩固了自己的知识.

一.VS简单连接数据库

使用DataGridView控件(显示和编辑不同数据类型的表格数据)来显示数据库中的数据,主要步骤是:先定义连接数据库和查询语句,再使用SqlConnection建立数据库,SqlDataAdapter连接数据库和查询命令,最后获取数据并显示在DataGridView控件上即可.运行结果如下图所示:

源程序:C#建立一个Windows窗体程序,点击窗体空白处生成Load..填写代码.

//新加命名空间
using System.Data.SqlClient;
using System.Reflection;

private void Form1_Load(object sender, EventArgs e)
{
    //定义数据内存中缓存,后面填充数据使用
    DataSet ds = new DataSet();

    //定义数据库连接语句:服务器=.(本地) 数据库名=TelephoneMS(手机管理系统)
    string consqlserver = "Data Source=.;Initial Catalog=TelephoneMS;Integrated Security=True;";

    //定义SQL查询语句
    string sql = "select * from Users";

    //定义SQL Server连接对象
    SqlConnection con = new SqlConnection(consqlserver);

    //数据库命令和数据库连接
    SqlDataAdapter da = new SqlDataAdapter(sql, con);

    try
    {
        da.Fill(ds);                                    //填充数据
        if (ds.Tables[0].Rows.Count > 0)                //判断是否符合条件的数据记录
        {
            dataGridView1.DataSource = ds.Tables[0];    //获取数据源赋值数据库控件
        }
    }
    catch (Exception msg)
    {
        throw new Exception(msg.ToString());  //异常处理
    }
    finally
    {
        con.Close();                    //关闭连接
        con.Dispose();                  //释放连接
        da.Dispose();                   //释放资源
    }
}

数据库中对应的代码和结果如下:

-------创建数据库:手机销售管理系统(TelePhone management system)--------                     
create database TelephoneMS             --创建数据库                     
use TelephoneMS                         --使用数据库
drop database TelephoneMS               --删除数据库
-------------------------------------------------------------------

-------------------------建表1 Users(角色表)------------------------
--创建表
create table Users
(
	username varchar(20) not null,       --用户名
	userpwd varchar(20) not null,        --用户密码
	userid varchar(20) not null,         --用户编号
	userrole varchar(20) not null        --用户权限
)

--删除表
drop table Users

--清空表中所有数据
truncate table Users

--设置主键:username(用户名)
alter table Users
	add constraint
pk_users primary key(username)

--设置外键:userid(用户编号)
alter table Users
	add constraint
fk_users foreign key(userid)
references UserInfo (userid)
---------------------------------------------------------------------
----------------------------(试验)插入数据查询--------------------------
insert into Users
	(username,userpwd,userid,userrole)
values('admin','123456','000001','adminst');

insert into Users
	(username,userpwd,userid,userrole)
values('Eastmount','eastmount','000002','manager');

select * from Users
----------------------------------------------------------------------

二.数据库简单登录验证

在做系统中通常需要对用户名和密码进行简单的登录验证,下面是简单的登录验证知识.运行结果如下:

主要思想是通过判断输入用户名和密码textbox数据在数据库中查询,结果存在即能实现.代码如下:

//新加命名空间
using System.Data.SqlClient;
using System.Reflection;

//点击"登录"按钮实现数据库验证登录功能
private void button1_Click(object sender, EventArgs e)
{
    //字符串赋值:用户名 密码
    string username = textBox1.Text.Trim();
    string userpwd = textBox2.Text.Trim();

    //定义数据库连接语句:服务器=.(本地) 数据库名=TelephoneMS(手机管理系统)
    string consqlserver = "Data Source=.;Initial Catalog=TelephoneMS;Integrated Security=True;";

    //定义SQL查询语句:用户名 密码
    string sql = "select * from Users where username='" + username + "' and userpwd='" + userpwd + "'";

    //定义SQL Server连接对象 打开数据库
    SqlConnection con = new SqlConnection(consqlserver);
    con.Open();

    //定义查询命令:表示对数据库执行一个SQL语句或存储过程
    SqlCommand com = new SqlCommand(sql, con);

    //执行查询:提供一种读取数据库行的方式
    SqlDataReader sread = com.ExecuteReader();

    try
    {
        //如果存在用户名和密码正确数据执行进入系统操作
        if (sread.Read())
        {
            MessageBox.Show("登录成功");
        }
        else
        {
            MessageBox.Show("请输入正确的用户名和密码");
        }
    }
    catch (Exception msg)
    {
        throw new Exception(msg.ToString());  //处理异常信息
    }
    finally
    {
        con.Close();                    //关闭连接
        con.Dispose();                  //释放连接
        sread.Dispose();                //释放资源
    }
}

实际系统中,弹出的界面“登录成功”可以通过下面的代码替换:

 Main Mwind = new Main();    //显示登录主菜单
 this.Hide();                //隐藏当前登陆窗体
 Mwind.Show();               //显示主登陆窗体

希望这些知识点能帮助巩固和学习C#连接数据库知识,如果叙述中有错误或不足之处见谅!

(By:Eastmount 2013-9-2http://blog.csdn.net/eastmount/)

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
2天前
|
数据库连接 应用服务中间件 PHP
|
1月前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
134 25
|
1月前
|
存储 缓存 Java
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
121 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
|
16天前
|
SQL 数据库
数据库数据恢复—SQL Server报错“错误 823”的数据恢复案例
SQL Server数据库附加数据库过程中比较常见的报错是“错误 823”,附加数据库失败。 如果数据库有备份则只需还原备份即可。但是如果没有备份,备份时间太久,或者其他原因导致备份不可用,那么就需要通过专业手段对数据库进行数据恢复。
|
2天前
|
Linux Shell 数据库
【YashanDB数据库】yasql登录有特殊字符@导致无法登录
【YashanDB数据库】yasql登录有特殊字符@导致无法登录
|
3天前
|
SQL 关系型数据库 数据库连接
|
1月前
|
关系型数据库 MySQL 数据库连接
Unity连接Mysql数据库 增 删 改 查
在 Unity 中连接 MySQL 数据库,需使用 MySQL Connector/NET 作为数据库连接驱动,通过提供服务器地址、端口、用户名和密码等信息建立 TCP/IP 连接。代码示例展示了如何创建连接对象并执行增删改查操作,确保数据交互的实现。测试代码中,通过 `MySqlConnection` 类连接数据库,并使用 `MySqlCommand` 执行 SQL 语句,实现数据的查询、插入、删除和更新功能。
|
4月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
72 3
|
3月前
|
存储 安全 编译器
学懂C#编程:属性(Property)的概念定义及使用详解
通过深入理解和使用C#的属性,可以编写更清晰、简洁和高效的代码,为开发高质量的应用程序奠定基础。
137 12
|
4月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
155 4