mysql 表名改成大写_mysql 把表名自动改为大写

最近要做sql标准化,要求所有的表名,字段名大写,我总不能把代码给改一边把,于是找到druid,使用语法分析,拿到sql,把表名改为大写。

package com.topnet.dao.util;

import com.alibaba.druid.sql.SQLUtils;

import com.alibaba.druid.sql.ast.SQLStatement;

import com.alibaba.druid.sql.ast.expr.SQLIdentifierExpr;

import com.alibaba.druid.sql.ast.statement.SQLExprTableSource;

import com.alibaba.druid.sql.ast.statement.SQLSelect;

import com.alibaba.druid.sql.ast.statement.SQLSelectStatement;

import com.alibaba.druid.sql.dialect.mysql.visitor.MySqlASTVisitorAdapter;

import com.alibaba.druid.util.JdbcConstants;

/**

* @author lpf 把sql语句改为大写

*/

public class SqlUpperUtil {

public static void main(String[] args) {

String sql =

" select * from ( select a.id from quick_datasource a, quick_auto b where a.id =b.AUTO_DATASOURCE_ID and a.id='2') as abc ";

System.out.println(upper(sql));

}

/**

* sql语句改为大写,给fastDao调用

*

* @param sql

* @return

*/

public static String upper(String sql) {

String dbType = JdbcConstants.MYSQL;

SQLStatement stmt = SQLUtils.parseSingleStatement(sql, dbType);

TableNameModifier m = new TableNameModifier();

stmt.accept(m);

return stmt.toString();

}

public static StringBuilder upper(StringBuilder sql) {

return new StringBuilder(upper(sql.toString()));

}

private static class TableNameModifier extends MySqlASTVisitorAdapter {

public TableNameModifier() {}

@Override

public boolean visit(SQLSelectStatement astNode) {

astNode.getSelect().accept(this);

return false;

}

@Override

public boolean visit(SQLSelect x) {

x.getQuery().accept(this);

return false;

}

@Override

public boolean visit(SQLExprTableSource x) {

if (x.getAlias() != null) {

x.setAlias(x.getAlias().toUpperCase());

}

x.getExpr().accept(this);

return false;

}

@Override

public boolean visit(SQLIdentifierExpr x) {

x.setName(x.getName().toUpperCase());

return false;

}

}

}

来源:oschina

链接:https://my.oschina.net/internetafei/blog/4314878

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值