当前位置:Gxlcms > PHP教程 > 多表查询遇到的难题

多表查询遇到的难题

时间:2021-07-01 10:21:17 帮助过:37人阅读

要实现 一个需求:通过硬件设备向服务器发出一个请求,
请求带3个参数:
1.用户编码
2.经度
3.纬度


服务器操作:
1.通过经纬度去百度地图获取具体地理地址
2.通过用户编码进行多表查询。获取用户的手机号码。
3.通过取得的地址使用短信网关发送到查询到的手机中
4.短信网关返回发送成功则保存相关数据到mysql



现在问题出在多表查询没有返回手机号码。但是在操作面板则能查询到。是什么问题

流程图:


php代码:


回复讨论(解决方案)

求大神

不明白你遇到了什么问题

不明白你遇到了什么问题


就是多表查询时,没获取到查询结果

没看到有多表查询
你先看看子查询 select user_group.userid from user_group where user_group.sqlid = '".$user."')
是否有结果

这个问题,先去看看查询语句是否有结果。。。

没看到有多表查询
你先看看子查询 select user_group.userid from user_group where user_group.sqlid = '".$user."')
是否有结果


这个有结果。。
我原来的sql语句也是可以执行的,在操作面板里是能查询到结果的,如图,
但 是在php里执行却没有查询到号码。mysql有4个总表,如图:

是不是因为这个问题没有查询到数据?

看来你不会调试程序
$ids= mysql_query($g);
改为 $ids= mysql_query($g) or die( $g .'
' . mysql_error());

看来你不会调试程序
$ids= mysql_query($g);
改为 $ids= mysql_query($g) or die( $g .'
' . mysql_error());


3q,改了出现这个:Access denied for user 'root'@'localhost' (using password: NO)

这个信息表示你没有连接数据库,或连接数据库失败

看来你不会调试程序
$ids= mysql_query($g);
改为 $ids= mysql_query($g) or die( $g .'
' . mysql_error());


我在前面已经调用了帐号和密码了的,这是为什么

前面就失败了

前面就失败了


这个要怎么修改

逐步检查,看看是哪一步错了

前面就失败了


有好几个都能连接上,并有返回数据。代码也和这个差不多,为啥这个连接不上

$mysql=mysqli_connect($db_host,$db_user,$db_password,$db_name);
改为:
$mysql=mysql_connect($db_host,$db_user,$db_password);

$g="select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '".$user."')";    $ids= mysql_query($g);    $n=@mysql_fetch_assoc($ids);    $f=$n['id'];


你的SQL查询里面仅仅获取了mobile 字段,但是你$f=$n['id'],貌似很不合理啊,获取一个没有select的字段,臣妾做不到啊

$g="select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '".$user."')";    $ids= mysql_query($g);    $n=@mysql_fetch_assoc($ids);    $f=$n['id'];


你的SQL查询里面仅仅获取了mobile 字段,但是你$f=$n['id'],貌似很不合理啊,获取一个没有select的字段,臣妾做不到啊



多谢提醒,我现在增加了一项:
  $ids= mysql_query($g,$mysql) or die( $g .'
' . mysql_error());

$g="select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '".$user."')";    $ids= mysql_query($g);    $n=@mysql_fetch_assoc($ids);    $f=$n['id'];


你的SQL查询里面仅仅获取了mobile 字段,但是你$f=$n['id'],貌似很不合理啊,获取一个没有select的字段,臣妾做不到啊


新增后提示出错:
select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '1409203388')Access denied for user 'root'@'localhost' (using password: NO)

晕死,我是让你修改SQL语句,增加对id字段引用


$g="select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '".$user."')";    $ids= mysql_query($g);    $n=@mysql_fetch_assoc($ids);    $f=$n['id'];


你的SQL查询里面仅仅获取了mobile 字段,但是你$f=$n['id'],貌似很不合理啊,获取一个没有select的字段,臣妾做不到啊


新增后提示出错:
select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '1409203388')Access denied for user 'root'@'localhost' (using password: NO)

$g="select akw_user.mobile,akw_user.id from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '".$user."')";    $ids= mysql_query($g);    $n=@mysql_fetch_assoc($ids);    $f=$n['id'];


改这样试试。

晕死,我是让你修改SQL语句,增加对id字段引用



$g="select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '".$user."')";    $ids= mysql_query($g);    $n=@mysql_fetch_assoc($ids);    $f=$n['id'];


你的SQL查询里面仅仅获取了mobile 字段,但是你$f=$n['id'],貌似很不合理啊,获取一个没有select的字段,臣妾做不到啊


新增后提示出错:
select akw_user.mobile from akw_user where akw_user.id in (select user_group.userid from user_group where user_group.sqlid = '1409203388')Access denied for user 'root'@'localhost' (using password: NO)



那个我改为mobile了,现在的情况是
Access denied for user 'root'@'localhost' (using password: NO)

我的#15 就被你忽视了

mysql iiiiiii_connect
mysql_query
说来惭愧一直用框架,加了i的能通用吗

我的#15 就被你忽视了


没有呢,我按你的建议修改了,还是不行哦,同一个做php的朋友,他说是帐号密码对不上。我就纳闷了,比如我前面有好几个返回json的都是使用这个帐号和密码,以正常返回json,为什么多表查询时就会出现这个情况

把你修改后的代码贴出来看看。

把你修改后的代码贴出来看看。

' . mysql_error());    $n=mysql_fetch_assoc($ids);    $f=$n['mobile'];    echo '--mobile--'.array($f).'--g--'.$g;    file_put_contents("localjson.txt",$data.'--dress--'.$dress.'-mobile-'.array($f));?>

mysql iiiiiii_connect
mysql_query
说来惭愧一直用框架,加了i的能通用吗


  $mysql=mysqli_connect($db_host,$db_user,$db_password);

现在这个就是有i的阿


mysql iiiiiii_connect
mysql_query
说来惭愧一直用框架,加了i的能通用吗


  $mysql=mysqli_connect($db_host,$db_user,$db_password);

现在这个就是有i的阿


谢谢,是这个错了,应该是
mysql_query

人气教程排行