当前位置:Gxlcms > 数据库问题 > 用Java理解sql的语法

用Java理解sql的语法

时间:2021-07-01 10:21:17 帮助过:19人阅读

select 相当于 for 循环
select id from IDArray

LinkedList a = new LinkedList();
for ( int i=0 ; i<tableA.length ; i++){
    a.add(IDArray.get("id" ) );
}

return a;

当执行子查询时,可以理解为
select id, ( select name from nameArray) as names ,from Idarray

LinkedList a = new LinkedList();
for ( int i=0 ; i<tableA.length ; i++){
    a.add(IDArray.get("id" ) );
    for(int j=0 ; j<nameArray.length ; j++){
       a.add(namesArray.get("name"));  
   }
}

很明显这里一对多了。所以执行不对。报SQL错误

所以在 select中,应该要具体确定某一个值
select id, ( select name from nameArray where nameId=id) as names from Idarray

LinkedList a = new LinkedList();
for ( int i=0 ; i<tableA.length ; i++){
   Object object =  IDArray.get("id" ) ;
  for ( int j=0 ; j<nameArray.length ; i++){
     if ( nameArray.get("nameId")==object){
       Object object2 = nameArray.get("nameId");
       a.add(object2);  
    }
}
       a.add(object);  
}

当且仅当if 条件的值搜索是单个值的时候,是对应上的

那么groupBy呢?

select id, ( select name from nameArray where nameId=id) as names from Idarray group by id

LinkedList a = new LinkedList();
for ( int i=0 ; i<tableA.length ; i++){
   Object object =  IDArray.get("id" ) ;
  for ( int j=0 ; j<nameArray.length ; i++){
     if ( nameArray.get("nameId")==object){
       Object object2 = nameArray.get("nameId");
       a.add(object2);  
    }
}
       a.add(object);  
}

LinkedList groupByArray = new LinkedList();

for ( int i=0 ; i< a. length  ; i++){
      int id = a[i].getId();
     LinkedList tempArray = new LinkedList();
     for ( int j=0 ; j<j.length ; j++){
       int temp = a[j].getId();
      if ( id==temp){
         tempArray.add(temp);
        }
    }
   groupByArray.add(tempArray);
}

欢迎加入学习交流群569772982,大家一起学习交流。

用Java理解sql的语法

标签:错误   array   list   循环   rom   data-   add   define   搜索   

人气教程排行