首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >将MYSQL命令行查询转换为内联php查询

将MYSQL命令行查询转换为内联php查询
EN

Stack Overflow用户
提问于 2015-01-16 01:56:49
回答 2查看 208关注 0票数 0

我几乎可以让MySQL在本地存储的maxmind数据库中执行geoip查找。使用命令行mysql >语法检索记录时我一直遵循的操作说明。例如:

代码语言:javascript
运行
复制
mysql> SELECT   glc.*
   FROM     geoip_blocks gbl
            JOIN geoip_locations glc
            ON       glc.glc_id = gbl.gbl_glc_id
   WHERE    gbl_block_start <= INET_ATON('149.156.1.4')
   ORDER BY gbl_block_start DESC
   LIMIT    1\G  

然而,我很难在php脚本中将其转换为mysql查询。

我试过了:

代码语言:javascript
运行
复制
`Select glc.* from geoip_blocks gbl JOIN geoip_locations glc ON glc.glc_id = gbl.gbl_glc_id WHERE    gbl_block_start <= INET_ATON('149.156.1.4') ORDER BY gbl_block_start DESC LIMIT 1\G` 

但这不管用。我相信这是一个很容易解决的问题,但我被难住了。

EN

回答 2

Stack Overflow用户

发布于 2015-01-16 01:58:55

mysql命令行有一个SQL宏,但是在原始\G中没有这样的宏。省略掉这个。也没有必要包含;

票数 1
EN

Stack Overflow用户

发布于 2015-01-16 02:16:08

您的php脚本应该如下所示:

代码语言:javascript
运行
复制
//set connection up
$mysql = new mysqli('mysql_server', 'mysql_user_name', 'mysql_password','mysql_DB');

//query
$sql = "SELECT glc.*
        FROM geoip_blocks gbl
        JOIN geoip_locations glc ON glc.glc_id = gbl.gbl_glc_id
        WHERE gbl_block_start <= INET_ATON('149.156.1.4')
        ORDER BY gbl_block_start DESC
        LIMIT 1";  

//run query & store result
$result = $mysql->query($sql);

//take a look at the results
if($result){
    while($row = $result->fetch_assoc()){

        var_dump($row);

    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/27969919

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档