yii 日期插件
——controller
public $defaultAction = "income";
public function actionIncome(){
$model = new StatsSpace;
$model->user_id = Yii::app()->user->id;
//日期
$idate = isset($_POST['Income']['idate']) ? $_POST['Income']['idate'] : "";
if(!$idate){
$endDate = date("Y-m-d");
$idate = date('m/d/Y',time()-24*3600*5)." - ".date("m/d/Y");
$_POST['Income']['idate']=$idate;
//$idate = date('m/d/Y',strtotime('2012-08-08'))." - ".date("m/d/Y");
}
$model->idate = $idate;
//计算month_income用
$model->idate_from_controller = $idate;
//tabs
$sumall = $model->getSumAllIncome();
//$dataProvider 数据提供者
$dataProvider = $model->getDataProviderIncome($idate);
$this->render("income", array(
'model'=>$model, //$model = new StatsSpace;
'sumall'=>$sumall, //tabs 根据广告位置,算总收入
'idate'=>$idate, //$model->idate_from_controller $model->idate 日期
'dataProvider'=>$dataProvider, //getDataProviderIncome($idate)【下面表格的具体数值】;
));
}
--------------model【data——where】
/**
* tabs相关
*/
public function getSumAll(){
$idate = $this->idate;
if($idate){
$tmp = explode(' - ', $idate);
$startDate = strtotime($tmp[0]);
$d1 = date('Y-m-d', $startDate);
$endDate = strtotime($tmp[1]);
$d2 = date('Y-m-d', $endDate);
}else{
$startDate = strtotime(date("Y-m-d",time()-24*3600*5));
$endDate = strtotime(date("Y-m-d"));
$d1 = date('Y-m-d', $startDate);
$d2 = date('Y-m-d', $endDate);
}
$sql = "SELECT
SUM(totalIncome) AS totalIncomeSum,
SUM(cpcIncome) AS cpcIncomeSum,
SUM(cpmIncome) AS cpmIncomeSum,
monthIncome AS monthIncomeSum
FROM
{{income}}
WHERE
user_id=:user_id
AND
idate>='$d1'
AND
idate<='$d2'";
$uid = Yii::app()->user->id;
$cmd = Yii::app()->db->createCommand($sql);
$row = $cmd->bindValue(':user_id', $uid)->queryRow();
return $row;
}
static public function computeAllData($d1="",$d2=""){
$user_id = Yii::app()->user->id;
if($d1 && $d2){
$where = "WHERE idate >= '{$d1}' AND idate <='{$d2}' AND user_id={$user_id}";
}else{
$where = "WHERE user_id={$user_id}";
}
$sql = "SELECT id,SUM(cpcAllShows) cpcAllShows,SUM(cpcValidClicks) cpcValidClicks,SUM(cpmAllShows) cpmAllShows,SUM(cpmValidShows) cpmValidShows,SUM(monthAllShows) monthAllShows,
SUM(totalIncome) totalIncome,SUM(cpcIncome) cpcIncome,SUM(cpmIncome) cpmIncome,SUM(monthIncome) monthIncome FROM {{income}}
$where
";
$row = Yii::app()->db->createCommand($sql)->queryRow();
return $row;
}
____view
<?php $form=$this->beginWidget('bootstrap.widgets.TbActiveForm',array(
'htmlOptions'=>array('style'=>'float:left;margin-bottom:-5px;')
)); ?>
<!--日期-->
<div style="float:left; margin-bottom: 20px;">
<div style="float:left;margin-left:5px;height:30px;text-align: bottom;position:position:relative "><p style='position:relative;margin:5px;font-size: 20px'>日期</p></div>
<?php
$this->widget('bootstrap.widgets.TbDateRangePicker', array(
'name'=>'Income[idate]',
'value'=>$model->idate,
'options'=>array(
'showAnim'=>'fold',
),
'htmlOptions'=>array(
'style'=>'height:20px;float:left;'
),
));?>
<?php $this->widget('bootstrap.widgets.TbButton', array('buttonType'=>'submit', 'type'=>'null', 'label'=>'查询','htmlOptions'=>array('style'=>'margin:0 0 10px 5px;')));?>
</div>
<?php $this->endWidget(); ?>
yii 日期插件的更多相关文章
- yii2.0使用bootstrap中日期插件
Yii2框架引用bootstrap中日期插件yii2-date-picker的方法. 使用composer安装 日期插件 php composer.phar require "2amigos ...
- 轻量级的日期插件--datebox
jquery的日期插件有好几款,H5中的input也可以自带日期选择.但为什么要再写一个,有两个理由,一个是引用的文件太大,而有时候只需要很简单的功能,二个是想加一些自定义的效果不好改. 我写的这个功 ...
- My97DatePicker日期插件
My97DatePicker是一款优秀的日期插件,它可以很方便地实现各种日期选择效果,博得广大IT开发人员的青睐. 下面来讲讲它的常用功能及设置方法. 方法/步骤 先来最简单的配置方法: (1)下 ...
- 基于JS功能强大的日期插件Kalendae
开发中需要一个日期插件,可以在zepto下使用,可以选择日期段,可以设置不可选日期 找到一个完全满足的,并且基于JS不依赖于任何库. 在线演示:http://chipersoft.com/Kalend ...
- jsp日期插件My97DatePicker
jsp日期插件My97DatePicker 强大的日期控件 使用方便简单 (2010-10-30 18:59:12) 转载▼ 标签: js javascript 日期插件 jsp it 分类: jqu ...
- jquery ui bootstrap日期插件
http://blog.csdn.net/php_897721669/article/details/7404527 搜索“jquery ui日期插件怎么显示年份”? $("#datepic ...
- (转)JQM 日期插件 mobiscroll Demo
(原)http://www.wglong.com/main/artical!details?id=11 JQM 日期插件 mobiscroll Demo 2013-04-25 / 分类:Jquery ...
- (转)jQuery Mobile 移动开发中的日期插件Mobiscroll 2.3 使用说明
(原)http://www.cnblogs.com/hxling/archive/2012/12/12/2814207.html jQuery Mobile 移动开发中的日期插件Mobiscroll ...
- bootstrap的日期插件datetimepicker有问题
bootstrap的日期插件datetimepicker在chrome中会出现掉下来的现象,而且一直没找到原因,下载最新版的插件直接在各个浏览器中都会掉下来, 问题一直解决不了,转而换其他插件 htt ...
随机推荐
- HDU 1176:免费馅饼(DP,自认为很详细的解释)
免费馅饼 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- 习题3.5 求链表的倒数第m个元素(20 分)浙大版《数据结构(第2版)》题目集
请设计时间和空间上都尽可能高效的算法,在不改变链表的前提下,求链式存储的线性表的倒数第m(>0)个元素. 函数接口定义: ElementType Find( List L, int m ); 其 ...
- jQuery插件制作方法详解
jQuery插件制作方法详解 jquery插件给我的感觉清一色的清洁,简单.如Jtip,要使用它的功能,只需要在你的元素的class上加 上Jtip,并引入jtip.js及其样式即可以了. ...
- python 直接将list 整体转化-----------map()
假设有这样一个 results = ['1', '2', '3'] 转化为下面这个样子 results = [1, 2, 3] 我们可以使用map函数 在Python2中这样操作: results = ...
- Thrift 个人实战--Thrift 网络服务模型(转)
前言: Thrift作为Facebook开源的RPC框架, 通过IDL中间语言, 并借助代码生成引擎生成各种主流语言的rpc框架服务端/客户端代码. 不过Thrift的实现, 简单使用离实际生产环境还 ...
- 实习第一周第一天:接口 extends是继承类,implement是实现接口,原接口里面的方法填充,方法名也是不变,重写override是父类的方法名不变,把方法体给改了
一.定义 Java接口(Interface),是一系列方法的声明,是一些方法特征的集合,一个接口只有方法的特征没有方法的实现,因此这些方法可以在不同的地方被不同的类实现,而这些实现可以具有不同的行为( ...
- mysql常用的聚合函数
GROUP BY(聚合)函数本章论述了用于一组数值操作的 group (集合)函数.除非另作说明, group 函数会忽略 NULL 值. 假如你在一个不包含 ROUP BY子句的语句中使用一个 gr ...
- 用复制mysql/data 文件夹 下面的数据库的形式来复制数据库出现的问题
用复制mysql/data 文件夹 下面的数据库的形式来复制数据库出现的问题 提示找不到表,我去看了一下,丢失了很多个表: 问题: 直接拷贝data下的数据库数据进行备份 , 发现部分数据表不见了. ...
- Spark的启动进程详解
Master和Worker是执行任务之前存在的进程 (类似于公司) Driver和Excutor是任务执行之后存在的进程(类似于公司接到项目后才成立的项目小组) 启动步骤: 启动Master资源管理进 ...
- 2018第52周日&技术人员如何面对裁员?
2018的最后一周,看了汽车的两个趋势,纯电动车和自动驾驶,两个现在很火但还有很多问题要解决的方向,尤其是自动驾驶.虽然它因为一些问题当前不能完全被克服,但因它而生的各种辅助驾驶技术却被用的越来越多, ...