mongodb 中date 类型的处理:ISODate

存储在mongodb 中的 date 类型,

例如:utime: ISODate('2017-04-11 T00:00:00.00Z')

查找当天的时间:

数据表名: foo

数据库中命令语句:

db.foo.find({'utime':{$gte:ISODate('2017-04-11 T00:00:00.00Z'),$lte:ISODate('2017-04-12 T00:00:00.00Z')})

python中语句:

数据库类 foo;

import datetime;

传过来的数据为query={'type':'','value':''}

type:为字段,value:为数值

传过来的value类型str ='2017-04-11'

search = {query['type']: {'$gte': datetime.datetime.strptime(query['value'], "%Y-%m-%d"), '$lte': datetime.datetime.strptime(query['value'], "%Y-%m-%d") + datetime.timedelta(days=1)}}

result = query['value'].split('-')

在datetime 中不能对  str 类型进行强制转换,必须在外部转换。

year = int(result[0])

month = int(result[1])

day = int(result[2])

search = {query['type']: {'$gte': datetime.datetime(year, month, day, 0, 0), '$lte': datetime.datetime(year, month, day+1, 0, 0)}}

foo.find(search)

查询到当天的日期列表。

有更好的办法会再进行补充。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值