使用jsqlsparser实例

结合项目使用,添加依赖或者自己下载相关的jar包

  <!-- https://mvnrepository.com/artifact/com.github.jsqlparser/jsqlparser -->
    <dependency>
        <groupId>com.github.jsqlparser</groupId>
        <artifactId>jsqlparser</artifactId>
        <version>1.4</version>
    </dependency>

下面通过自己做的实例来简单了解一下jsqlsparser的使用

jsqlsparser实例:

/***
	 * 获取select sql表名
	 * @param sql
	 * @return
	 */
	public static List<String> select_table(String sql){
		Statement statement = null;
		try {
			statement = CCJSqlParserUtil.parse(sql);
		} catch (JSQLParserException e) {
			e.printStackTrace();
		}
		Select selectStatement = (Select) statement;
		TablesNamesFinder tablesNamesFinder = new TablesNamesFinder();
		List<String> tableList = tablesNamesFinder
				.getTableList(selectStatement);
		return tableList;
	}


	/**
	 * 获取insert 表名
	 * @param sql
	 * @return
	 * @throws JSQLParserException
	 */
	public static String insert_table(String sql) {
		Statement statement = null;
		try {
			statement = CCJSqlParserUtil.parse(sql);
		} catch (JSQLParserException e) {
			e.printStackTrace();
		}
		Insert insertStatement = (Insert) statement;
		String string_tablename = insertStatement.getTable().getName();
		return string_tablename;
	}

	/**
	 * 获取insert字段名
	 * @param sql
	 * @return
	 */
	public static List<String> insert_column(String sql) {
		Statement statement = null;
		try {
			statement = CCJSqlParserUtil.parse(sql);
		} catch (JSQLParserException e) {
			e.printStackTrace();
		}
		Insert insertStatement = (Insert) statement;
		List<Column> table_column = insertStatement.getColumns();
		List<String> str_column = new ArrayList<String>();
		for (int i = 0; i < table_column.size(); i++) {
			str_column.add(table_column.get(i).toString());
		}
		return str_column;
	}

	/**
	 * 获取insert value值
	 * @param sql
	 * @return
	 */
	public static List<String> insert_values(String sql){
		Statement statement = null;
		try {
			statement = CCJSqlParserUtil.parse(sql);
		} catch (JSQLParserException e) {
			e.printStackTrace();
		}
		Insert insertStatement = (Insert) statement;
		List<Expression> insert_values_expression = ((ExpressionList) insertStatement
				.getItemsList()).getExpressions();
		List<String> str_values = new ArrayList<String>();
		for (int i = 0; i < insert_values_expression.size(); i++) {
			str_values.add(insert_values_expression.get(i).toString());
		}
		return str_values;
	}

因为我自己只用到了添加语句的获取方法,但是jar包里基本上都有,可以下载看一下
这个插件挺好用的,直接传入对应的SQL语句就能实现功能

实际调用

 			//根据SQL语句获取表名 sql[i]为sql语句
            String table = DbUtils.insert_table(sql[i]);
            //根据SQL语句获取字段集
            List <String> column = DbUtils.insert_column(sql[i]);
            //根据SQL语句获取参数集
            List <String> values = DbUtils.insert_values(sql[i]);

另外查询的获取方法也有可以参考一下源底层代码

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值