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. 深度学习 dns tunnel检测 使用统计特征 全连接网络——精度99.8%

    代码如下: import numpy as np import tflearn from tflearn.layers.core import dropout from tflearn.layers. ...

  2. WIN7 64位升级更新到IE10或IE11后,IE不能打开

    权限问题,已经解决 解决办法: 用regedit打开注册表,找到 HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\Main 对左侧树Mai ...

  3. hadoop-3.0.0-alpha4安装部署过程

    关闭防火墙 #systemctl stop firewalld.service #停止firewall #systemctl disable firewalld.service #禁止firewall ...

  4. openfire重新配置数据库oracle、mysql

    1.openfire重新配置设置: 删除target/openfire/conf/openfire.xml中的 <setup>true</setup> 2.删除浏览器之前访问过 ...

  5. Ural2102:Michael and Cryptography(数论&素数)

    The hacker Michael develops breakthrough password manager, which is called KEK (Keeper of Encrypted ...

  6. bzoj1858 [Scoi2010]序列操作——线段树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1858 线段树...调了一个上午...(后面带 // 的都是改出来的) lazy 标记的下放好 ...

  7. 去除inline-block的间隙

    产生间隙的原因就是标签之间的空格,去除的方法: 1 设置父元素的font-size:0;空格字符的宽高都为0, <div class="demo1 demo2"> &l ...

  8. Mac下Ruby升级与Rails的安装

    也是醉了,网上查了半天一脸懵逼.然后自己动手试试 gem install rails瞬间命令行就没反应了,以为命令行挂了,但是一会儿报错说是没有权限. 好吧,那么来这个 sudo gem instal ...

  9. js字符串去除连续或全部重复字符

    js字符串去除连续重复字符 ()和\number 配合使用表示重复正则第number个括号内匹配到的内容,如:(\d)\1表示重复第一个匹配块(\d)即等价于如果(\d)匹配到a,则表达式为aa 相应 ...

  10. bzoj 1061: [Noi2008]志愿者招募【最小费用最大流】

    神奇的建图:连接(s,1,inf,0)(n+1,t,inf,0),对于1~n连接(i,i+1,inf-a[i],0),对于每个志愿者(s,t,c),连接(s,t+1,inf,c). 因为从s开始的流是 ...