欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

利用Java理解sql的语法(实例讲解)

程序员文章站 2023-12-17 10:45:04
select 相当于 for 循环 select id from idarray linkedlist a = new linkedlist(); for...

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);
}

以上这篇利用java理解sql的语法(实例讲解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

上一篇:

下一篇: