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实现登录的更多相关文章

  1. ADO.NET复习总结(5)--工具类SqlHelper 实现登录

    工具类SqlHelper 即:完成常用数据库操作的代码封装 一.基础知识1.每次进行操作时,不变的代码: (1)连接字符串:(2)往集合存值:(3)创建连接对象.命令对象:(4)打开连接:(5)执行命 ...

  2. 新闻公布系统 (Asp.net 三层架构 )

    2012年度课程设计---新闻公布系统(小结)                                                                             ...

  3. 2015-11-03 ado.net3

    DataReader和DateSet区别: 1. DataReader是一行一行的读,且只能向前读.DateSet是一次性读取出来放到内存中,所以,DataReader读取速度更快,占用内存更低. 2 ...

  4. sqlHelper做增删改查,SQL注入处理,存储值,cookie,session

    一.存储值 eg:登录一个页面,在进入这个页面之前你怎么知道它登没登录呢?[在登录成功之后我们把状态保存起来] 存储值得方式有两种,一种是cookie,一种是session 1.1区别: 代码: if ...

  5. sqlHelper做增删改查

    1.把数据库里面的数据显示出来 sqlHelper怎么用:[网上可以下载,需要可以找楼主要] 1.拷贝到项目,修改它的命名空间等于当前项目名称 2.数据库的连接信息,用户名,密码,登录方式等 < ...

  6. 一个简单的后台与数据库交互的登录与注册[sql注入处理,以及MD5加密]

    一.工具: vs2013[因为我现在用的也是2013,版本随便你自己开心] sql2008[准备过久升级] 二.用到的语言: HTML+CSS+Jquery+Ajax+sqlserver HTML[相 ...

  7. Web应用程序系统的多用户权限控制设计及实现-登录模块【4】

    通过前三个模块的介绍,把web权限系统开发所需要的基本类,Css文件,EasyUI框架等准备好后,就可以着手开始系统的编码了. 登陆模块是权限处理系统的关键,根据输入用户的的信息,可自动从数据库中加载 ...

  8. MVC登录案例

    1.在Controllers文件夹里面新建一个控制器HomeController;2.在默认的Index方法里面添加一个视图,名字跟Controller中的方法名一样叫Index,添加后的视图文件会在 ...

  9. JQuery的ajax登录案例

    1.简单版AjaxLogin.html代码: <head> <title></title> <script src="jquery-1.8.3.js ...

随机推荐

  1. 转: Nodejs 发送HTTP POST请求实例

    项目里面需要用到使用NodeJs来转发HTTP POST请求,把过程记录一下: exports.sendEmail = function (req, res) { res.send(200, req. ...

  2. HDU 5735 Born Slippy(拆值DP+位运算)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5735 [题目大意] 给出一棵树,树上每个节点都有一个权值w,w不超过216,树的根为1,从一个点往 ...

  3. VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法]

    VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法] - tingya的专栏 - 博客频道 - CSDN.NET VIPS:基于视觉的页面分割算法[微软下一代搜索引擎核心分页算法] 分类 ...

  4. php正则表达式的基本语法

    简单的说,正则表达式是一种可以用于模式匹配和替换的强有力的工具.我们可以在几乎所有的基于UNIX系统的工具中找到正则表达式的身影,例 如,vi编辑器,Perl或PHP脚本语言,以及awk或sed sh ...

  5. zoj 1081 (改进的弧长算法)(转)

    看到网上除了射线法,很长一段代码之外,看到了一个很简单的算法解决这个问题,特意转了过来 /* 这个算法是源自<计算机图形学基础教程>(孙家广,清华大学出版社),在该书 的48-49页,名字 ...

  6. Unity cg vertex and fragment shaders(一)

    cg片段 Cg程序片段写CGPROGRAM和ENDCG之间 开始时的片段可以作为#pragma语句编译指令 Pass { // ... the usual pass state setup ... C ...

  7. UVA1471( LIS变形)

    这是LIS的变形,题意是求一个序列中去掉某个连续的序列后,能得到的最长连续递增序列的长度. 用DP的解法是:吧这个序列用数组a来记录,再分别用两个数组f记录以i结尾的最长连续递增序列的长度,g[i]记 ...

  8. C++面向对象类的书写相关细节梳理

    类的问题 继承类的原因:为了添加或者替换功能. 1. 继承时重写类的方法 v 替换功能 ① 将所有方法都设置为virtual(虚函数),以防万一. Virtual:经验表明最好将所有方法都设置为vir ...

  9. XCode里遇到 #include <XXX.h>file not found的解决方案

    最近在学习如何在C++里调用Java方法,遇到提示 #include <XXX.h> file  not  found 的问题.也google了好久都没有找到合适的解决方案. 认真的研究了 ...

  10. (Problem 53)Combinatoric selections

    There are exactly ten ways of selecting three from five, 12345: 123, 124, 125, 134, 135, 145, 234, 2 ...