通过SqlHelper实现登录
1.建立解决方案:.
首先创建windows窗体应用程序,然后拖出登录界面
2. 写配置文件App.config:
<configuration>
<connectionStrings>
<add
name="mssqlserver"
connectionString="Data Source=.;Initial Catalog=test;User ID=sa;Password=1q2w3e4R"/>
</connectionStrings>
</configuration>
其中的name可以随意去写,没有任何限制。连接字符串中的【Data Source=.】为服务器名称,【Initial Catalog-test】为表名,后面的为用户名和密码。
3. 写SqlHelper代码:
3.1 读取配置文件:
·首先要添加引用:System.Configuration
·然后读取连接字符串:
private
static
readonly
string
connStr
=
ConfigurationManager.ConnectionStrings["mssqlserver"].ConnectionString;
3.2 封装常用的方法
·执行insert/delete/update的方法
public
static
int
ExecuteNonQuery(string
sql, CommandType
cmdType, params
SqlParameter[] pms)
{
//创建连接对象
using (SqlConnection
con
=
new
SqlConnection(connStr))
{
//创建命令对象
using (SqlCommand
cmd
=
new
SqlCommand(sql, con))
{
//设置当前执行的是存储过程还是带参数的Sql语句
cmd.CommandType
=
cmdType;
//判断是否传递参数
注意:如果传递的不是数组类型,那么不去判空也不会报错,但是如果是数组类型,那么就会报错。所以为了保险起见,应该进行判空。
if (pms
!=
null)
{
cmd.Parameters.AddRange(pms);
}
con.Open();
return
cmd.ExecuteNonQuery();
}
}
}
·执行返回单个值的方法
public
static
object
ExecuteScalar(string
sql, CommandType
cmdType, params
SqlParameter[] pms)
{
using (SqlConnection
con
=
new
SqlConnection(connStr))
{
using (SqlCommand
cmd
=
new
SqlCommand(sql, con))
{
cmd.CommandType
=
cmdType;
if (pms
!=
null)
{
cmd.Parameters.AddRange(pms);
}
con.Open();
return
cmd.ExecuteScalar();
}
}
}
·返回SqlDataReader的方法
public
static
SqlDataReader
ExecuteReader(string
sql, CommandType
cmdType, params
SqlParameter[] pms)
{
SqlConnection
con=new
SqlConnection(connStr);
using (SqlCommand
cmd
=
new
SqlCommand(sql, con))
{
cmd.CommandType
=
cmdType;
if (pms
!=
null)
{
cmd.Parameters.AddRange(pms);
}
try
{
con.Open();
return
cmd.ExecuteReader(CommandBehavior.CloseConnection);
}
catch
{
con.Close();
con.Dispose();
throw;
}
}
}
·执行返回DataTable方法
public
static
DataTable
ExecuteDataTable(string
sql, CommandType
cmdType, params
SqlParameter[] pms)
{
DataTable
dt=new
DataTable();
using (SqlDataAdapter
adapter
=
new
SqlDataAdapter(sql, connStr))
{
adapter.SelectCommand.CommandType
=
cmdType;
if (pms
!=
null)
{
adapter.SelectCommand.Parameters.AddRange(pms);
}
adapter.Fill(dt);
return
dt;
}
}
4. 执行登录操作:
private
void
button1_Click(object
sender, EventArgs
e)
{
string
sql
=
"select COUNT(*) from users where loginId=@uid and loginPwd=@pwd";
SqlParameter[] pms=new
SqlParameter[]
{
new
SqlParameter("@uid",textBox1.Text.Trim()),
new
SqlParameter("@pwd",textBox2.Text)
};
int
n=(int) SqlHelper.ExecuteScalar(sql, CommandType.Text, pms);
if (n
>
0)
{
MessageBox.Show("成功!");
}
else
{
MessageBox.Show("失败!");
}
}
通过SqlHelper实现登录的更多相关文章
- ADO.NET复习总结(5)--工具类SqlHelper 实现登录
工具类SqlHelper 即:完成常用数据库操作的代码封装 一.基础知识1.每次进行操作时,不变的代码: (1)连接字符串:(2)往集合存值:(3)创建连接对象.命令对象:(4)打开连接:(5)执行命 ...
- 新闻公布系统 (Asp.net 三层架构 )
2012年度课程设计---新闻公布系统(小结) ...
- 2015-11-03 ado.net3
DataReader和DateSet区别: 1. DataReader是一行一行的读,且只能向前读.DateSet是一次性读取出来放到内存中,所以,DataReader读取速度更快,占用内存更低. 2 ...
- sqlHelper做增删改查,SQL注入处理,存储值,cookie,session
一.存储值 eg:登录一个页面,在进入这个页面之前你怎么知道它登没登录呢?[在登录成功之后我们把状态保存起来] 存储值得方式有两种,一种是cookie,一种是session 1.1区别: 代码: if ...
- sqlHelper做增删改查
1.把数据库里面的数据显示出来 sqlHelper怎么用:[网上可以下载,需要可以找楼主要] 1.拷贝到项目,修改它的命名空间等于当前项目名称 2.数据库的连接信息,用户名,密码,登录方式等 < ...
- 一个简单的后台与数据库交互的登录与注册[sql注入处理,以及MD5加密]
一.工具: vs2013[因为我现在用的也是2013,版本随便你自己开心] sql2008[准备过久升级] 二.用到的语言: HTML+CSS+Jquery+Ajax+sqlserver HTML[相 ...
- Web应用程序系统的多用户权限控制设计及实现-登录模块【4】
通过前三个模块的介绍,把web权限系统开发所需要的基本类,Css文件,EasyUI框架等准备好后,就可以着手开始系统的编码了. 登陆模块是权限处理系统的关键,根据输入用户的的信息,可自动从数据库中加载 ...
- MVC登录案例
1.在Controllers文件夹里面新建一个控制器HomeController;2.在默认的Index方法里面添加一个视图,名字跟Controller中的方法名一样叫Index,添加后的视图文件会在 ...
- JQuery的ajax登录案例
1.简单版AjaxLogin.html代码: <head> <title></title> <script src="jquery-1.8.3.js ...
随机推荐
- codeforces 547B. Mike and Feet 单调栈
题目链接 用单调栈计算出一个数字, 左边第一个比他小的数字的位置, 右边比第一个他小的数字的位置, 然后len = r[i] - l[i] +1. ans[len] = max(ans[len], a ...
- C语言2
函数是C语言的基本单位,类是java,c#,c++的基本单位 int abs(int x); double fabs(double x); 按变量的存储方式:静态变量.自动变量.寄存器变量 指针就 ...
- 依赖注入(DI)和控制反转(IOC)
依赖注入(DI)和控制反转(IOC) 0X1 什么是依赖注入 依赖注入(Dependency Injection),是这样一个过程:某客户类只依赖于服务类的一个接口,而不依赖于具体服务类,所以客户类只 ...
- QR Code簡介、介紹
QR Code為目前最常被使用的一種二維條碼,1994年由日本Denso-Wav e公司發明,QR是英文Qu ickResponse的縮寫,即快速反應的意思,1999年時,公布了符合日本當地的標準-「 ...
- 领域驱动设计系列(2)浅析VO、DTO、DO、PO的概念、区别和用处
PO:persistant object持久对象 最形象的理解就是一个PO就是数据库中的一条记录.好处是可以把一条记录作为一个对象处理,可以方便的转为其它对象. BO:business object业 ...
- flume 日志采集工具
Flume是Cloudera提供的一个高可用的,高可靠的,分布式的海量日志采集.聚合和传输的系统,Flume支持在日志系统中定制各类数据发送方,用于收集数据:同时,Flume提供对数据进行简单处理,并 ...
- C++面试经常涉及的概念1
1.new.delete.malloc.free关系 delete会调用对象的析构函数,和new对应.free只会释放内存,new调用构造函数.malloc与free是C++/C语言的标准库函数,ne ...
- Cube Stacking(并差集深度+结点个数)
Cube Stacking Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 21567 Accepted: 7554 Ca ...
- Apache Maven-AntRun-Plugin 官网 bug
Maven AntRun Plugin 今天在 Apache maven-antrun-plugin 官网查找资料时,竟然发现了一个bug!! 在此记录下,以免在同一个地方摔倒两次! 想起一句话,尽信 ...
- ArcMAp对线要素进行平滑处(打断)
一:工具简单介绍 -- ArcMAp10.1的高级编辑工具中提供了对线/面要素进行概括/平滑处理的工具. 概括工具.平滑工具分别例如以下:(首先得开启编辑状态 --- 才干够对要素的属性进行更改).选 ...