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 ...
随机推荐
- 1010. Radix (25) pat
Given a pair of positive integers, for example, 6 and 110, can this equation 6 = 110 be true? The an ...
- LG2375 [NOI2014]动物园
题意 给定一个长为\(L\)的字符串(\(L \leq 1e6\)) 求一个\(num\)数组,\(num[i]\)表示长度为\(i\)的前缀中字符串\(S'\)的数量,其中\(S'\)既是该前缀的前 ...
- && 和 || 运算
a() && b() :如果执行a()后返回true,则执行b()并返回b的值:如果执行a()后返回false,则整个表达式返回a()的值,b()不执行: a() || b() :如果 ...
- MySQL--忘记MYSQL管理员密码
如root用户密码,可以按照以下方式来修改: STEP1: 停止MySQL服务 ps -ef | grep -v 'grep' | grep 'mysqld' | awk '{print $2}' | ...
- 在oracle的连接(join)中使用using关键字
如果是使用natraul join,并且两张表中如果有多个字段是具有相同的名称和数据类型的,那么这些字段都将被oracle自作主张的将他们连接起来. 但实际上我们有时候是不需要这样来连接的.我们只需要 ...
- bat计算两个时间差
这个是脚本代码[保存为etime.bat放在当前路径下即可: 免费内容: :etime <begin_time> <end_time> <return>rem 所测 ...
- Linux 性能工具安装部署
docker 一.运行docker Linux内核版本需要在3.8以上,针对centos6.5 内核为2.6的系统需要先升级内核.不然会特别卡 在yum的ELRepo源中,有mainline(4.5) ...
- nyoj 数独
数独 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 数独是一种运用纸.笔进行演算的逻辑游戏.玩家需要根据9×9盘面上的已知数字,推理出所有剩余空格的数字,并满足每一 ...
- 03.将MPP部署到开发板上
转载侵删 在一般的嵌入式开发中,只要将uboot,kernel,rootfs下载到开发板上,就可以进行程序开发了.但是海思又进一步的把一些常用视频编解码算法等封装到MPP平台中,进一步简化了工程师的开 ...
- Tomcat 8 中的startup.bat
1. bat文件 批处理文件,在DOS和Windows(任意版本)的系统中,bat文件是可执行文件 2. startup.bat 中涉及的bat语法 2.1 @. echo. echo off @ec ...