在开发过程中数据访问是必不可少的。每个框架都会有自己数据访问机制。大家在一般的情况下会为自己的框架配备2套数据访问机制,ORM和DataHelper。当然,根据项目的需要有时候也可能只一种。

其实这2个东西差不多被写烂了,我在这里再谈数据访问可鼓足了很大的勇气,如果写的不好请大家见谅。

首先说说需求。

1.       快速的编写sql配置文件,很完善的配置文件验证和智能提示功能。

2.       把sql语句按模块划分,都放在配置文件中。不再会出现程序中到处可见sql语句,和找不到sql语句的情况了。

3.       修改sql语句再也不需要编译程序集了。

4.       数据访问对象抽象化。统一的数据访问对象,更换数据库只修改web.config就可以了。程序完全不需要修改。

5.       数据库访问更简便。数据访问永远只需三步。获取配置文件中的信息生成dbcommand(只需要指定一个key),给dbcommand中的参数赋值(参数对象已经根据配置文件生成好了,你只需要赋值就可以了,其他的不用管。如果没有参数这一步都省了),执行这个dbcommand。

6.       连接字符串统一管理,不管连接字符串是明文还是密文,都不需要修改任何程序。

写的比较抽象啊,往下看慢慢会明白。

首先说说sql配置文件。

写这个配置文件的时候和写webconfig一样,智能提示,非常方便。而且支持多个系统集成,配置文件一共分三层,系统(一个文件)、模块、sql语句。系统集成的时候把多个sql配置文件放一起,完全不冲突。而且管理sql语句更清晰,部署后调试修改sql更方便。

<?xml version="1.0" encoding="utf-8" ?>
<!--配置说明。 <SqlConfig>
  <Module moduleName="模块名">
    <Sql sqlName="sql语句名称" text="sql语句或存储过程名" type="可以不指定,默认为Text">
      <Parameters>
        <add parameterName="参数名" defaultVaule="默认值,如果没有可以不指定。" direction="可以不指定,默认为Input" dbType="可以不指定。默认为String"/>
      </Parameters>
      <DynamicSql>
        <add parameterName="参数名" dbType="可以不指定。默认为String" direction="可以不指定,默认为Input" filterText="必须指定,如果该参数赋值了,要动态添加到sql语句中的查询条件。"/>
      </DynamicSql>
    </Sql>
  </Module>
</SqlConfig>--> <!--示例
<SqlConfig>
  <Module moduleName="module1">
    <Sql sqlName="AllGroupName" text="select * from groups" />
    <Sql sqlName="GetAllUserName" text="select username from users" />
    <Sql sqlName="GetUserNameByGroupID" text="select username from users where groupid=@GroupID">
      <Parameters>
        <add parameterName="@GroupID" dbType="Int32"/>
      </Parameters>
    </Sql>
    <Sql sqlName="GetUserCount" text="GetUserCount" type="StoredProcedure">
      <Parameters>
        <add parameterName="@GroupID" defaultVaule="1" dbType="Int32" direction="Input"/>
        <add parameterName="@returnValue" dbType="Int32" direction="ReturnValue"/>
      </Parameters>
    </Sql>
    <Sql sqlName="test" text="select * from table where parm=@parm">
      <Parameters>
        <add parameterName="@parm"/>
      </Parameters>
      <DynamicSql>
        <add parameterName="@parm1" filterText="and parm1=@parm1"/>
        <add parameterName="@parm2" filterText="or parm2=@parm2"/>
        <add parameterName="@parm3" filterText="and parm3=@parm3"/>
      </DynamicSql>
    </Sql>
  </Module>
  <Module moduleName="Product"></Module>
