代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Java
】
将sql语句保存在properties文件里并解析
作者:
development
/ 发布于
2015/7/9
/
558
/** * 处理Sql Map * * @author songfeixian@qq.com 说明:加载sql map中的sql到map中,并提供动态长度sql处理 */ public class SqlKit { protected static final Logger log = Logger.getLogger(SqlKit.class); /** * xml中所有的sql语句 */ public static final Map<String, String> sqlMap = new HashMap<String, String>(); /** * 过滤掉的sql关键字 */ /** * 清楚加载的sql */ public static void destory() { sqlMap.clear(); } /** * 初始化加载sql语句到Properties */ public static synchronized void init(boolean isInit) { try { File file = new File(PathKit.getRootClassPath()); List<File> sqlFiles = new ArrayList<File>(); findFiles(file, sqlFiles); Properties properties = new Properties(); for (File sqlFile : sqlFiles) { System.out.println("加载Properties文件" + sqlFile.getAbsolutePath().toString()); InputStream input = new FileInputStream(sqlFile); properties.load(input); Enumeration enums = properties.propertyNames(); while (enums.hasMoreElements()) { String key = (String) enums.nextElement(); String value = properties.getProperty(key); if (!sqlValidate(value)) { log.error("sql解析异常id为" + key + ";sql语句为:" + value); } } sqlMap.putAll(new HashMap<String, String>((Map) properties)); properties.clear(); } sqlMap.putAll(new HashMap<String, String>((Map) properties)); for (Map.Entry<String, String> sql : sqlMap.entrySet()) { // log.warn("sqlKEY:" + sql.getKey() + "sql体:" + // sql.getValue()); if (!sqlValidate(sql.getValue())) { log.error("最后sql解析异常id为" + sql.getKey() + ";sql语句为:" + sql.getValue()); } } } catch (Exception e) { log.error("sql解析异常"); e.printStackTrace(); } } /** * 递归查找文件 * * @param baseFile * @param sqlXmlFiles */ private static void findFiles(File baseFile, List<File> sqlXmlFiles) { if (!baseFile.isDirectory()) { if (baseFile.getName().endsWith(".sql.properties")) { sqlXmlFiles.add(baseFile); } } else { File[] fileList = baseFile.listFiles(); for (File file : fileList) { if (file.isDirectory()) { findFiles(file, sqlXmlFiles); } else { if (file.getName().endsWith(".sql.properties")) { sqlXmlFiles.add(file); } } } } } /** * sql校验方法 */ public static boolean sqlValidate(String sql) { if (null == sql || sql.isEmpty()) { return false; } String sqlTemp = sql.toLowerCase().trim(); if (sqlTemp.startsWith("select") || sqlTemp.startsWith("update") || sqlTemp.startsWith("insert") || sqlTemp.startsWith("delete")) { return true; } else if (sqlTemp.startsWith("create table")) { return true; } else if (sqlTemp.startsWith("alter table")) { return true; } else if (sqlTemp.startsWith("comment on")) { return true; } return false; } }
试试其它关键字
properties
properties文件
解析
同语言下
.
List 切割成几份 工具类
.
一行一行读取txt的内容
.
Java PDF转换成图片并输出给前台展示
.
java 多线程框架
.
double类型如果小数点后为零则显示整数否则保留两位小
.
将图片转换为Base64字符串公共类抽取
.
sqlParser 处理SQL(增删改查) 替换schema 用于多租户
.
JAVA 月份中的第几周处理 1-7属于第一周 依次类推 29-
.
java计算两个经纬度之间的距离
.
输入时间参数计算年龄
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
development
贡献的其它代码
(
2
)
.
将sql语句保存在properties文件里并解析
.
文件上传以及删除文件方法
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3