动态SQL语句:定义(一)
文章系列
静态SQL与动态SQL
- 静态SQL:程序运行前,具有固定的形式和结构的SQL。
- 动态SQL:程序运行时,能够动态改变形式或结构的SQL。
一些思考和想法
在实际的项目中,很多时候无法简单地用一条静态的SQL语句实现复杂的业务逻辑,往往需要通过程序语言动态地生成SQL语句。然而,在代码中通过条件判断语句拼接产生SQL语句,存在诸多缺点,简单列举如下:
代码杂乱和重复,编码的工作量大,而且容易产生错误。
拼接SQL语句的过程中,容易引起SQL注入。
代码与SQL语句混合在一起,代码结构不清晰,SQL语句的可读性不高。
针对以上存在的问题,希望实现以下几个目标:
提供一套统一的标记语言,编写动态SQL语句。
提供一个代码解析器解析动态SQL语句,生成真实的SQL。
避免拼接SQL过程中存在的问题,如:SQL注入,多余的【and】或【or】或【,】等。
这篇文章先定义好要实现的动态SQL语法以及必要的条件判断函数,在后续的文章中,会逐步给出具体的实现方案,最终的代码也将会发布到Github:https://github.com/Lotusun/Robin.git。希望通过这个实践,提高自己对:编译原理、词法分析器、语法分析器、有限状态机以及ScriptEngine的理解。
动态SQL语法
条件语句(if)
用法:if( condition ){ body },或if( condition ){ body } else { body }
说明:condition支持JavaScript语法。
选择语句(choose)
用法:choose{ when(condition){ body } else { body } }
说明:condition支持JavaScript语法;when子句可以存在多个;
结构语句(where)
用法:where{ body }
说明:用于where语句,能够去除body前后多余的【and】或【or】。
结构语句(set)
用法:set{ body }
说明:用于update语句,能够去除body前后多余的【,】。
结构语句(value)
用法:value{ body }
说明:用于insert语句,能够生成insert语句。
参数语句(#)
用法:#{name}
说明:能够将参数替换为【?】,避免SQL注入。
参数语句($)
用法:${name}
说明:能够将参数替换成字符串,存在SQL注入。
参数语句(@)
用法:@{name}
说明:标记存储过程的返回值。
参数语句(in)
用法:in{name}
说明:用于in语句,能够将List参数替换成多个【?】。
分页语句(page)
用法:page(a, b){ body } order { column }
说明:能够动态生成分页语句;其中,a为每页行数,b为当前页数;
条件判断函数
isNull()
说明:测试对象的值,若为null则为true,否则为false。
isNotNull()
说明:测试对象的值,功能与isNull()相反。
isAllNull()
说明:测试多个对象的值,若存在对象使isNotNull()为true则为false,否则为true。
isAnyNull()
说明:测试多个对象的值,若存在对象使isNull()为true则为true,否则为false。
isEmpty()
说明:测试对象的值,若为:null或空字符串或数组长度为0,则为true,否则为false。
isNotEmpty()
说明:测试对象的值,功能与isEmpty()相反。
isAllEmpty()
说明:测试多个对象的值,若存在对象使isNotEmpty()为true则为false,否则为true。
isAnyEmpty()
说明:测试多个对象的值,若存在对象使isEmpty()为true则为true,否则为false.
isBlank()
说明:测试对象的值,若为:null或空字符串或空白字符(\t, \n, \r等)则为true,否则为false。
isNotBlank()
说明:测试对象的值,功能与isBlanl()相反。
isAllBlank()
说明:测试多个对象的值,若存在对象使isNotBlank()为true则为false,否则为true。
isAnyBlank()
说明:测试多个对象的值,若存在对象使isBlank()为true则为true,否则为false。
示例
select语句
select id, account, name, sex from user where{ if(isNotEmpty(name)){ name = #{name} } }update语句
update user set{ if(isNotEmpty(name)){ name = #{name}, } if(isNotEmpty(sex)){ sex = #{sex}, } }insert语句
insert user values{ id = #{id}, account = #{account}, name = #{name} if(isNotEmpty(sex)){ sex = #{sex} } }delete语句
delete from user where{ if(isNotEmpty(id)){ id = #{id} }else{ } }
动态SQL语句:定义(一)的更多相关文章
- 动态sql语句基本语法--Exec与Exec sp_executesql 的区别
http://www.cnblogs.com/goody9807/archive/2010/10/19/1855697.html 动态sql语句基本语法 1 :普通SQL语句可以用Exec执行 ...
- IBatis.net动态SQL语句
在学习动态SQL语句之前,首先必须对条件查询有一定了解,先来学习如何向IBatis.Net的映射文件里传入参数. 一.条件查询 1.传递单个参数 如根据Id查询: <select id=&quo ...
- 存储过程中执行动态Sql语句
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...
- IBatis.net动态SQL语句(六)
在学习动态SQL语句之前,首先必须对条件查询有一定了解,先来学习如何向IBatis.Net的映射文件里传入参数. 一.条件查询 1.传递单个参数 如根据Id查询: <select id=&quo ...
- Oracle基础 动态SQL语句
一.静态SQL和动态SQL的概念. 1.静态SQL 静态SQL是我们常用的使用SQL语句的方式,就是编写PL/SQL时,SQL语句已经编写好了.因为静态SQL是在编写程序时就确定了,我们只能使用SQL ...
- oracle 存储过程 动态sql语句
一.在oracle项目开发中越到问题: 在利用ODP向oracle中插入数据时,如果这样写: insert into clobTable (id, story) values(1,'....'); ...
- 处理动态SQL语句的参数
原文:处理动态SQL语句的参数 经常对SQL进行开发,写动态的SQL语句,是少之不了的,但是在使用动态语句中,常是因为有动态的参数的出现.参考下面代码示例: 正因为有了标记1的动态条件代码,而让SQL ...
- MyBatis 源码分析——动态SQL语句
有几年开发经验的程序员应该都有暗骂过原生的SQL语句吧.因为他们不能一句就搞定一个业务,往往还要通过代码来拼接相关的SQL语句.相信大家会理解SQL里面的永真(1=1),永假(1=2)的意义吧.所以m ...
- 怎样SQL存储过程中执行动态SQL语句
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...
随机推荐
- C# 对Outlook联系人的增、删、查
原文:C# 对Outlook联系人的增.删.查 [转] 注:定义变量 Outlook.Application myOlApp = new Outlook.ApplicationClass(); Out ...
- webBrowser 参数设置
//禁用脚本错误等类似的窗口信息 this.webBrowser1.ScriptErrorsSuppressed = true; //禁用右键菜单 this.webBrowser1.IsWebBrow ...
- 学习使用简单的php
配置文件在:/etc/php5/$中,不同的模式含有自己的php.ini配置文件.php可以运行于多种模式:cgi.fastcgi.cli.web模块模式等4种: 我现在使用的模式是cli模式,这里进 ...
- Windows 下安装 Oracle 12c 教程
原文 Windows 下安装 Oracle 12c 教程 申明:本文原作者:Jmq 本文给大家带来的是 Oracle 12C 的安装教程. 1.准备 1.1 下载 Oracle 12c 安装程序 ...
- 【转】【Android应用开发详解】第01期:第三方授权认证(一)实现第三方授权登录、分享以及获取用户资料
转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/9057257 由于公司项目的需要,要实现在项目中使用第三方授权登录以及分享文字 ...
- Redis API与常用数据类型简介
Redis API与常用数据类型简介 一.Redis API For .Net 首先,不得不说Redis官方提供了众多的API开发包,但是目前Redis官方版本不支持.Net直接进行连接,需要使用一些 ...
- MySql 集群配置
MYSQL CLUSTER方案介绍 本文的大致框架来自罗志威.黄川的报告, 在它的基础上进行简化和修改一些bug并且添加了主从复制的章节,最后做出该文档 MySQL Cluster 是MySQL适合于 ...
- Linux普通文件和设备的异同点
众所周知,Linux下一切皆文件,文件包含数据,具有属性,通过目录中的名字被标识,可以从一个文件读取数据,写入另一个文件,而Linux把这写应用于设备. 请看如下普通文件和设备的对比:
- java中的log
slf4j slf4j的全称是: Simple Logging Facade for Java (SLF4J). slf4j的官方网站:http://www.slf4j.org 简介 SLF4J不是 ...
- POJ 2337 输出欧拉路径
太无语了. 这道题做了一整天. 主要还是我太弱了. 以后这个就当输出欧拉路径的模版吧. 题目中的输出字典序最小我有点搞不清楚,看了别人是这么写的.但是我发现我过不了后面DISCUSS里面的数据. 题意 ...