使用javaDate类代数据仓库维度表
使用javaDate类代数据仓库维度表
Date类别:
,返回一个相对日期的毫秒数。精确到毫秒。但不支持日期的国际化和分时区显示。
Date 类从Java 开发包(JDK)1.0 就開始进化,当时它仅仅包括了几个取得或者设置一个日期数据的各个部分的方法。 比方说月, 日, 和年。 这些方法如今遭到了批评而且已经被转移到了Calendar类里去了,这样的改进旨在更好的处理日期数据的国际化格式。
Calender类:
相对于Date更加强大的时间类,是抽象类,提供了常规的日期改动功能和国际化支持。
GregorianCalendar类:
提供处理日期的方法。用于计算日期。是Calendar类的子类,实用的是有个推断闰年的方法。
DateFormat类:
能够接受字符串输入、输出。提供了将日期/时间信息进行格式化处理的功能。
SimpleDateFormat类:
功能更强大的日期时间格式化类,自己定义格式化日期和时间。
java.util.Locale类:
描写叙述特定的地理、政治、文化上的地区。Locale对象主要封装了“地区”和“语言种类”双方面 .
以下用代码来模拟生成日期维度表的一些字段值:
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;
import java.util.Locale;
public class DateUtil {
Localeloc = new Locale("zh", "CN");
// Localeloc = new Locale("en", "CN");
Calendarcalendar = new GregorianCalendar(loc);
publicvoid init(){
calendar.set(2014,9, 10);
}
publicDate add(int day){
calendar.add(Calendar.DAY_OF_MONTH,day);
returncalendar.getTime();
}
publicvoid showDate(Date date){
p("TimeInMillis",calendar.getTimeInMillis()+"");
p("ShortDate",java.text.DateFormat.getDateInstance(java.text.DateFormat.SHORT,loc)
.format(date));
p("MEDIUMDate",java.text.DateFormat.getDateInstance(java.text.DateFormat.MEDIUM,loc)
.format(date));
p("LONGDate",java.text.DateFormat.getDateInstance(java.text.DateFormat.LONG, loc)
.format(date));
p("LONGFULL",java.text.DateFormat.getDateInstance(java.text.DateFormat.FULL, loc)
.format(date));
SimpleDateFormatsdf = new SimpleDateFormat("D",loc);
p("dayin year",sdf.format(date));
sdf.applyPattern("d");
p("dayin month",sdf.format(date));
sdf.applyPattern("EEEE");
p("dayname",sdf.format(date));
sdf.applyPattern("E");
p("dayabbreviation",sdf.format(date));
sdf.applyPattern("ww");
p("weekin year",sdf.format(date));
sdf.applyPattern("W");
p("weekin month",sdf.format(date));
sdf.applyPattern("MM");
String month = sdf.format(date);
p("monthnumber",sdf.format(date));
sdf.applyPattern("MMMM");
p("monthname",sdf.format(date));
sdf.applyPattern("MMM");
p("monthabbreviation",sdf.format(date));
sdf.applyPattern("yy");
p("year2",sdf.format(date));
sdf.applyPattern("yyyy");
p("year4",sdf.format(date));
intquarter_number = (int)Math.ceil( (Integer.parseInt(month) /3.0));
p("quertername","Q"+quarter_number);
intfirst_day_of_week = calendar.getFirstDayOfWeek();
p("is_first_day_of_week",firstWeekDay(first_day_of_week));
}
publicvoid p(String desc,String date){
System.out.println(desc+ " : " + date);
}
publicvoid calAndShow(){
for(int i = 0; i < 3; i++) {
init();
showDate(add(i));
System.out.println();
}
}
publicString firstWeekDay(int first){
returnfirst == calendar.get(Calendar.DAY_OF_WEEK) ? "yes" : "no";
}
publicstatic void main(String[] args) {
DateUtild = new DateUtil();
d.calAndShow();
System.out.println(Math.ceil(11.0/3.0));
}
}
版权声明:本文博客原创文章。博客,未经同意,不得转载。
使用javaDate类代数据仓库维度表的更多相关文章
- 《BI那点儿事—数据的艺术》理解维度数据仓库——事实表、维度表、聚合表
事实表 在多维数据仓库中,保存度量值的详细值或事实的表称为“事实表”.一个按照州.产品和月份划分的销售量和销售额存储的事实表有5个列,概念上与下面的示例类似. Sate Product Mouth U ...
- 维度表, 事实表, 数据仓库, BI...
以前一直对维度表, 事实表, 数据分析, BI等概念等有一些模糊. 这几天的学习终于让这些有了一些眉目了: 维度表示你要对数据进行分析时所用的一个量, 比如你要分析产品销售情况, 你可以选择按类别来进 ...
- 【BIEE】04_当维度表中的维不存在事实表中,需要展示所有维度并且数据类展示为0
有时候,我们往往会存在这样的需求 例如:事实表的数据如下 EMP_FACT表示事实表,DIM_LEVEL是维度表 预期效果:(根据员工信息,分析各等级员工工资与员工个数) 我们在BIEE报表中新建报表 ...
- HAWQ取代传统数仓实践(八)——维度表技术之角色扮演维度
单个物理维度可以被事实表多次引用,每个引用连接逻辑上存在差异的角色维度.例如,事实表可以有多个日期,每个日期通过外键引用不同的日期维度,原则上每个外键表示不同的日期维度视图,这样引用具有不同的含义.这 ...
- BI中事实表和维度表的定义
一个典型的样例是,把逻辑业务比作一个立方体,产品维.时间维.地点维分别作为不同的坐标轴,而坐标轴的交点就是一个详细的事实.也就是说事实表是多个维度表的一个交点.而维度表是分析事实的一个窗体. 首先介绍 ...
- HAWQ取代传统数仓实践(十二)——维度表技术之分段维度
一.分段维度简介 在客户维度中,最具有分析价值的属性就是各种分类,这些属性的变化范围比较大.对某个个体客户来说,可能的分类属性包括:性别.年龄.民族.职业.收入和状态,例如,新客户.活跃客户.不活跃客 ...
- HAWQ取代传统数仓实践(十一)——维度表技术之维度合并
有一种合并维度的情况,就是本来属性相同的维度,因为某种原因被设计成重复的维度属性.例如,在销售订单示例中,随着数据仓库中维度的增加,我们会发现有些通用的数据存在于多个维度中.客户维度的客户地址相关信息 ...
- HAWQ取代传统数仓实践(十)——维度表技术之杂项维度
一.什么是杂项维度 简单地说,杂项维度就是一种包含的数据具有很少可能值的维度.事务型商业过程通常产生一系列混杂的.低基数的标志位或状态信息.与其为每个标志或属性定义不同的维度,不如建立单独的将不同维度 ...
- HAWQ取代传统数仓实践(九)——维度表技术之退化维度
退化维度技术减少维度的数量,简化维度数据仓库模式.简单的模式比复杂的更容易理解,也有更好的查询性能. 有时,维度表中除了业务主键外没有其它内容.例如,在本销售订单示例中,订单维度表除了订 ...
随机推荐
- linux命令:rm
删文件要一个个回答y,谁有好办法自动删除? rm -rf 用rm递归删除目录下面的所有.o文件: find . -name "*.o" | xargs rm -f :
- ASM - 条件判断
技术交流,DH讲解. 正式之前,我们看看寄存器和CPU的标志位: OD中的截图,下方的CPAZSTDO就是标志位. Delphi的FPU窗口,右边一列就是标志位.为什么要给大家看标志位呢?因为ASM中 ...
- 火炬之光模型导出(Unity载入火炬之光的模型)
先说明几点.导出方案可行,測试通过. python和blender的版本号一定要用下文中所说的.新的Python或者是新的Blender版本号都无法完美导入. 导入导出脚本能够选择 (http://c ...
- 软考之路(四)---软件project一 概念模型,逻辑模型,物理模型
自从接触到数据库到如今这三个概念大家理解的还有些不清楚,今天来为大家解答疑惑,共同提高,结合生活理解 概念模型 概念模型就是在了解了用户的需求,用户的业务领域工作情况以后,经过分析和总结 ...
- CodeForce 439C Devu and Partitioning of the Array(模拟)
Devu and Partitioning of the Array time limit per test 1 second memory limit per test 256 megabytes ...
- Beauty of Array
Description Edward has an array A with N integers. He defines the beauty of an array as the summatio ...
- MTU & MSS 详解记录(转)
先学习理解一下帧的封装格式: 需要注意的是,区别两种帧封装格式:802标准帧和以太网帧 1,在802标准定义的帧格式中,长度字段是指它后续数据的字节长度,但不包括C R C检验 ...
- TCP/IP笔记 二.网络层(2)——ICMP,RIP,OSPF,BGP
1. ICMP ICMP (Internet Control Message Protocol) 作用:提高 IP 数据报交付成功的机会. 1.1 特点 ICMP 允许主机或路由器报告差错情况和提供有 ...
- MapReduce调度与执行原理之作业初始化
前言 :本文旨在理清在Hadoop中一个MapReduce作业(Job)在提交到框架后的整个生命周期过程,权作总结和日后参考,如有问题,请不吝赐教.本文不涉及Hadoop的架构设计,如有兴趣请参考相关 ...
- Windows的自带控件(比如TButton)大多数消息都由它自己处理,Delphi覆盖了那么多WM_函数优先级较低,一般用不上
在空窗体上放一个TButton,一个TPanel,然后把在TWinControl.WMEraseBkgnd里下断点: procedure TWinControl.WMEraseBkgnd(var Me ...