play 框架中如何在anorm 解析数据库结果时进行datetime格式转换?-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

play 框架中如何在anorm 解析数据库结果时进行datetime格式转换?

2016-02-11 23:21:48 2450 0

从MySQL取得的数据里有一项是time,取回来的是“yyyy-MM-dd HH:mm:ss”格式的java.sql.timestamp类型的数据,我有下面的代码把time转换成为joda.DateTime类型的数据,然后转为字符串传给前端,但是发现转换成了一串数字的timestamp形式,但是前端需要展示“yyyy-MM-dd HH:mm:ss”格式的时间。请问在服务器后台怎么进行这个格式化?
下面是我的代码。

import org.joda.time.DateTime

import anorm.SqlParser._
import anorm._
import play.api.db.DB
import play.api.libs.functional.syntax._
import play.api.libs.json._
import play.api.Play.current

/**
 * Created by zsh on 2015/5/11.
 */
case class JDItem(
                  id: Long,//商品ID
                  name: String,//商品名称
                  url: String,//商品url
//                  imgsrc: String,//商品图片(url)
                  price: Double,//商品价格
                  commentnum: Int,//商品评论数
                  likerate:Int,//好评率
                  time:DateTime,//上架时间
//                  wareInfo: String,//产品特色介绍(图文)
//                  wareStandard: String,//产品规格
//                  warePack:String,//产品包装
//                  wareService:String,//产品售后
                  category:String)

object JDItem {

  val jditem = {
    get[Long]("id") ~
    get[String]("name") ~
    get[String]("url") ~
    get[Double]("price") ~
    get[Int]("commentnum") ~
    get[Int]("likerate") ~
    get[DateTime]("time") ~
    get[String]("category") map {
      case id ~ name ~ url ~price~
        commentnum~likerate~time~category => JDItem(id,name,url,price,
        commentnum,likerate,time,category)
    }
  }

  implicit val JDItemWrites: Writes[JDItem] = (
    (JsPath \ "id").write[Long] and
      (JsPath \ "name").write[String] and
      (JsPath \ "url").write[String] and
      (JsPath \ "price").write[Double] and
      (JsPath \ "commentnum").write[Int] and
      (JsPath \ "likerate").write[Int] and
      (JsPath \ "time").write[DateTime] and
      (JsPath \ "category").write[String]
    )(unlift(JDItem.unapply))

  def getJson(category:String,sort:String,DescOrAsc:String):JsObject = DB.withConnection{ implicit c =>
    val list = SQL("select id,name,url,price,commentnum,likerate,time,category from "+category+" order by "+sort+" "+DescOrAsc+" limit 100").as(jditem *)
    val json:JsValue = Json.toJson(list)
    val jsobject = Json.obj("total"-> list.length,"rows"-> json)
    println("发送的字符串是========"+jsobject.toString())
    jsobject
  }

  def all(): List[String] = DB.withConnection { implicit c =>
    SQL("show tables").as(get[String]("table_name") *)
  }
}
取消 提交回答
全部回答(0)
相关问答

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 1038382浏览量 回答数 17

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157686浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 337002浏览量 回答数 8

22

回答

爬虫数据管理【问答合集】

我是管理员 2018-08-10 16:37:41 147231浏览量 回答数 22

31

回答

[@倚贤][¥20]刚学完html/css/js的新手学习servlet、jsp需要注意哪些问题?

弗洛伊德6 2018-10-27 21:52:43 146035浏览量 回答数 31

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 259827浏览量 回答数 38

21

回答

请教一下数据量有100万条左右要什么配置?

易网网络 2013-03-27 15:18:02 192637浏览量 回答数 21

249

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 305624浏览量 回答数 249

24

回答

【精品问答】python技术1000问(1)

问问小秘 2019-11-15 13:25:00 475623浏览量 回答数 24

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 204385浏览量 回答数 2
+关注
蛮大人123
我说我不帅他们就打我,还说我虚伪
0
文章
7733
问答
问答排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载