</SqlConfig>--> <SqlConfig xmlns="http://www.w3school.com.cn" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.w3school.com.cn SqlStringConfigSchema.xsd">
  <Module moduleName="CE.SqlString.SqlStringTest.Author">
    <Sql sqlName="GetCity" text="select distinct city from authors" />
    <Sql sqlName="GetState" text="select distinct state from authors" />
    <Sql sqlName="SearchAuthors" text="select au_id,au_lname,au_fname,phone,address,city,state,zip,[contract] from authors where 1=1">
      <DynamicSql>
        <add parameterName="@au_id" filterText="and au_id=@au_id"/>
        <add parameterName="@au_lname" filterText="and au_lname like '%' + @au_lname + '%'"/>
        <add parameterName="@au_fname" filterText="and au_fname like '%' + @au_fname + '%'"/>
        <add parameterName="@address" filterText="and address like '%' + @address + '%'"/>
        <add parameterName="@city" filterText="and city = @city"/>
        <add parameterName="@state" filterText="and state = @state"/>
        <add parameterName="@contract" dbType="Boolean" filterText="and [contract] = @contract"/>
      </DynamicSql>
    </Sql>
    <Sql sqlName="GetAuthorInfo" text="select au_id,au_lname,au_fname,phone,address,city,state,zip,[contract] from authors where au_id=@au_id">
      <Parameters>
        <add parameterName="@au_id"/>
      </Parameters>
    </Sql>
    <Sql sqlName="UpdateAuthor" text="update authors set au_lname=@au_lname,au_fname=@au_fname,phone=@phone,address=@address,city=@city,state=@state,zip=@zip,[contract]=@contract where au_id=@au_id">
      <Parameters>
        <add parameterName="@au_lname"/>
        <add parameterName="@au_fname"/>
        <add parameterName="@phone"/>
        <add parameterName="@address"/>
        <add parameterName="@city"/>
        <add parameterName="@state"/>
        <add parameterName="@zip"/>
        <add parameterName="@contract" dbType="Boolean"/>
        <add parameterName="@au_id"/>
      </Parameters>
    </Sql>
  </Module>
</SqlConfig>

再说说数据访问。

永远的只需要三步,可以控制开发人员编码规范。都用这个,不会一人写一个,或者要用的时候自己open一个连接了。

//获取command。
command = DataHelper.SqlModule["GetAuthorInfo"].Command; //给参数赋值。
command.Parameters["@au_id"].Value = au_id; //执行它,DataHelper.Database是封装的Enterprise Library中的Database类型。支持直接返回dataset,事务等等。不过我特别喜欢用datareader。
using (reader = DataHelper.Database.ExecuteReader(command))
{     if (reader.Read())
    {
        author = new Author();
        author.Au_id = reader[0].ToString();
        author.Au_lname = reader[1].ToString();
        author.Au_fname = reader[2].ToString();
        author.Phone = reader[3].ToString();
        author.Address = reader[4].ToString();
        author.City = reader[5].ToString();
        author.State = reader[6].ToString();
        author.Zip = reader[7].ToString();
        author.Contract = Convert.ToBoolean(reader[8].ToString());
    }
}

访问对象抽象化。

可以到到下面这个配置。

<connectionStrings>
    <add name="PubsConnectionString" connectionString="Data Source=.;Initial Catalog=pubs;Persist Security Info=True;User ID=sa;Password=sa"
      providerName="System.Data.SqlClient" />
</connectionStrings>

如果你是System.Data.SqlClient,那么dbcommand就是sqlcommand,dbcommand里面参数也是SqlParameter。

你是哪种providerName,我就可以自动跟你生成那种command。暂时支持四种,System.Data.Odbc、System.Data.OleDb、System.Data.OracleClient和System.Data.SqlClient。

用兴趣你自己加,俺不拦你,加好后给我cc一份就好了。

再看看上面connectionstring,你加密不加密都不需要改代码,我们一样读的出来。当然,你自己写个算法出来肯定是读不出来的。你只能用RsaProtectedConfigurationProvider和DataProtectionConfigurationProvider加密。

