[英]How to retrieve table and column names from SQl using JSQLPARSE
我第一次使用JSQLPARSER。 我有一些動態生成的SQL文件,我需要從該SQL中讀取表名和列名。 經過大量的搜尋之后,我嘗試使用JSQLPARSER。 我正在嘗試從文件中讀取列名,但由於表達式原因我無法讀取列名,請任何人都可以糾正我在哪里出錯的代碼。 我正在獲取CLASSCASTEXCEPTION代碼:
public static void main(String[] args) throws JSQLParserException
{
// TODO Auto-generated method stub
String statement="SELECT LOCATION_D.REGION_NAME, LOCATION_D.AREA_NAME, COUNT(DISTINCT INCIDENT_FACT.TICKET_ID) FROM LOCATION_D, INCIDENT_FACT WHERE ( LOCATION_D.LOCATION_SK=INCIDENT_FACT.LOCATION_SK ) GROUP BY LOCATION_D.REGION_NAME, LOCATION_D.AREA_NAME";
CCJSqlParserManager parserManager = new CCJSqlParserManager();
Select select=(Select) parserManager.parse(new StringReader(statement));
PlainSelect plain=(PlainSelect)select.getSelectBody();
List selectitems=plain.getSelectItems();
System.out.println(selectitems.size());
for(int i=0;i<selectitems.size();i++)
{
Expression expression=((SelectExpressionItem) selectitems.get(i)).getExpression();
System.out.println("Expression:-"+expression);
Column col=(Column)expression;
System.out.println(col.getTable()+","+col.getColumnName());
}
}
public class TablesNamesFinder
implements SelectVisitor, FromItemVisitor, ExpressionVisitor,
ItemsListVisitor
{
private List tables;
public List getTableList(Select select) {
tables = new ArrayList();
select.getSelectBody().accept(this);
return tables;
}
public void visit(PlainSelect plainSelect) {
plainSelect.getFromItem().accept(this);
if (plainSelect.getJoins() != null) {
for (Iterator joinsIt = plainSelect.getJoins().iterator(); joinsIt.hasNext();) {
Join join = (Join) joinsIt.next();
join.getRightItem().accept(this);
}
}
if (plainSelect.getWhere() != null)
plainSelect.getWhere().accept(this);
}
public void visit(Union union) {
for (Iterator iter = union.getPlainSelects().iterator(); iter.hasNext();) {
PlainSelect plainSelect = (PlainSelect) iter.next();
visit(plainSelect);
}
}
public void visit(Table tableName) {
String tableWholeName = tableName.getWholeTableName();
tables.add(tableWholeName);
}
public void visit(SubSelect subSelect) {
subSelect.getSelectBody().accept(this);
}
//and other visit implement ....
}
您選擇的第三個值不是列而是函數。 因此,JSqlParser提供了無法轉換為Column的表達式。
正如wumpz指出的那樣,列表中的函數無法轉換為列。 我的要求也是如此,此代碼有助於解決它。 希望這可以幫助。 可以驗證表達式是列還是函數,並可以相應地使用它。
for(int i=0;i<selectitems.size();i++)
{
Expression expression=((SelectExpressionItem) selectitems.get(i)).getExpression();
System.out.println("Expression:-"+expression);
if( expression instanceof Column)
{
Column col=(Column)expression;
System.out.println(col.getTable()+","+col.getColumnName());
}
else if (expression instanceof Function)
{
Function function = (Function) expression;
System.out.println(function.getAttribute()+","+function.getName()+""+function.getParameters());
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.