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. codeforces 686A A. Free Ice Cream(水题)

    题目链接: A. Free Ice Cream //#include <bits/stdc++.h> #include <vector> #include <iostre ...

  2. 洛谷P2943 清理——DP

    题目:https://www.luogu.org/problemnew/show/P2943 一眼看去就有个 n^2 的做法:f[i] = min{ f[j] + num( i - j ) * num ...

  3. str函数isdigit、isdecimal、isnumeric的区别

    s为字符串s.isalnum() 所有字符都是数字或者字母s.isalpha() 所有字符都是字母s.isdigit() 所有字符都是数字s.islower() 所有字符都是小写s.isupper() ...

  4. php 和 js之间使用json通信

    有时候我们需要用后台从数据库中得到的数据在js中进行处理,但是当从php中获取到数据的时候,使用的是键值对形式的多维关联数组.而我们知道,js只支持索引数组,不支持关联数组,这个时候从后台传递过来的数 ...

  5. (转)IE内存泄露,iframe内存泄露造成的原因和解决方案

    http://my.oschina.net/jsan/blog/11169 http://blog.csdn.net/tianma630/article/details/8502395 jQuery ...

  6. CodeForces 723A The New Year: Meeting Friends (水题)

    题意:给定 3 个数,求其中一个数到另外两个数之间的最短距离. 析:很明显选中间那个点了. 代码如下: #pragma comment(linker, "/STACK:1024000000, ...

  7. Codeforces Round #382 (Div. 2) (模拟|数学)

    题目链接: A:Ostap and Grasshopper B:Urbanization C:Tennis Championship D:Taxes 分析:这场第一二题模拟,三四题数学题 A. 直接模 ...

  8. 【插件开发】—— 4 SWT编程须知

    根据前两篇博文,应该对插件开发有所了解. 前文回顾: 1 插件学习篇 2 简单的建立插件工程以及模型文件分析 3 利用扩展点,开发透视图 SWT知识介绍 之前学过Java的朋友,多少页会一些关于Swi ...

  9. Ocelot(九)- 教你如何配置Ocelot?

    配置 可以在此处找到示例配置.配置有两个部分.一组ReRoutes和一个GlobalConfiguration.ReRoutes是告诉Ocelot如何处理上游请求的对象.全局配置有点hacky并允许覆 ...

  10. Visual Studio 2015 个版本下载

    Visual Studio 2015是一个基本完整的开发工具集,它包括了整个软件生命周期中所需要的大部分工具,如UML工具.代码管控工具.集成开发环境(IDE)等等.所写的目标代码适用于微软支持的所有 ...