duangu8264 2014-09-16 14:06
浏览 6
已采纳

返回PDO限制字符?

Is it possible in PDO to limit the character return? I'm trying the following but it simply doesn't return a results set no matter which field I put in the LEFT, yet the rest of the query in this case the id and title is returned as expected. Am I missing something?

    $sql = "SELECT LEFT(content,10), id, title FROM posts";
    $query = $this->db->prepare($sql);
    $query->execute();

So I'm loading my model (above) via the controller like so:

    $posts_model = $this->loadModel('PostsModel');
    $posts = $posts_model->getAllPosts();

Then in my view Im echoing out the results like so:

<?php foreach ($posts as $post) { ?>
<tr>
    <td><h3><?php if (isset($post->title)) echo $post->title; ?></h3></td>
    <td><?php if (isset($post->content)) echo $post->content; ?></td>
</tr>

Not sure if this helps any? Like I say I can switch title and content around and it will echo them out it just wont echo the column in the LEFT part of the SQL statement. I've tried the raw mysql query in PHPMYAdmin and it returns the data as I expect just wont work in the live application using PDO.

  • 写回答

1条回答 默认 最新

  • dongshen9058 2014-09-16 14:45
    关注

    If you SELECT LEFT(content,10), then the column name in the result set will be "LEFT(content,10)", so you'd need to access the data as $post->{'LEFT(content,10)'}. To avoid that, give it an alias:

    SELECT LEFT(content,10) AS content ...
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 如何在炒股软件中,爬到我想看的日k线
  • ¥15 51单片机中C语言怎么做到下面类似的功能的函数(相关搜索:c语言)
  • ¥15 seatunnel 怎么配置Elasticsearch
  • ¥15 PSCAD安装问题 ERROR: Visual Studio 2013, 2015, 2017 or 2019 is not found in the system.
  • ¥15 (标签-MATLAB|关键词-多址)
  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序
  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起