在项目中使用SQL动态配置的方式可以让后期的维护和发布后的修改变得更加方便,无论使用那种配置方式都离不开解析成最终真正能执行的SQL。
下面代码就是一种比较简单的处理方法,SQL的参数以##括起来。

1.在代码中先建立一个需要解析的SQL,后面需要变成配置方式

/// <summary>
/// 暂时用于测试
/// </summary>
static string _sql = "SELECT * FROM TB_USER WHERE ID = #ID# AND NAME LIKE '%#NAME#%'";

2.建立一个根据参数KEY去解析的方法,一般情况下都是使用此方法

/// <summary>
/// 根据SQL和参数集合解析成需要执行的SQL
/// </summary>
/// <param name="str"></param>
/// <param name="dic"></param>
/// <returns></returns>
public static string AnalyticalByDic(string str, Dictionary<string, string> dic)
{
str = str.ToUpper();
foreach (var item in dic)
{
str = str.Replace(string.Format("#{0}#", item.Key.ToUpper()), item.Value);
}
return str;
}

3.建立一个根据顺序解析的方法,不推荐使用此方法

/// <summary>
/// 根据SQL和参数集合解析成需要执行的SQL
/// </summary>
/// <param name="str"></param>
/// <param name="list"></param>
/// <returns></returns>
public static string AnalyticalByList(string str, List<string> list)
{
str = str.ToUpper();
List<string> sqlList = new List<string>();
var sqlstr = str;
int i = ;
int j = ;
int sum = ;
while (true)
{
i = str.Substring(sum, str.Length - sum).IndexOf('#') + ;
sum += i;
j = str.Substring(sum, str.Length - sum).IndexOf('#');
if (i < || j < )
{
break;
}
sqlList.Add(str.Substring(sum, j));
sum += j + ;
}
for (int index = ; index < sqlList.Count && index < list.Count; index++)
{
str = str.Replace(string.Format("#{0}#", sqlList[index].ToUpper()), list[index]);
}
return str;
}

4.方法建好了,就试一下DEMO看看效果,直接在Main里面调用就好

static void Main(string[] args)
{
Dictionary<string, string> dic = new Dictionary<string, string>();
dic.Add("ID", "");
dic.Add("Name", "jimmy.pan");
string sql = _sql;
Console.WriteLine(AnalyticalByDic(sql, dic));
List<string> list = new List<string>();
list.Add("");
list.Add("jimmy");
sql = _sql;
Console.WriteLine(AnalyticalByList(sql, list));
Console.Read();
}

5.运行结果如下图

6.整体代码

using System;
using System.Collections.Generic; namespace SQLAnalytical
{
class Program
{
static void Main(string[] args)
{
Dictionary<string, string> dic = new Dictionary<string, string>();
dic.Add("ID", "");
dic.Add("Name", "jimmy.pan");
string sql = _sql;
Console.WriteLine(AnalyticalByDic(sql, dic));
List<string> list = new List<string>();
list.Add("");
list.Add("jimmy");
sql = _sql;
Console.WriteLine(AnalyticalByList(sql, list));
Console.Read();
} /// <summary>
/// 根据SQL和参数集合解析成需要执行的SQL
/// </summary>
/// <param name="str"></param>
/// <param name="dic"></param>
/// <returns></returns>
public static string AnalyticalByDic(string str, Dictionary<string, string> dic)
{
str = str.ToUpper();
foreach (var item in dic)
{
str = str.Replace(string.Format("#{0}#", item.Key.ToUpper()), item.Value);
}
return str;
} /// <summary>
/// 根据SQL和参数集合解析成需要执行的SQL
/// </summary>
/// <param name="str"></param>
/// <param name="list"></param>
/// <returns></returns>
public static string AnalyticalByList(string str, List<string> list)
{
str = str.ToUpper();
List<string> sqlList = new List<string>();
var sqlstr = str;
int i = ;
int j = ;
int sum = ;
while (true)
{
i = str.Substring(sum, str.Length - sum).IndexOf('#') + ;
sum += i;
j = str.Substring(sum, str.Length - sum).IndexOf('#');
if (i < || j < )
{
break;
}
sqlList.Add(str.Substring(sum, j));
sum += j + ;
}
for (int index = ; index < sqlList.Count && index < list.Count; index++)
{
str = str.Replace(string.Format("#{0}#", sqlList[index].ToUpper()), list[index]);
}
return str;
} /// <summary>
/// 暂时用于测试
/// </summary>
static string _sql = "SELECT * FROM TB_USER WHERE ID = #ID# AND NAME LIKE '%#NAME#%'"; }
}

