java将很长的一条sql语句,自动换行输出(修改版)2019-06-01(bug未修复)
package org.jimmy.autosearch2019.test;
import java.util.HashMap;
public class AutoLinefeedSql {
public static final String BLANK = " ";
public static final String BLANK_REG = " {2,}";
public static final String SEMICOLON = ";";
public static final String COMMA = ",";
public static final String COMMA_REG = ", +| +,";
public static final int WORD_PER_LINE = 4;
public static HashMap<Integer, Integer> replaceMap = new HashMap<Integer, Integer>();
public static final String SINGLE_QUOTE_REG = "'";
public static final String REPLACE_TEXT = "\u9fa5";
public static void main(String[] args) {
String sql = "with result as( select t.str from( select '1' str union all select '2' str union all select '3' str union all select '4' str union all select '5' str union all select '6' str union all select '7' str ) t cross apply (select t2.str from( select '1' str union all select '2' str union all select '3' str union all select '4' str ) t2 where t.str = t2.str) t3) select * from result; go";
sql = replaceSpecialStr(sql, SINGLE_QUOTE_REG, REPLACE_TEXT);
System.out.println(autoLinefeed(sql, SINGLE_QUOTE_REG, REPLACE_TEXT));
}
/**
* @author ラピスラズリ(Dawn)
* @date 2019年6月1日 下午4:29:19
* @detail 替换成一定不会出现在sql中的字符串,换行后再替换回来
*/
public static String replaceSpecialStr(String sql, String reg, String text) {
sql = sql.replaceAll(reg, text);
return sql;
}
/**
* @author ラピスラズリ(Dawn)
* @date 2019年6月1日 下午4:29:55
* @detail 自动换行sql
*/
public static String autoLinefeed(String sql, String reg, String replaceText) {
//空格数超过2就替换成1个空格
sql = sql.replaceAll(BLANK_REG, BLANK);
//,空格或空格,替换成,
sql = sql.replaceAll(COMMA_REG, COMMA);
StringBuffer linefeededTextSb = new StringBuffer();
String[] sqlSubArr = sql.split(BLANK);
for(int i = 0; i < sqlSubArr.length; i++) {
String sqlSub = sqlSubArr[i].trim();
if(sqlSub.indexOf(SEMICOLON) == sqlSub.length() - 1) {
linefeededTextSb.append(sqlSub + System.lineSeparator());
}else {
if(i % WORD_PER_LINE == WORD_PER_LINE - 1) {
linefeededTextSb.append(sqlSub + System.lineSeparator());
}else {
linefeededTextSb.append(sqlSub + BLANK);
}
}
}
sql = linefeededTextSb.toString();
linefeededTextSb = new StringBuffer();
sqlSubArr = sql.split(COMMA);
if(sqlSubArr != null && sqlSubArr.length > 0) {
for(int i = 0; i < sqlSubArr.length; i++) {
String sqlSub = sqlSubArr[i];
if(sqlSub.indexOf(SEMICOLON) == sqlSub.length() - 1) {
linefeededTextSb.append(sqlSub + System.lineSeparator());
}else {
if(i % WORD_PER_LINE == WORD_PER_LINE - 1) {
linefeededTextSb.append(sqlSub + COMMA + System.lineSeparator());
}else {
linefeededTextSb.append(sqlSub + COMMA);
}
}
}
}
if(linefeededTextSb.lastIndexOf(COMMA) == linefeededTextSb.length() - 1) {
linefeededTextSb.deleteCharAt(linefeededTextSb.length() - 1);
}
String text = linefeededTextSb.toString();
text = text.replaceAll(replaceText, reg);
return text;
}
/*public static void replaceSpecialStr() {
Set<Entry<Integer, Integer>> entrySet = replaceMap.entrySet();
Iterator<Entry<Integer, Integer>> iterator = entrySet.iterator();
while(iterator.hasNext()) {
int index = iterator.next().getValue();
}
}
public static void initReplaceMap(String sql, int index, String text) {
System.out.println("index:" + index + ",text:" + text);
int singleQuoteIndex1 = index;
int singleQuoteIndex2 = index + text.length() - 1;
replaceMap.put(singleQuoteIndex1, singleQuoteIndex1);
replaceMap.put(singleQuoteIndex2, singleQuoteIndex2);
String singleQuote1 = sql.substring(singleQuoteIndex1, singleQuoteIndex1 + 1);
System.out.println(singleQuote1);
String singleQuote2 = sql.substring(singleQuoteIndex2, singleQuoteIndex2 + 1);
System.out.println(singleQuote2);
}
*/
}
运行后效果图:

