A voir également:
- Utiliser une requete dans une autre
- Operation doit utiliser une requete qui peut etre mise a jour - Forum - Access
- Récupérer pseudo utilisateur pour requète SQL ✓ - Forum - PHP
- PHP utilisation IF requete ✓ - Forum - PHP
- Utiliser une requete dans une autre ✓ - Forum - Programmation
- {Access} Utilisation de requete Update sous vb ✓ - Forum - Access
8 réponses
blackdam
- Messages postés
- 327
- Date d'inscription
- lundi 19 février 2007
- Statut
- Membre
- Dernière intervention
- 13 février 2015
bonjour!
c'est uniquement du code SQL ou autour il y a un autre langage de programmation?
c'est uniquement du code SQL ou autour il y a un autre langage de programmation?
Signaler
blackdam
- Messages postés
- 327
- Date d'inscription
- lundi 19 février 2007
- Statut
- Membre
- Dernière intervention
- 13 février 2015
Tu pourrais peut etre faire une boucle "for" et pour chaque valeur dans ton tableau, exécuter la requete et stocker le résultat dans un autre tableau... je ne sais pas si c'est une façon optimisée de faire :p
blackdam
- Messages postés
- 327
- Date d'inscription
- lundi 19 février 2007
- Statut
- Membre
- Dernière intervention
- 13 février 2015
oui donc une petite boucle for...
après regarde la rapidité de tes requetes voir si c'est une bonne solution tant au niveau efficacité qu'au niveau rapidité!
si ça marche, pense à mettre ce post en "résolu!"
après regarde la rapidité de tes requetes voir si c'est une bonne solution tant au niveau efficacité qu'au niveau rapidité!
si ça marche, pense à mettre ce post en "résolu!"
Mika
$categories = 'select c.categories_id as categories from ' . TABLE_CATEGORIES . ' c where c.parent_id = 183 ';
$categories_array = tep_db_query($categories);
while( $categories = tep_db_fetch_array($categories_array))
{
$query1 = 'select o.orders_id from ' . TABLE_ORDERS . ' o ';
$query1 .= ', ' . TABLE_ORDERS_PRODUCTS . ' op '; $query1 .= ', ' . TABLE_PRODUCTS . ' p ';
$query1 .= ', ' . TABLE_PRODUCTS_TO_CATEGORIES . ' pc ';
$query1 .= 'where pc.categories_id in ' . $categories['categories'] . ' ';
}
Comme ça, j'ai déja essayé mais cela me renvoie Query est vide!!
$categories_array = tep_db_query($categories);
while( $categories = tep_db_fetch_array($categories_array))
{
$query1 = 'select o.orders_id from ' . TABLE_ORDERS . ' o ';
$query1 .= ', ' . TABLE_ORDERS_PRODUCTS . ' op '; $query1 .= ', ' . TABLE_PRODUCTS . ' p ';
$query1 .= ', ' . TABLE_PRODUCTS_TO_CATEGORIES . ' pc ';
$query1 .= 'where pc.categories_id in ' . $categories['categories'] . ' ';
}
Comme ça, j'ai déja essayé mais cela me renvoie Query est vide!!
blackdam
- Messages postés
- 327
- Date d'inscription
- lundi 19 février 2007
- Statut
- Membre
- Dernière intervention
- 13 février 2015
si je comprend bien et que ton $categories_array est un tableau...
Pour les trucs en gras et soulignés jsui pas sur de la synthaxe... jsui plus orienté java mais c'est pour te guider dans le raisonnement...
en gros, tu boucles pour chaque variable qu'il y a dans ton tableau!
Plus t'avance moins vite, moins t'avance plus vite
$categories_array = tep_db_query($categories); for( $i = 0, i < "taille de $categorie_array", i++) { $query1 = 'select o.orders_id from ' . TABLE_ORDERS . ' o '; $query1 .= ', ' . TABLE_ORDERS_PRODUCTS . ' op '; $query1 .= ', ' . TABLE_PRODUCTS . ' p '; $query1 .= ', ' . TABLE_PRODUCTS_TO_CATEGORIES . ' pc '; $query1 .= 'where pc.categories_id = ' . $categories_array[i] . ' '; }
Pour les trucs en gras et soulignés jsui pas sur de la synthaxe... jsui plus orienté java mais c'est pour te guider dans le raisonnement...
en gros, tu boucles pour chaque variable qu'il y a dans ton tableau!
Plus t'avance moins vite, moins t'avance plus vite
Mika
Le soucis, c'est que ma requête va s'exécuter plusieurs fois...
il faudrait que je puisse récupérer les valeurs renvoyées dans la première requête et les comparer avec un IN.
Cela donnerai
where .... IN (500,600,700,800...)
il faudrait que je puisse récupérer les valeurs renvoyées dans la première requête et les comparer avec un IN.
Cela donnerai
where .... IN (500,600,700,800...)
blackdam
- Messages postés
- 327
- Date d'inscription
- lundi 19 février 2007
- Statut
- Membre
- Dernière intervention
- 13 février 2015
Je sais que ta requete va s'executer plusieurs fois...
n'étant pas un as en SQL au niveau optimisation, je ne sais pas quel choix est le mieux!
mais bon, ta 1ere requete met un temps fou à s'executer... si tu as 50 nombres dans ton IN, il va comparer sa valeur à 50 nombres... ou alors executer 50 petites requetes...
au choix!
n'étant pas un as en SQL au niveau optimisation, je ne sais pas quel choix est le mieux!
mais bon, ta 1ere requete met un temps fou à s'executer... si tu as 50 nombres dans ton IN, il va comparer sa valeur à 50 nombres... ou alors executer 50 petites requetes...
au choix!