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未修复)的更多相关文章

  1. 如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号(;)。

    1.如果一条SQL语句太长,我们可以通过回车键来创建一个新行来编写SQL语句,SQL语句的命令结束符为分号(;). 2.select查询的多个字段之间要用逗号“,”分割,如果查询涉及多个表,那多个表之 ...

  2. java执行多条SQL语句

    一次执行多条SQL的技术要点如下: DatabaseMetaData接口是描述有关数据库的整体综合信息,由于DatabaseMetaData是接口,所以没有构造方法,故不能使用new来创建Databa ...

  3. 腾讯面试:一条SQL语句执行得很慢的原因有哪些?---不看后悔系列

    说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你"输入URL回车之后,究竟发生了什么"一样,看看你能说出多少了. 之前腾讯 ...

  4. 一条SQL语句执行得很慢的原因有哪些?

    说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你“输入URL回车之后,究竟发生了什么”一样,看看你能说出多少了. 之前腾讯面试的实话,也问到这 ...

  5. 一条SQL语句执行得很慢的原因有哪些?(转)

    一条 SQL 语句执行的很慢,那是每次执行都很慢呢?还是大多数情况下是正常的,偶尔出现很慢呢?所以我觉得,我们还得分以下两种情况来讨论. 1.大多数情况是正常的,只是偶尔会出现很慢的情况. 2.在数据 ...

  6. 一条SQL语句执行得很慢原因有哪些

    一条SQL语句执行得很慢,要分两种情况: 1.大多数情况是正常,偶尔很慢 数据库在处理数据忙时候,更新或新增数据都会暂时记录到redo log日志,等空闲时把数据同步到磁盘.假设数据库一直很忙,更新又 ...

  7. 一条SQL语句执行得很慢的原因有哪些?| MySQL高性能优化规范建议

    一条SQL语句执行得很慢的原因有哪些 https://mp.weixin.qq.com/s?__biz=Mzg2OTA0Njk0OA==&mid=2247485185&idx=1&am ...

  8. 一条SQL语句执行得很慢的原因有哪些

    说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你"输入URL回车之后,究竟发生了什么"一样,看看你能说出多少了. 之前腾讯 ...

  9. JavaWeb 学习007-4个页面,5条sql语句(添加、查看、修改、删除)2016-12-2

    需要复习的知识: 关联查询 =================================================================================班级模块学 ...

随机推荐

  1. 【IOI 1996】 Network of Schools

    [题目链接] 点击打开链接 [算法] 对于第一问,将这个图缩点,输出出度为零的点的个数 对于第二问,同样将这个图缩点,输出入度为零.出度为零的点的个数的最大值 [代码] #include <al ...

  2. ubuntu搭建Gerrit代码审核服务器

    谷歌的 Android 开源项目在 Git 的使用上有两个重要的创新,一个是为多版本库协同而引入的 repo,另外一个重要的创新就是 Gerrit —— 代码审核服务器.Gerrit 为 git 引入 ...

  3. Gym 100962J Jimi Hendrix (树形DP)

    题意:给定一棵树,然后每条边有一个字母,然后给定一行字符串,问你能不能从这棵树上找到,并输出两个端点. 析:树形DP,先进行递归到叶子结点,然后再回溯,在回溯的时候要四个值,一个是正着匹配的长度和端点 ...

  4. bzoj 1600: [Usaco2008 Oct]建造栅栏【dp】

    要求三边和大于第四边,所以任意一条边的长度都是小于n/2 设f[i][j]为前i条长为j,转移的时候用n/2限制 #include<iostream> #include<cstdio ...

  5. springboot(五) 加载配置文件优先级顺序

    github代码地址:https://github.com/showkawa/springBoot_2017/tree/master/spb-demo/spb-brian-query-service ...

  6. 原生javascript之实战 轮播图

    成品效果如下图所示: 因为博客园限制图片上传大小被我删了一些帧数,所以图片看起来会有一点卡,现实运行是不会的 搭建HTML和CSS结构 HTML代码如下: <div class="wr ...

  7. vue按需加载组件,异步组件

    说实话,我一开始也不知道什么叫按需加载组件,组件还可以按需加载???后来知道了 学不完啊...没关系,看我的 按需加载组件,或者异步组件,主要是应用了component的 is 属性 template ...

  8. Minimal Ratio Tree HDU - 2489

    Minimal Ratio Tree HDU - 2489 暴力枚举点,然后跑最小生成树得到这些点时的最小边权之和. 由于枚举的时候本来就是按照字典序的,不需要额外判. 错误原因:要求输出的结尾不能有 ...

  9. 203 Remove Linked List Elements 删除链表中的元素

    删除链表中等于给定值 val 的所有元素.示例给定: 1 --> 2 --> 6 --> 3 --> 4 --> 5 --> 6, val = 6返回: 1 --& ...

  10. 基于CentOS6.5或Ubuntu14.04下Suricata里搭配安装 ELK (elasticsearch, logstash, kibana)(图文详解)

    前期博客 基于CentOS6.5下Suricata(一款高性能的网络IDS.IPS和网络安全监控引擎)的搭建(图文详解)(博主推荐) 基于Ubuntu14.04下Suricata(一款高性能的网络ID ...