java将很长的一条sql语句,自动换行输出(修改版)2019-06-01(bug未修复)的更多相关文章
- 如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号(;)。
1.如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号(;). 2.select查询的多个字段之间要用逗号“,”分割,如果查询涉及多个表,那多个表之 ...
- java执行多条SQL语句
一次执行多条SQL的技术要点如下: DatabaseMetaData接口是描述有关数据库的整体综合信息,由于DatabaseMetaData是接口,所以没有构造方法,故不能使用new来创建Databa ...
- 腾讯面试:一条SQL语句执行得很慢的原因有哪些?---不看后悔系列
说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你"输入URL回车之后,究竟发生了什么"一样,看看你能说出多少了. 之前腾讯 ...
- 一条SQL语句执行得很慢的原因有哪些?
说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你“输入URL回车之后,究竟发生了什么”一样,看看你能说出多少了. 之前腾讯面试的实话,也问到这 ...
- 一条SQL语句执行得很慢的原因有哪些?(转)
一条 SQL 语句执行的很慢,那是每次执行都很慢呢?还是大多数情况下是正常的,偶尔出现很慢呢?所以我觉得,我们还得分以下两种情况来讨论. 1.大多数情况是正常的,只是偶尔会出现很慢的情况. 2.在数据 ...
- 一条SQL语句执行得很慢原因有哪些
一条SQL语句执行得很慢,要分两种情况: 1.大多数情况是正常,偶尔很慢 数据库在处理数据忙时候,更新或新增数据都会暂时记录到redo log日志,等空闲时把数据同步到磁盘.假设数据库一直很忙,更新又 ...
- 一条SQL语句执行得很慢的原因有哪些?| MySQL高性能优化规范建议
一条SQL语句执行得很慢的原因有哪些 https://mp.weixin.qq.com/s?__biz=Mzg2OTA0Njk0OA==&mid=2247485185&idx=1&am ...
- 一条SQL语句执行得很慢的原因有哪些
说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你"输入URL回车之后,究竟发生了什么"一样,看看你能说出多少了. 之前腾讯 ...
- JavaWeb 学习007-4个页面,5条sql语句(添加、查看、修改、删除)2016-12-2
需要复习的知识: 关联查询 =================================================================================班级模块学 ...
随机推荐
- 一.OC基础之:1,OC语言的前世今生 ,2,OC语言入门,3,OC语言与C的差异,4,面向对象,5,类和对象的抽象关系,6,类的代码创建,7,类的成员组成及访问
1,OC语言的前世今生 , 一, 在20世纪80年代早期,布莱德.麦克(Brad Cox)设计了OC语言,它在C语言的基础上增加了一层,这意味着对C进行了扩展,从而创造出一门新的程序设计语言,支持对象 ...
- SPOJ:Just One Swap(统计&思维)
You are given an array of size N. How many distinct arrays can you generate by swapping two numbers ...
- BZOJ_1307_玩具_单调栈+双指针
BZOJ_1307_玩具_单调栈+双指针 Description 小球球是个可爱的孩子,他喜欢玩具,另外小球球有个大大的柜子,里面放满了玩具,由于柜子太高了,每天小球球都会让妈妈从柜子上拿一些玩具放在 ...
- BZOJ_2947_[Poi2000]促销_堆
BZOJ_2947_[Poi2000]促销_堆 Description Bytelandish连锁超市委托你编写一个程序来模拟一项即将施行的促销活动,该活动的规则如下: ●想要参与的顾客,只需把他的个 ...
- 《JAVA与模式》之责任链模式
责任链模式是一种对象的行为模式.在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链.请求在这个链上传递,直到链上的某一个对象决定处理此请求.发出这个请求的客户端并不知道链上的哪一个 ...
- linux简单技巧和怎么样进入root用户
1.使用shell的Tab键自动补全 Tab在linux命令行输入中可以自动完成.在linux 命令行中使用Tab键会极大提高输入效率2.使用shell的历史记录 shell会记录用户执行命令的历史记 ...
- 利用爬虫将Yuan先生的博客文章爬取下来
由于一次巧遇,我阅读了Yuan先生的一篇博客文章,感觉从Yuan先生得博客学到很多东西,很喜欢他得文章.于是我就关注了他,并且想阅读更多出自他手笔得博客文章,无奈,可能Yuan先生不想公开自己得博客吧 ...
- bootstrap 弹出框 另类运用
下面是我在做一个简单登录页面时,应用boostrap弹出框,通过调节做成警示框的过程,前后经过了一番波折.因为摸索过程十分有趣,最后也是成功的,使用弹出框做除了警示框的效果,下面我们来看一下吧. 首先 ...
- Oracle - RMAN备份 之 incarnation的实验和小结
对于RMAN恢复我一直都不是很明白,因为,老是搞不清楚不完全恢复该怎么进行,今天,通过这个实验即是对不完全恢复的实践,也是希望搞清楚incarnation到底是怎么工作的.很可惜,本人对Oracle的 ...
- MoveTo和LineTo函数的意思
这是个画线函数, moveto是移动到某个坐标,lineto是从当前坐标, 移动的某个坐标连接早当前坐标.这两个函数加起来就是画一条直线.