最近一直在学习“深蓝医生”的PDF.NET框架,对Sql-Map使用存储过程有了点小小的体会。基础知识请到http://www.cnblogs.com/bluedoctor/archive/2010/07/03/1769890.html中查看。

本文通过一个简单的例子以说明通过Sql-Map使用存储过程,并返回一个实体类。

功能实现:通过存储过程验证登录用户的合法性。

1.创建数据库表:

//系统用户维护表
CREATE TABLE T_USER
(
[USER_ID] [int] PRIMARY KEY,
[LOGIN_NAME] [nvarchar](50) NULL,
[REAL_NAME] [nvarchar](50) NULL,
[PASSWORD] [nvarchar](50) NULL,
[USER_STATE] [int] NULL,  --0:未激活  1:激活
[REMARK] [nvarchar](200) NULL
)

2.创建用户验证存储过程:

//功能:验证用户的合法性。如果验证通过则返回当前登录用户的全部信息
CREATE PROCEDURE up_user_verify
(
@login_name nvarchar(50),
@password nvarchar(50),
@error nvarchar(500) output  --如果验证未通过,输出错误提示信息。
)
AS
declare @user_id int,
@pwd nvarchar(50),
@user_state int
  --判断是否存在用户,此处对用户的登录名和登录密码进行大小写区分
select @user_id = [user_id], @pwd = [password], @user_state = [user_state]
  from t_user
  where cast([login_name] as varbinary) = cast(@login_name as varbinary)
--登录名验证
if @user_id is null
begin
set @error = '用户登录名:'+@login_name+'不存在'
return null
end
--登录密码验证
if cast(@password as varbinary) != cast(@pwd as varbinary)
begin
set @error = '登录密码不正确,请重新输入'
return null
end
--用户状态验证
if @user_state = 0
begin
set @error = '用户:' +@login_name+'未激活'
return null
end
  --通过验证,返回用户的信息
select * from t_user where [login_name] = @login_name

3.生成表T_USER对应的实体类:

  [Serializable()]
public partial class Tb_User : EntityBase
{
public Tb_User()
{
TableName = "T_USER";
EntityMap=EntityMapType.Table;
PrimaryKeys.Add("USER_ID");
}
protected override void SetFieldNames()
{
PropertyNames = new string[] { "USER_ID","LOGIN_NAME","REAL_NAME","PASSWORD","USER_STATE","REMARK" };
}
/// <summary>
/// 用户ID
/// </summary>
public System.Int32 USER_ID
{
get{return getProperty<System.Int32>("USER_ID");}
set{setProperty("USER_ID",value );}
}
/// <summary>
/// 登录名称
/// </summary>
public System.String LOGIN_NAME
{
get{return getProperty<System.String>("LOGIN_NAME");}
set{setProperty("LOGIN_NAME",value ,);}
}
/// <summary>
/// 真实姓名
/// </summary>
public System.String REAL_NAME
{
get{return getProperty<System.String>("REAL_NAME");}
set{setProperty("REAL_NAME",value ,);}
}
/// <summary>
/// 登录密码
/// </summary>
public System.String PASSWORD
{
get{return getProperty<System.String>("PASSWORD");}
set{setProperty("PASSWORD",value ,);}
}
/// <summary>
/// 用户状态
/// </summary>
public System.String USER_STATE
{
get{return getProperty<System.String>("USER_STATE");}
set{setProperty("USER_STATE",value ,);}
}
/// <summary>
/// 备注信息
/// </summary>
public System.String REMARK
{
get{return getProperty<System.String>("REMARK");}
set{setProperty("REMARK",value ,);}
}
}

4.Sql-Map配置脚本:

