edit: Оба запроса могут быть объединены с строкой JOIN
$query = "
SELECT
dd.user_id,
dd.foo
FROM
tmp_agent_coverage as ac
LEFT JOIN
tmp_detail_db as dd
ON
ac.agent_id=dd.user_id
WHERE
ac.primary_area LIKE '$search_term%'
";
$result=mysqli_query($dbc, $query) or mysqliError($dbc, "Could not obtain primary area coverage2");
while($r=mysqli_fetch_array($result))
{
echo $r['user_id'], ' ', $r['foo'], "\n";
}
edit2: автономный пример
<?php
$dbc = new mysqli('localhost', 'localonly', 'localonly', 'test');
if ($dbc->connect_error) {
var_dump($mysqli->connect_errno, $mysqli->connect_error);
die;
}
setup($dbc);
$search_term = 'xy';
$query = "
SELECT
dd.user_id,
dd.foo
FROM
tmp_agent_coverage as ac
LEFT JOIN
tmp_detail_db as dd
ON
ac.agent_id=dd.user_id
WHERE
ac.primary_area LIKE '$search_term%'
";
$result=mysqli_query($dbc, $query) or mysqliError($dbc, "Could not obtain primary area coverage2");
while($r=mysqli_fetch_array($result))
{
echo $r['user_id'], ' ', $r['foo'], "\n";
}
define('DEVELOPMENT_DEBUG_MESSAGES', 1);
function mysqliError($dbc, $description) {
if ( !defined('DEVELOPMENT_DEBUG_MESSAGES') || !DEVELOPMENT_DEBUG_MESSAGES ) {
echo '<div class="error">', htmlspecialchars($description), '</div>';
}
else {
echo '
prints
1 fooxy1
3 fooxy2
5 fooxy3
original answer:
mysqli::query
returning false means that an error occured while executing the query. That could be e.g. a syntax error or privileges or ... or ...
The error
and errno
properties of your $dbc object should hold more detailed information about the error. But you shouldn't show the complete error message to just any arbitrary user.
So, for debugging purposes define a function like
define('DEVELOPMENT_DEBUG_MESSAGES', 1);
function mysqliError($dbc, $description) {
if ( !defined('DEVELOPMENT_DEBUG_MESSAGES') || !DEVELOPMENT_DEBUG_MESSAGES ) {
echo '<div class="error">', htmlspecialchars($description), '</div>';
}
else {
echo '
and then use this function in your code like
<?php
define('DEVELOPMENT_DEBUG_MESSAGES', 1);
[...]
$query="SELECT agent_id FROM agent_coverage WHERE primary_area LIKE '$search_term%'";
$result=mysqli_query($dbc, $query) or mysqliError($dbc, "Could not obtain primary area coverage2");
remove the define(...)
line when you're done debugging.