热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

一次数据访问层的改进之路

随着平民网络时代的到来,微型数据库必然发挥它独到的作用,Access就是一个不错的选择!今个,我也用了下Access数据库,麻雀虽小,名堂多啊!查询,永远是神一样的问题,不停的探索,无止境的接近极限,很明显,如何用最少的代码写出最好的查询?对,问题是:如何

随着平民网络时 代的到来,微型 数据 库必然发挥它独到的作用,Access就是一个不错的选择! 今个,我也用了下Access 数据 库,麻雀虽小,名堂多啊! 查询,永远是神一样的问题,不停的探索,无止境的接近极限,很明显,如何用最少的代码写出最好的查询? 对,问题是: 如何

  随着平民网络时 代的到来,微型数据库必然发挥它独到的作用,Access就是一个不错的选择!

  今个,我也用了下Access数据库,麻雀虽小,名堂多啊!

  查询,永远是神一样的问题,不停的探索,无止境的接近极限,很明显,如何用最少的代码写出最好的查询?

  对,问题是:

  如何用最少的代码写出最好的查询?

  我的"最好"的定义是:代码最美,效率最合适(能快就快,不能快够用就行),开发速度最快.

  这里,以用户登录为例子,先生成相应的实体类(UserLoginInfo.cs):

  UserLoginInfo.cs

  下面我们一起来玩数据查询的升级游戏:

  具体问题:查询出userPass为“123456”这种下三滥的密码的用户

  1.最原始查询

  GetList(string userPass)

  //中间掉了一句话

  foreach(OleDbParameter para in paras){

  cmd.Parameters.Add(para);

  }

  总结:在这个阶段,最恶心的就是

  1.一大堆Connection,Command的操作

  2.读取reader赋值给list的UserLoginInfo的过程,每个字段,索引的对起来,心烦!

  2.对Connection,Command的封装。

  就是SqlHelper那样的,自己随便搞了个。

  ACECommonHelper

  大概的思想,就是这样,调用代码,我想大家也能想象的到,代码参考下一个步骤,可重用性大了。

  3.改进reader填充到list,自动读取。

  根据反射,读取数据库中的字段,自动给UserLoginInfo相应的字段赋值。

  说明:由于是代码生成,数据库的字段基本上和生成类的属性一致。

  从网上下了个类:

  ACEReaderToMode.cs

  改进后的查询方法:

  GetList(string userPass)

  public List GetList(string userPass)

  {

  List list = null;

  List paras = new List();

  OleDbParameter para = new OleDbParameter("@userPass", OleDbType.LongVarWChar);

  para.Value = userPass;

  paras.Add(para);

  using (OleDbConnection cOnnection= new OleDbConnection(connectionString))

  {

  OleDbDataReader reader = AccessHelper.ACECommonHelper.ExcuteReader(

  "select * from User_login where ",

  conn,

  paras.ToArray());

  list = AccessHelper.ACEReaderToModel.ReaderToList(reader);

  reader.Close();

  conn.Close();

  }

  return list;

  }

[1] [2] 下一页

【责编:coco】

推荐阅读
  • 本文介绍了Java语言开发的远程教学系统,包括源代码、MySQL数据库配置以及相关文档,适用于计算机专业的毕业设计。系统支持远程调试,采用B/S架构,适合现代教育需求。 ... [详细]
  • 最新计算机专业原创毕业设计参考选题都有源码+数据库是近期作品ling取参考你的选题刚好在下面有,有时间看到机会给您发1ssm资源循环利用2springboot校园考勤系统3ssm防 ... [详细]
  • 数据结构入门:栈的基本概念与操作
    本文详细介绍了栈这一重要的数据结构,包括其基本概念、顺序存储结构、栈的基本操作(如入栈、出栈、清空栈和销毁栈),以及如何利用栈实现二进制到十进制的转换。通过具体代码示例,帮助读者更好地理解和应用栈的相关知识。 ... [详细]
  • 本文将详细介绍如何在没有显示器的情况下,使用Raspberry Pi Imager为树莓派4B安装操作系统,并进行基本配置,包括设置SSH、WiFi连接以及更新软件源。 ... [详细]
  • 本文详细介绍如何通过设置SSH密钥来获取连接GitHub远程仓库的权限,包括生成密钥、添加到GitHub账户以及验证连接等步骤。 ... [详细]
  • 本文介绍如何配置SecureCRT以正确显示Linux终端的颜色,并解决中文显示问题。通过简单的步骤设置,可以显著提升使用体验。 ... [详细]
  • CentOS 7.2 配置防火墙端口开放
    本文介绍如何在 CentOS 7.2 系统上配置防火墙以开放特定的服务端口,包括 FTP 服务的临时与永久开放方法,以及如何验证配置是否生效。 ... [详细]
  • 本指南详细介绍了如何在同一台计算机上配置多个GitHub账户,并使用不同的SSH密钥进行身份验证,确保每个账户的安全性和独立性。 ... [详细]
  • WinSCP: 跨Windows与Linux系统的高效文件传输解决方案
    本文详细介绍了一款名为WinSCP的开源图形化SFTP客户端,该工具支持SSH协议,适用于Windows操作系统,能够实现与Linux系统之间的文件传输。对于从事嵌入式开发的技术人员来说,掌握WinSCP的使用方法将极大提高工作效率。 ... [详细]
  • 利用SSH隧道实现外网对局域网机器的安全访问
    本文探讨了一种常见的网络配置问题及其解决方案,即如何在外网环境下安全地访问位于局域网内的计算机。特别介绍了使用SSH反向隧道技术来实现这一目标的具体步骤和注意事项。 ... [详细]
  • 在Linux系统上构建Web服务器的详细步骤
    本文详细介绍了如何在Linux系统上搭建Web服务器的过程,包括安装Apache、PHP和MySQL等关键组件,以及遇到的一些常见问题及其解决方案。 ... [详细]
  • 本文详细介绍了如何通过Git Bash在本地仓库与远程仓库之间建立连接并进行同步操作,包括克隆仓库、提交更改和推送更新等步骤。 ... [详细]
  • Windows 环境下安装 Git 并连接 GitHub 的详细步骤
    本文详细介绍了如何在 Windows 系统中安装 Git 工具,并通过配置 SSH 密钥实现与 GitHub 的安全连接。包括下载、安装、环境配置及验证连接等关键步骤。 ... [详细]
  • Redis安全防护深入解析
    本文详细探讨了如何通过指令安全、端口管理和SSL代理等措施有效保护Redis服务的安全性。 ... [详细]
  • Django xAdmin 使用指南(第一部分)
    本文介绍如何在Django项目中集成和使用xAdmin,这是一个增强版的管理界面,提供了比Django默认admin更多的功能。文中详细描述了集成步骤及配置方法。 ... [详细]
author-avatar
流寇仏翔_609
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有