<CommandClass Name="UserManage" Class="UserInfoManageDAL" Description="系统用户信息维护" Interface="">
<Select CommandName="VerifyUser" CommandType="StoredProcedure" Method="" Description="验证用户的合法性"
ResultClass="EntityObject" ResultMap="DAL.Entitys.Tb_User">
<![CDATA[[up_user_verify] #login_name:String,String,50,Input# #password:String,String,50,Input# #error:String,String,500,Output#]]>
</Select>
</CommandClass>

5.SQL-MAP的DAL程序:

public partial class UserInfoManageDAL : DBMapper
{
/// <summary>
/// 默认构造函数
/// </summary>
public UserInfoManageDAL()
{
Mapper.CommandClassName = "UserManage";
Mapper.EmbedAssemblySource = "DAL,DAL.SqlMap.config";
}/// <summary>
/// 用户合法性验证
/// </summary>
/// <param name="loginName">登录名</param>
/// <param name="password">登录密码</param>
/// <param name="error">验证失败的错误信息</param>
/// <returns>验证通过,返回用户实体类实例</returns>
public Tb_User VerifyUser(string loginName, string password, ref string error)
{
CommandInfo cmdInfo = Mapper.GetCommandInfo("VerifyUser");
cmdInfo.DataParameters[].Value = loginName;
cmdInfo.DataParameters[].Value = password;
cmdInfo.DataParameters[].Value = error;
Tb_User user = EntityQuery<Tb_User>.QueryObject(CurrentDataBase.ExecuteDataReader(cmdInfo.CommandText, cmdInfo.CommandType, cmdInfo.DataParameters));        
error = user == null ? cmdInfo.DataParameters[].Value.ToString() : string.Empty;
return user;
}
/// <summary>
/// 获取全部用户信息
/// </summary>
/// <returns>用户实体列表</returns>
public List<Tb_User> GetAllUser()
{
return OQL.From<Tb_User>().Select().END.ToList<Tb_User>();
}
/// <summary>
/// 通过用户ID获取用户信息
/// </summary>
/// <param name="userId">用户ID</param>
/// <returns></returns>
public Tb_User GetUserById(int userId)
{
Tb_User user = new Tb_User();
user.USER_ID = userId;
OQL q = OQL.From(user).Select().Where(user.USER_ID).END;
return EntityQuery<Tb_User>.QueryObject(q);
}
}

6.测试程序

private void button1_Click(object sender, EventArgs e)
{
  UserInfoManageDAL dal = new UserInfoManageDAL();
  string name = "admin";
  string pwd = "abc";
  string error = string.Empty;
  Tb_User user = dal.VerifyUser(name, pwd, ref error);
  if (user == null)
    MessageBox.Show(error);
  else
    MessageBox.Show(user.USER_ID.ToString() + ":" user.LOGIN_NAME + ":" + user.REAL_NAME);
}

PDF.NET框架学习篇之SQL-MAP使用存储过程的更多相关文章

  1. Farseer.net轻量级开源框架 中级篇:SQL执行报告

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 数据库切换 下一篇:Farseer.net轻量级开源框架 中级篇: 探究ORM(M ...

  2. 集合框架学习之Collection和Map详解

    线性表,链表,哈希表是常用的数据结构,在进行Java开发时,JDK已经为我们提供了一系列相应的类来实现基本的数据结构.这些类均在java.util包中.本文试图通过简单的描述,向读者阐述各个类的作用以 ...

  3. [python 测试框架学习篇] 分享 uiautomator测试框架

    uiautomator测试框架 :https://testerhome.com/topics/4194

  4. [python测试框架学习篇] 分享一个和adb相关的测试框架

    https://testerhome.com/topics/7106   (user: zteandallwinner     password: same to qq ) 264768502 · # ...

  5. Flask框架学习篇(一)

    安装好Python,pip install flask安装好flask后,开始编写第一个flask程序 #包含动态路由的flask程序from flask import Flask app= Flas ...

  6. Farseer.net轻量级开源框架 中级篇:探究ORM(Mapping)

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: SQL执行报告 下一篇:Farseer.net轻量级开源框架 中级篇: Cooki ...

  7. Farseer.net轻量级开源框架 中级篇:数据库切换

    导航 目   录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 中级篇: 动态数据库访问 下一篇:Farseer.net轻量级开源框架 中级篇: SQL执行 ...

  8. 1.0EnterpriseFrameWork 框架学习

    1.先报其主页 :博主的框架是开源的 http://www.cnblogs.com/kakake/p/3938262.html . 2.学习的精髓是:该框架支持 ORM.SQL语句 和 存储过程 ,O ...

  9. JavaSE中Map框架学习笔记

    前言:最近几天都在生病,退烧之后身体虚弱.头疼.在床上躺了几天,什么事情都干不了.接下来这段时间,要好好加快进度才好. 前面用了三篇文章的篇幅学习了Collection框架的相关内容,而Map框架相对 ...

随机推荐

  1. 第四章 HTML与JavaScript

    DHTML就是与CSS和Web文档进行交互生成动态页面的JavaScript. 4.1HTML文档剖析 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML ...

  2. 使用supervisor提高nodejs调试效率

    如果你有PHP 开发经验,会习惯在修改PHP 脚本后直接刷新浏览器以观察结果,而你 在开发Node.js 实现的HTTP 应用时会发现,无论你修改了代码的哪一部份,都必须终止 Node.js 再重新运 ...

  3. 深入理解CSS定位中的堆叠z-index

    × 目录 [1]定义 [2]堆叠规则 [3]堆叠上下文[4]兼容 前面的话 对于所有定位,最后都不免遇到两个元素试图放在同一位置上的情况.显然,其中一个必须盖住另一个.但,如何控制哪个元素放在上层,这 ...

  4. Android切换动画之ViewPager

    有过开发经验的程序员都知道这个效果,就是当我们第一次安装一个软件时有一个使用说明的图片切换效果,他是如何实现的呢?今天我们就一起学习一下吧,难度系数1.0,就是只要你仔细分析,都可以学会.废话不多说, ...

  5. 数据可视化(1)--Chart.js

    Chart.js是一个HTML5图表库,使用canvas元素来展示各式各样的客户端图表,支持折线图.柱形图.雷达图.饼图.环形图等.在每种图表中,还包含了大量的自定义选项,包括动画展示形式. Char ...

  6. ArcGIS Earth数据小析

    ArcGIS Earth,一款轻量级的三维地球应用.因为工作关系下载试用了半天,正好借这个机会简单研究一下ArcGIS Earth的大概思路,特别是地形数据的组成和影像数据的加载,在这总结整理一下.下 ...

  7. [转载]—— Android JNI知识点

    Java Native Interface (JNI)标准是java平台的一部分,它允许Java代码和其他语言写的代码进行交互.JNI 是本地编程接口,它使得在 Java 虚拟机 (VM) 内部运行的 ...

  8. android中AVD的使用

    AVD路径设置 前面提到,不管用Eclipse还是从命令行创建Android Emulator时,相应的文件是被放置到 “C:\Documents and Settings\Administrator ...

  9. Java之HashMap在多线程情况下导致死循环的问题

    PS:不得不说Java编程思想这本书是真心强大.. 学习内容: 1.HashMap<K,V>在多线程的情况下出现的死循环现象   当初学Java的时候只是知道HashMap<K,V& ...

  10. flexbox简介

    flexbox简介 什么是flexbox flexbox是一种新的布局方式,这种布局方式是2009年W3C提出的方案.它可以简便,完整,完成页面的布局.目前,它已经得到所有浏览器的支持. 但是flex ...