Backbone JS + Codeigniter Restful API和MYSQL子串函数无法正常工作

时间:2014-03-19 12:23:47

标签: php mysql codeigniter rest backbone.js

我有这个BackboneJS应用程序,我使用Codeigniter作为后端。我使用RESTful API将数据从MySQL数据库返回到前端。作为我的应用程序的一部分,我想显示音乐艺术家专辑和相关曲目以及曲目持续时间。现在,我得到的跟踪持续时间就像00:03:26,但我希望它显示03:26,所以我使用SUBSTRING方法进行了MySQL查询:

public function artist_tracks_get($artist_id)  
{ 
    $this->load->database();
    $sql = "SELECT products.title AS album_title, products.genre AS album_genre, products.ccws_pro_id AS product_upc, track_title, SUBSTRING(track_duration, 4) AS track_duration FROM products
                INNER JOIN track_albumn_information ON products.ccws_pro_upc = track_albumn_information.product_upc 
                AND track_albumn_information.artist_id =  '".$artist_id."'  LIMIT 0 , 30";
    $query = $this->db->query($sql);
    $data = $query->result();

    if($data) {
        $this->response($data, 200); 
    } else {
        $this->response(array('error' => 'Couldn\'t find any artist albums!'), 404);
    }
}

在我的Backbone View中,我有:

serialize: function() {
var grouped = _.groupBy(this.collection.toJSON(), function(item) {
    return item.album_title;
}), spanned = [];
_.each(grouped, function(item) {
    var firstItem = item[0],
        spannedItem = {
            'album_genre': firstItem.album_genre,
            'album_id': firstItem.album_id,
            'album_title': firstItem.album_title,
            'cover_image': firstItem.cover_image,
            'digitalReleaseDate': firstItem.digitalReleaseDate,
            'physicalReleaseDate': firstItem.physicalReleaseDate,
            'pro_id': firstItem.pro_id,
            'product_upc': firstItem.product_upc,
            'tracks': []
        };
    _.each(item, function(albumItem) {
        spannedItem.tracks.push({
            'track_duration': albumItem.track_duration,
            'track_title': albumItem.track_title
        })
    })
    spanned.push(spannedItem);
});

return spanned;
}

当我在本地phpmyadmin上运行此查询时,我得到了正确的结果03:26但是当我在网络服务器上在线测试时,我得到00:03:26 ...这里有什么问题?它是SQL版本吗? BackboneJs无法处理SUBSTRING - 方法吗?

请帮忙!提前谢谢......

1 个答案:

答案 0 :(得分:1)

Backbone不知道你在MySQL中做了什么,所以Backbone没有MySQL SUBSTRING()的问题。

如果你想避免处理MYSQL,你可以简单地做

albumItem.track_duration.substr(3);

在视图中将其显示为" 03:26"。