mongo的时间类型,erlang中对其的处理

需求:要想在一个调度中,从mongo中查出大于一个时间戳的所有的数据总和。

这个需求很简单,一个是scheduler,还有另一个就是查出来大于某个时间戳的总和,比如大于每天0点时间点的和.

需要注意的是:mongo中的date类型以UTC(Coordinated Universal Time)存储,就等于GMT(格林尼治标准时)时间,我们是+8时区,也就是时差相差8,所以+8小时就是系统当前时间.

举个栗子:

%% 获取当天的0点时间戳
%% GMT时间(格林尼治时间)比北京时间少8小时
get_today_zerotime_timestamp() ->
 calendar:datetime_to_gregorian_seconds({date(),{0,0,0}}) -  calendar:datetime_to_gregorian_seconds({{1970,1,1}, {0,0,0}}) - 8*60*60.

  

%%定时调度,从"mh_android"表中,统计这时刻的发送消息数-------send_trend--------------------------
total_message()->

        DbInfo = op_mongo:init_dbinfo(),
        {MongoConn, DbName, Collection}=op_mongo:split_mh_android(DbInfo),
         Zero_time = get_today_zerotime_timestamp(),        %获取mongo中0点时间戳
        {ok, Num} = mongo:do(unsafe, slave_ok, MongoConn, DbName,
                                            fun() ->mongo:count( Collection, {"sut",  {<<"$gte">>,Zero_time}} ) end), %% 获取时间戳"sut"大于等于0点时间戳的总和

  

时间: 2024-10-27 04:31:55

mongo的时间类型,erlang中对其的处理的相关文章

MySQL中日期和时间类型

1 日期类型 MySql中关于日期的类型有Date/Datetime/Timestamp三种类型. 日期赋值时,允许"不严格"语法:任何标点符都可以用做日期部分或时间部分之间的间割符.例如,'98-12-31 11:30:45'.'98.12.31 11+30+45'.'98/12/31 11*30*45'和'[email protected]@31 11^30^45'是等价的,对于不合法的将会转换为:0000-00-00 00:00:00 1.1 Date格式 此类型的字段,存储数据

Java中,关于字符串类型、随机验证码、 时间类型

一.字符串类型:String类型 定义一个字符串 String a="Hello World"; String b= new String ("Hello World"); 字符串之间的拼接: String a=abcd; String b=abcd; String c=a+b; System.out.println(c); //输出的值 为 "abcdabcd" //string类型同样可以和int类型拼接,假设 int d= 555, 那么

sqlserver中对时间类型的字段转换

获取当前日期利用 convert 来转换成我们需要的datetime格式. select CONVERT(varchar(12) , getdate(), 112 ) 20040912------------------------------------------------------------ select CONVERT(varchar(12) , getdate(), 102 ) 2004.09.12-----------------------------------------

MySql中的时间类型datetime,timestamp,date,year比较

MySQL日期类型.日期格式.存储空间.日期范围比较.日期类型        存储空间       日期格式                 日期范围------------ ---------   --------------------- -----------------------------------------datetime       8 bytes   YYYY-MM-DD HH:MM:SS   1000-01-01 00:00:00 ~ 9999-12-31 23:59:5

java中存储mysql数据库时间类型【date、time、datetime、timestamp】

在MySQL中对于时间的存储自己见表的时候都是设置的varchar类型的,感觉挺方便的. 昨天拿别人建好的表写代码,发现这张表中时间类型为datetime的,凭感觉试了一下不行,网上查了刚开始试了好几个都是不对的,一脸懵逼. -----------------------------------------------------------------------------------------------------------------------------------------

1 Java中的时间类型

总结:sql中的时间转 util的时间直接赋值即可:反过来,必须先吧util下的时间转换成毫秒,再通过sql的构造器生成sql的时间格式. 1 Java中的时间类型 java.sql包下给出三个与数据库相关的日期时间类型,分别是: l Date:表示日期,只有年月日,没有时分秒.会丢失时间: l Time:表示时间,只有时分秒,没有年月日.会丢失日期: l Timestamp:表示时间戳,有年月日时分秒,以及毫秒. 这三个类都是java.util.Date的子类. 2 时间类型相互转换 把数据库

MySql中时间类型总结

最近建表要用到时间类型的数据,但对时间类型的数据一向不了解,就总结了一下.. 一.日期DATE 一个日期.支持的范围是"1000-01-01"以"9999-12-31".MySQL显示日期用 "YYYY-MM-DD"格式,但允许使用字符串或数字列赋值日期. 1.在一个字符串"YYYY-MM-DD"或"yy-mm-dd"格式."不严格"语法是允许任何标点符号 字符可以作为之间的日期部分的分

input在HTML5中的六种时间类型应用教程

[转自e良师益友网]HTML5每日坚持一练:今天介绍一下input在HTML5中的6种时间类型的应用,你可以自己尝试编出实例的哦 1.Date类型 如果在之前,我们使用js+css+dom才能实现日历选择日期的效果,在HTML5中,我们只需要设置input为date类型即可,提交表单的时候也不需要我们验证数据了,它已经帮我们实现了. 2.Time类型 此类型是一个专门用来输入时间的文本框,在提交的时候检查是否输入了有效的时间. 3.DateTime类型 datetime类型的input元素是专门

MySQL 中的日期时间类型

日期时间类型中包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体的取值范围,超出或非法的其他值时,MySQL 会回退到 0.TIMESTAMP 类型是个例外,给它设置一个超出范围的值时,将保存上该类型允许的最大值. MySQL 按标准格式 YYYY-MM-DD hh:mm:ss[.fraction] 输出日期时间,但设置或进行日期时间相关的比较时却支持灵活的多种格式,会自动解析.具体支持的输入格式可参见 Section 9.1.3, "Da