频道栏目
首页 > 资讯 > SQL Server > 正文

从输入的SQL参数中获取表名及字段名的操作教程

18-06-05        来源:[db:作者]  
收藏   我要投稿

工具类

package com.isoft.mongo;/*
 * @Author: Create by Achun
 *@Time: 2018/6/3 23:20
 *
 */

import java.util.ArrayList;
import java.util.List;

public class SQLUtils {

    public List getColumns(String querysql){
        List column = new ArrayList();
        String tmp = querysql.substring(querysql.indexOf("select") + 6,
                querysql.indexOf("from")).trim();
        if (tmp.indexOf("*") == -1){
            String cols[] = tmp.split(",");
            for (String c:cols){
                column.add(c);
            }
        }
        return column;
    }

    public String getTBname(String querysql){
        String tmp = querysql.substring(querysql.indexOf("from")+4).trim();
        int sx = tmp.indexOf(" ");
        if(sx == -1){
            return tmp;
        }else {
            return tmp.substring(0,sx);
        }
    }

}

测试:

package com.isoft.mongo;
/*
 * @Author: Create by Achun
 *@Time: 2018/6/3 23:32
 *
 */

import java.util.List;

public class SQLUtilsTest {
    public static void main(String[] args) {
        String querysql = "select id,name,age,exent_month from mg";
        SQLUtils utils = new SQLUtils();
        String tablename = utils.getTBname(querysql);
        List columns = utils.getColumns(querysql);
        System.out.println("tablename:" + tablename);
        System.out.println("columns:" + columns);
        System.out.println("frist column:"+columns.get(0));

    }
}
相关TAG标签
上一篇:python高阶函数实例分析
下一篇:Linux 第三次握手ACK的接收和TCP连接建立完成的实验分享
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站