SQL动态配置,动态解析SQL的更多相关文章

  1. Delphi动态配置ODBC数据源--SQL Server版本

    (摘自)http://jxlearnew.blog.163.com/blog/static/549786592007102451431413/ 这里介绍一种用Delphi来实现动态注册的方法,希望对各 ...

  2. 使用不同模板引擎beetl、FreeMarker、Velocity动态解析sql的方法

    1. String sql = null;if(null == renderType || renderType.equals(ConstantRender.sql_renderType_beetl) ...

  3. MyBatis的getMapper()接口、resultMap标签、Alias别名、 尽量提取sql列、动态操作

    一.getMapper()接口 解析:getMapper()接口 IDept.class定义一个接口, 挂载一个没有实现的方法,特殊之处,借楼任何方法,必须和小配置中id属性是一致的 通过代理:生成接 ...

  4. 学习动态性能表 v$sql

    学习动态性能表 第三篇-(1)-v$sql V$SQL中存储具体的SQL语句. 一条语句可以映射多个cursor,因为对象所指的cursor可以有不同用户(如例1).如果有多个cursor(子游标)存 ...

  5. .Net程序员学用Oracle系列(28):PLSQL 之SQL分类和动态SQL

    1.SQL 语句分类 1.1.分类方法及类型 1.2.数据定义语言 1.3.数据操纵语言 1.4.其它语句 2.动态 SQL 理论 2.1.动态 SQL 的用途 2.2.动态 SQL 的语法 2.3. ...

  6. Quartz动态添加定时任务执行sql(服务启动添加+手动添加)

    系统用来每天插入视图数据... 一.数据库表设计 1.接口配置表(t_m_db_interface_config) 2.接口日志表(t_m_db_interface_log) 3.前端配置页面 查询页 ...

  7. MyBatis框架之SQL映射和动态SQL

    使用MyBatis实现条件查询 1.SQL映射文件: MyBatis真正的强大之处就在于SQL映射语句,MyBatis专注于SQL,对于开发人员来说也是极大限度的进行SQL调优,以保证性能.下面是SQ ...

  8. .NET在EF中使用sql,用动态类吧!

    .NET在EF中使用sql,用动态类吧! 前言 在.NET中使用Entity Framework能快速.方便地结合LINQ来对数据库进行一系列的增删改查操作.但是由于EF根据表达式最后生成通用的sql ...

  9. PL/SQL开发中动态SQL的使用方法

    一般的PL/SQL程序设计中,在DML和事务控制的语句中可以直接使用SQL,但是DDL语句及系统控制语句却不能在PL/SQL中直接使用,要想实现在PL/SQL中使用DDL语句及系统控制语句,可以通过使 ...

随机推荐

  1. 三、SpringBoot-application.properties配置文件和application.yml配置文件

    其实SpringBoot的配置文件有.properties和.yml两种形式,两种配置文件的效果类似,只不过是格式不同而已,孩儿们可以根据下面这几种张截图,通过对比端口号的配置,以及连接SQLServ ...

  2. 变量声明和定义的关系------c++ primer

    为了允许把程序分成多个逻辑部分来编写,c++语言支持分离式编译机制 为了支持分离式编译,c++语言把声明和定义区分开来.声明(declaration)使得名字为程序所知,一个文件如果想使用别处定义的名 ...

  3. Linux中,关闭selinux

    首先我们可以用命令来查看selinux的状态getenforce 这个命令可以查看到selinux的状态,当前可以看到是关闭状态的. 还有一个命令也可以查看出selinux的状态.sestatus - ...

  4. C# 向TIM或者QQ自动发送中文消息【微信也是可用的】 附测试GIF

    之前用C++简单的写了一个demo 现在用C#写了完整版 定义字符 定义发送数量 定义发送对象 注意事项 QQ必须单独一个窗体 微信对象在输入名字的时候必须写微信 源代码 using System; ...

  5. ES聚合报错

    在测试Elasticsearch聚合的时候报了一个错误.具体如下: GET /megacorp/employee/_search { "aggs": { "all_int ...

  6. Xamarin如何使用终端设备的NFC功能传递卡号等信息给Web页面(Android)

    一.前提条件,App必须具有NFC权限. 二.项目中加入监控类NFCCatchActivity.cs [Activity(Label = "NFCCatch",Theme = &q ...

  7. 关于“java.lang.OutOfMemoryError : unable to create new native Thread”的报错问题

    好吧 我发誓这是postgresql的Mirroring Controller的RT测试的最后一个坑了. 在这个RT测试的最后,要求测试Mirroring Controller功能在长时间运行下的稳定 ...

  8. IntelliJ IDEA 把Maven项目导出可执行jar包

    2017年04月05日 14:05:08 waterimelon 阅读数:1574 标签: intellij ideamaven 更多 个人分类: idea   第一步  第二步  第三步 

  9. C++11 中的 Defaulted 和 Deleted 函数

    http://blog.jobbole.com/103669/ C++11 中的 Defaulted 和 Deleted 函数 2016/07/21 · C/C++, 开发 · C++ 分享到:3   ...

  10. php 实现无限极分类

    原始数据 $array = array( array('id' => 1, 'pid' => 0, 'n' => '河北省'), array('id' => 2, 'pid' ...