首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Medoo限制不起作用

Medoo限制不起作用
EN

Stack Overflow用户
提问于 2017-11-20 18:15:41
回答 2查看 2K关注 0票数 2

我遇到了一个意想不到的问题。

代码语言:javascript
复制
<?php
    header("Access-Control-Allow-Origin: *");
    include_once("Medoo.php");
    use Medoo\Medoo;

    $db = new Medoo([
        'database_type' => 'mysql',
        'database_name' => '************',
        'server' => 'localhost',
        'username' => '************',
        'password' => '************'
    ]);

    function getThreads($db, $start, $limit){
        $data = $db->select('threads', ['id', 'title', 'content', 'date', 'userid'],  ["AND" => ["active" => "1", "limit" => [$start, $limit]]]);
        return $data;
    }

    function utf8ize($d) {
        if (is_array($d)) {
            foreach ($d as $k => $v) {
                $d[$k] = utf8ize($v);
            }
        } 
        else if (is_string ($d)) {
            return utf8_encode($d);
        }
        return $d;
    }

    $start=htmlspecialchars(trim($_POST['start']));
    $limit=htmlspecialchars(trim($_POST['limit']));

    $query = getThreads($db, $start, $limit);
    if($query == false) {
        echo json_encode(array("code" => "failed"));
    } 
    else {
        echo json_encode(utf8ize($query));
    }
?>

如果我使用参数启动0和限制5的参数通过ajax调用php文件,结果就是console.log()总是“失败”。已经从medoo尝试了debug()函数,但是sql查询看起来不错。一切都很好..。有什么想法或建议吗?有人能帮忙吗?

代码语言:javascript
复制
var start = 0;
var limit = 5;
$.ajax({
    type: "POST",
    url: 'http://*********/****/********.php',
    crossDomain: true,
    dataType: "text json",
    data: "&start="+start+"&limit="+limit,
    success: function (data) {
        console.log(data);
        if(data.code == "failed"){

        } else {
            start += limit;
            data.reverse();
            $('#threads').html("");
            for (var i = 0; i < data.length; i++) {
                if(data[i]['userid'] == localStorage.id){
                    $('#threads').append("<ons-card onclick='pushpc("+data[i]["id"]+","+data[i]["userid"]+");'><div id='threadid'>"+data[i]["id"]+"</div><div class='title'>"+decode_utf8(data[i]["title"])+"</div><div class='content'>"+decode_utf8(data[i]["content"])+"</div></ons-card>");
                } else {
                $('#threads').append("<ons-card onclick='pushpc("+data[i]["id"]+","+data[i]["userid"]+");'><div id='threadid'>"+data[i]["id"]+"</div><div class='title'>"+decode_utf8(data[i]["title"])+"</div><div class='content'>"+decode_utf8(data[i]["content"])+"</div></ons-card>");
            }
            }
        }
    }
});
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-11-20 20:50:28

我解决了:

代码语言:javascript
复制
  $data = $db->query("SELECT id, title, content, date, userid FROM threads LIMIT ".$start.", ".$limit."")->fetchAll();
票数 -1
EN

Stack Overflow用户

发布于 2018-03-03 19:07:40

它应该是

代码语言:javascript
复制
   function getThreads($db, $start, $limit){
    $data = $db->select('threads', ['id', 'title', 'content', 'date', 'userid'],  ["active" => "1", "LIMIT" => [$start, $limit]]);
    return $data;
   }

限制在medoo中不是一个条件,您可以在没有“和”的情况下使用它。

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

https://stackoverflow.com/questions/47398570

复制
相关文章

相似问题

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