我有这个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
- 方法吗?
请帮忙!提前谢谢......
答案 0 :(得分:1)
Backbone不知道你在MySQL中做了什么,所以Backbone没有MySQL SUBSTRING()
的问题。
如果你想避免处理MYSQL,你可以简单地做
albumItem.track_duration.substr(3);
在视图中将其显示为" 03:26"。