SQL动态配置,动态解析SQL
在项目中使用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的更多相关文章
- Delphi动态配置ODBC数据源--SQL Server版本
(摘自)http://jxlearnew.blog.163.com/blog/static/549786592007102451431413/ 这里介绍一种用Delphi来实现动态注册的方法,希望对各 ...
- 使用不同模板引擎beetl、FreeMarker、Velocity动态解析sql的方法
1. String sql = null;if(null == renderType || renderType.equals(ConstantRender.sql_renderType_beetl) ...
- MyBatis的getMapper()接口、resultMap标签、Alias别名、 尽量提取sql列、动态操作
一.getMapper()接口 解析:getMapper()接口 IDept.class定义一个接口, 挂载一个没有实现的方法,特殊之处,借楼任何方法,必须和小配置中id属性是一致的 通过代理:生成接 ...
- 学习动态性能表 v$sql
学习动态性能表 第三篇-(1)-v$sql V$SQL中存储具体的SQL语句. 一条语句可以映射多个cursor,因为对象所指的cursor可以有不同用户(如例1).如果有多个cursor(子游标)存 ...
- .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. ...
- Quartz动态添加定时任务执行sql(服务启动添加+手动添加)
系统用来每天插入视图数据... 一.数据库表设计 1.接口配置表(t_m_db_interface_config) 2.接口日志表(t_m_db_interface_log) 3.前端配置页面 查询页 ...
- MyBatis框架之SQL映射和动态SQL
使用MyBatis实现条件查询 1.SQL映射文件: MyBatis真正的强大之处就在于SQL映射语句,MyBatis专注于SQL,对于开发人员来说也是极大限度的进行SQL调优,以保证性能.下面是SQ ...
- .NET在EF中使用sql,用动态类吧!
.NET在EF中使用sql,用动态类吧! 前言 在.NET中使用Entity Framework能快速.方便地结合LINQ来对数据库进行一系列的增删改查操作.但是由于EF根据表达式最后生成通用的sql ...
- PL/SQL开发中动态SQL的使用方法
一般的PL/SQL程序设计中,在DML和事务控制的语句中可以直接使用SQL,但是DDL语句及系统控制语句却不能在PL/SQL中直接使用,要想实现在PL/SQL中使用DDL语句及系统控制语句,可以通过使 ...
随机推荐
- 复制构造函数被调用的三种情况------新标准c++程序设计
1.当用一个对象去初始化同类的另一个对象时,会引发复制构造函数被调用.例如,下面的两条语句都会引发复制构造函数的调用,用以初始化c2. C c2 (c1); C c2=c1; 这两条语句是等价的.注意 ...
- 《C#多线程编程实战》2.8 Barrier
不得不说,C#的同步线程的机制是真的多. 各式各样.几乎各种场景下都有可以使用的同步机制. 今天说的,就是比较有意思了. 等待的机制很简单,单纯的等待. 使用的方法我就等. 等待的东西或者内容则是你自 ...
- python-判断语句介绍
1.生活中的判断场景 1.1 火车站安检 1.2 上网吧 2.开发中的判断场景 2.1 密码判断 2.2 重要日期判断 if 今天是周六或者周日: 约妹子 if 今天是情人节: 买玫瑰 if 今天发工 ...
- NSSet集合
前言 NSSet:集合 NSSet 集合跟数组差不多,但 Set 集合不能存放相同的对象,它是一组单值对象的集合,被存放进集合中的数据是无序的,它可以是可变的,也可以是不变的. Xcode 7 对系统 ...
- rsync入门
rsync是Linux/unix下一个用于远程文件(目录)同步的一个精巧的小工具程序,有很多文章讨论了其功能和实现原理,本文主要就不赘述了. 主要介绍下实践时使用的一些方法和细枝末节留作工作笔记以便日 ...
- JVM高级特性与实践(一):Java内存区域 与 内存溢出异常
套用<围城>中的一句话,“墙外面的人想进去,墙里面的人想出来”,用此来形容Java与C++之间这堵内存动态分配和垃圾收集技术所围成的“围墙”就再合适不过了. 对于从事C.C++的开发人员而 ...
- [golang] go的typeswitch guard(类型区别)语法和type assertion(类型断言)语法
最近在实现golang,看到个go的特性语法: typeswitch guard. typeswitch guard语法如下: package main import "fmt" ...
- 导出table为Excel
1.HTML <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset=" ...
- 转载---<html>与<body>
关于根元素html以及body的对比,主要是遇到设置背景色的问题,这里转载张鑫旭的关于html和body对比的文.(直接贴过来,是为了以后自己方便看) 原文地址:http://www.zhangxin ...
- python学习之路---day05
字典一:基本组成 dic={"",[],{},"",2,} 字典由key 和value组成, key(键):键是不可变的(且必须要不可改变),一个字典中的key ...