数据访问与sql语句的管理(一)的更多相关文章

  1. 1.4 数据库和常用SQL语句(正文)——MySQL数据库命令和SQL语句

    前面我们已经讲述了,登录时,我们使用mysql –u root –p命令进行,此时如果设置了密码,则需要输入密码. 输入密码后即进入MySQL的操作界面,此时,命令行窗体左侧显示"mysql ...

  2. 项目总结04:SQL批量导入数据:将具有多表关联的Excel数据,通过sql语句脚本的形式,导入到数据库

    将具有多表关联的Excel数据,通过sql语句脚本的形式,导入到数据库 写在前面:本文用的语言是java:数据库是MySql: 需求:在实际项目中,经常会被客户要求,做批量导入数据:一般的简单的单表数 ...

  3. 使用excel中的数据快速生成sql语句

    在小公司的话,总是会有要开发去导入历史数据(数据从旧系统迁移到新系统上)的时候.这个时候,现场实施或客户会给你一份EXCEL文档,里面包含了一些别的系统上的历史数据,然后就让你导入到现在的系统上面去. ...

  4. mysql中获取一天、一周、一月时间数据的各种sql语句写法

    今天抽时间整理了一篇mysql中与天.周.月有关的时间数据的sql语句的各种写法,部分是收集资料,全部手工整理,自己学习的同时,分享给大家,并首先默认创建一个表.插入2条数据,便于部分数据的测试,其中 ...

  5. 数据库添加数据II及SQL语句错误

    前些时候,写的代码(数据库添加数据I),往数据库添加数据都是很基本的一条一条地添加.但是平常用于测试时,总不可能一条一条地添加测试数据吧,然后我就尝试着一次性添加几百上千条,但是再次操作的时候,就出问 ...

  6. 如何把Excel数据转化成SQL语句-转

    问题背景 在我们实际的程序开发.维护的过程中,很多时候都要和Excel打交道. 因为用户的数据很多时候是Excel存储的. 公司维护项目的时候,经常要帮客户导入Excel数据,这些数据很多,零 碎,而 ...

  7. mysql--------大数据量分页sql语句优化

    分页程序原理很简单,这里就不多说了,本篇文章主要说的是在数据表记录量比较大的情况下,如何将分页SQL做到更优化,让MySQL执行的更快的方法. 一般的情况下,我们的分页SQL语句是这样的: ,; 以上 ...

  8. mysql中删除完全重复数据的准确SQL语句

    删除数据库中重复的记录,只保留一条 DELETE FROM tb_gps_records WHERE id NOT IN (SELECT bid FROM (SELECT min(id) as bid ...

  9. excel数据通过构建sql语句导入到数据库中

    拿到一张excel数据表格,数据格式如下图所示: 2.根据excel数据结果,构建保存excel数据的表结构 CREATE TABLE #tmpExcel(IP VARCHAR(100),IPAddr ...

随机推荐

  1. Sass、Ruby、Nodejs、gulp

    1.Sass文件就是普通的文本文件,不过其文件后缀名有两种,一种为“.sass”:另一种为“.scss”.我们一般用“.scss”就好,至于这两种文件扩展名的区别在于“.sass”是Sass语言文件的 ...

  2. jzoj2701 【GDKOI2012模拟02.01】矩阵

    传送门:https://jzoj.net/senior/#main/show/2701 [题目大意] 给出矩阵A,求矩阵B,使得

  3. bzoj 5010: [Fjoi2017]矩阵填数

    Description 给定一个 h*w 的矩阵,矩阵的行编号从上到下依次为 1..h,列编号从左到右依次1..w.在这个矩阵中你需要在每 个格子中填入 1..m 中的某个数.给这个矩阵填数的时候有一 ...

  4. NYOJ 284 坦克大战 (广搜)

    题目链接 描述 Many of us had played the game "Battle city" in our childhood, and some people (li ...

  5. bzoj 1500 修改区间 splay

    内个我也不知道哪儿不对,TLE了,说说思路吧 其实思路也没什么说的,就是裸的splay,对于最后一个操作 我们记下每个区间的最长前缀,最长后缀,那么最长子序列就是 前缀,后缀,左子树的后缀+右子树的前 ...

  6. 转: JAVA_SWT常用事件, 和方法

    转自: http://blog.csdn.net/lyq19870515/article/details/9450275 获取焦点事件: text.addListener(SWT.FocusIn, n ...

  7. POJ3466(01背包变形)

    Proud Merchants Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/65536 K (Java/Others) ...

  8. VMX指令集

    指令 作用 VMPTRLD 加载一个VMCS结构体指针作为当前操作对象 VMPTRST 保存当前VMCS结构体指针 VMCLEAR 清除当前VMCS结构体 VMREAD 读VMCS结构体指定域 VMW ...

  9. P1029 最大公约数和最小公倍数问题

    题目描述 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P,Q的个数 条件: 1.P,Q是正整数 2.要求P,Q以x0为 ...

  10. 自动清空Tomcat日志的办法

    cd /usr/local/tomcat7/logs #清空日志 echo > catalina.out vi r.sh #!/bin/sh ########################## ...