Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Używanie zmiennej PHP przed zapytaniem MYSQL

Poza bardzo popularnym zaleceniem, aby nie używać funkcji mysql_*,
musisz się upewnić, że w elementach tablicy nie ma żadnych spacji.

Oto przykładowy kod do usuwania i debugowania zapytania na każdym kroku.

<?php

$elements = array('  element A', "\t Element B \r\n");

var_dump($elements);

/*
use var_dump to check your array elements for whitespace and such
array(2) {
  [0]=>
  string(11) "  element A"
  [1]=>
  string(14) "   Element B
"
}
*/

// create your IN clause string and verify it
$joinedString = "('" . join("','",array_map('trim',$elements)) . "')";

var_dump($joinedString);
/*
use var_dump not echo
string(25) "('element A','Element B')"

*/

// your query string finally becomes
$query = "SELECT * FROM smoelenboek 
WHERE sectie1 IN $joinedString 
OR sectie2 IN $joinedString 
OR sectie3 IN $joinedString 
OR sectie4 IN $joinedString 
OR sectie5 IN $joinedString 
AND actief='ja' ORDER BY achternaam ASC";

// and check it with var_dump and also run it in PhpMyAdmin
var_dump($query);
/*
string(280) "SELECT * FROM smoelenboek
WHERE sectie1 IN ('element A','Element B')
OR sectie2 IN ('element A','Element B')
OR sectie3 IN ('element A','Element B')
OR sectie4 IN ('element A','Element B')
OR sectie5 IN ('element A','Element B')
AND actief='ja' ORDER BY achternaam ASC"
*/


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Wstaw wiele danych do MySQL i zaktualizuj, jeśli istnieją

  2. PHP MYSQL - Różnica między 127.0.0.1 a hostem lokalnym

  3. Jak zmienić datę mysql na Ago w php

  4. Jak naprawić Określony klucz był za długi; maksymalna długość klucza to 1000 bajtów

  5. Jak wybrać wszystko przed/po określonym znaku w MySQL — SUBSTRING_INDEX()