[php/sql] variable NULL

Fermé
Rémy - 18 avril 2008 à 15:38
okuni Messages postés 1221 Date d'inscription jeudi 4 septembre 2008 Statut Membre Dernière intervention 2 janvier 2014 - 20 oct. 2008 à 23:03
Bonjour,

Bla bla inutile, voici le code :
$req=mysql_query("SELECT * FROM $fiche WHERE blabla=\"1\";");
			while($rep=mysql_fetch_array($req))
			{
				$k=0;
				$contenu.='INSERT INTO '.$fiche.' VALUES (';
				
				while(isset($rep[$k]) OR ???????)
				{
						$contenu.='\''.$rep[$k].'\', ';
						$k++;
				}
				$contenu=substr($contenu, 0, strlen($contenu)-2);
				$contenu.=');'."\r\n";
			}


J'espère que vous comprenez à peu près ce que je veux faire : mettre des requêtes sql dans une variable...
Mon soucis : certaines valeurs de ma bdd sont égales à NULL. Du coup, lors du isset($rep[$k]), la réponse est FALSE et ma boucle s'arrête.
Ma question donc : comment différencier NULL d'une valeur non définie ?
J'espère m'être bien fait comprendre, n'hésitez pas à demander des précisions.

Merci de m'éclairer...
A voir également:

15 réponses

Thamior Messages postés 264 Date d'inscription lundi 11 février 2008 Statut Membre Dernière intervention 18 mars 2014 47
18 avril 2008 à 15:41
Bonjour,

Je te propose de remplacer isset par empty. Le manuel de cette fonction :
https://www.php.net/empty

En espérant que ça t'aide.
0
Non, empty, ne correspond pas à ça.
empty : 0, NULL ou vide
j'ai aussi testé le is_null, rien à faire !... grrrrr
0
elghafoud Messages postés 121 Date d'inscription jeudi 20 février 2003 Statut Membre Dernière intervention 29 avril 2013 18
18 avril 2008 à 15:55
si je comprends bien ...
voici ce que tu peux faire...
dans un premier temps utilise la fonction isset($variable) ! si la variable/la case de ton tableau existe... si c'est le cas, tu peux ajouter if(empty($variable)) pour voir si elle est vide ou pas ......

https://www.php.net/manual/fr/function.isset.php

courage
0
Désolé mais pas possible car :

$var=NULL;
if(isset($var))echo 'ok';else echo 'pas ok';


renvoie 'pas ok'...
0
Thamior Messages postés 264 Date d'inscription lundi 11 février 2008 Statut Membre Dernière intervention 18 mars 2014 47
18 avril 2008 à 16:03
Je viens de penser à cette syntaxe :

$var=NULL;
if($var == NULL)echo 'ok';else echo 'pas ok';

Normalement ça devrait t'afficher ok.
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
Exact mais lorsque $var n'est pas déclarée (c'est mon cas en bout de bdd), il renvoie 'ok' aussi.

Comment différencier NULL de 'non déclaré' ??
0
Thamior Messages postés 264 Date d'inscription lundi 11 février 2008 Statut Membre Dernière intervention 18 mars 2014 47
18 avril 2008 à 16:08
Dans ce cas, je ferai quelque chose qui ressemble à ça :
$var=NULL;
if(($var == NULL) && !empty($var))echo 'ok';else echo 'pas ok';

Je pense que ça devrait marcher.
0
le NULL est inclus dans le empty.
J'ai quand même testé mais... :(
Merci bien en tout cas. Si tu as une autre idée...
0
Thamior Messages postés 264 Date d'inscription lundi 11 février 2008 Statut Membre Dernière intervention 18 mars 2014 47
18 avril 2008 à 16:20
Je viens de tomber sur le site suivant :
http://www.webmaster-hub.com/publication/imprimer27.html

Presque en bas de page, il y a une piste pour ton problème.

En espérant que ça t'aide.
0
Déjà vu.
Mais ca confirme mon intuition... IM-PO-SI-BLE !!
Il va faloir que je change la structure de ma bdd et vire les NULL... Un boulot dingue parce que j'ai une centaine de fichier php à modifier :'-(
0
Thamior Messages postés 264 Date d'inscription lundi 11 février 2008 Statut Membre Dernière intervention 18 mars 2014 47
18 avril 2008 à 16:29
Je vais faire des tests si je trouve quelques choses de concluant, je te passerai le code ^^.

Si tu trouves, je veux bien aussi.
0
OK, pas de problèmes, merci bcp en tout cas !!
0
Je me suis résigné à ce qu'il n'y ait pas de NULL dans ma base de données. A priori, ca fonctionne.
0
salut,
je tombe ici en cherchant les moyens de verifier si une variable n'est pas definie, mais bon....
bref desolé de remonter le topic mais si t'as pas fini de changer tous les NULL de ta bdd, rémy, t'as qu'a essayer ceci :

if (empty($var) OR $var == NUL) { echo pas ok; }

if (!empty $var AND $var != NULL) {echo ok}


je ne vois qu'est ce qui bloquerait ...?
0
Salut !

Perso sur une base oracle ou les valeurs étaient en "(NULL)" ou même sans rien du tout j'ai détourné le problème en testant comme ceci :

if($var!='' && $var!=' ')...

Si ça peut aider quelqun ;)
0
okuni Messages postés 1221 Date d'inscription jeudi 4 septembre 2008 Statut Membre Dernière intervention 2 janvier 2014 126
20 oct. 2008 à 23:03
Comme a dit 4vn3r
c'est plus utile d'utiliser !empty

et sinon, pour modifier très rapidement ta bdd, utilise un for ;)
mais fais bien attention au perte de donnée (je parle d'expérience lool) sauvegarde bien ta base avant de la modifier, on ne sais jamais :p
0