解决CI框架的Disallowed Key Characters错误提示

用CI框架时,有时候会遇到这么一个问题,打开网页,只显示 Disallowed Key Characters 错误提示。有人说 url 里有非法字符。但是确定 url 是纯英文的,问题还是出来了。但清空浏览器历史记录和cookies后。 刷新就没问题了。有时候。打开不同的浏览器。有的浏览器会有问题,有的就不会。

Read More

MySQL中select * for update锁表的问题

MySQL中select * for update锁表的问题由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL才会执行Row lock (只锁住被选取的资料例) ,否则MySQL将会执行Table Lock (将整个资料表单给锁住)。
举个例子:
假设有个表单products ,里面有id跟name二个栏位,id是主键。
例1: (明确指定主键,并且有此笔资料,row lock)
SELECT * FROM products WHERE id='3' FOR UPDATE;
SELECT * FROM products WHERE id='3' and type=1 FOR UPDATE;

Read More

脏读、不可重复读和虚读

脏读 dirty reads:当事务读取还未被提交的数据时,就会发生这种事件。举例来说:Transaction 1 修改了一行数据,然后 Transaction 2 在 Transaction 1 还未提交修改操作之前读取了被修改的行。如果 Transaction 1 回滚了修改操作,那么 Transaction 2 读取的数据就可以看作是从未存在过的。
不可重复的读 non-repeatable reads:当事务两次读取同一行数据,但每次得到的数据都不一样时,就会发生这种事件。举例来说:Transaction 1 读取一行数据,然后 Transaction 2 修改或删除该行并提交修改操作。当 Transaction 1 试图重新读取该行时,它就会得到不同的数据值(如果该行被更新)或发现该行不再存在(如果该行被删除)。
虚读(幻读) phantom read:如果符合搜索条件的一行数据在后面的读取操作中出现,但该行数据却不属于最初的数据,就会发生这种事件。举例来说:Transaction 1 读取满足某种搜索条件的一些行,然后 Transaction 2 插入了符合 Transaction 1 的搜索条件的一个新行。如果 Transaction 1 重新执行产生原来那些行的查询,就会得到不同的行。

Read More

php 时间计算问题小结

示例代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
<?php
//GB2312的Encode
header("Cache-Control: no-store, no-cache, must-revalidate");
header("Cache-Control: post-check=0, pre-check=0", false);

/*重点了解strtotime()函数
1、strftime比time()好用,可以直接把常用的’2010-02-03‘转成时间戳。
2、date()可以显示1970年前的时间。而不必用负数做参数
3、日期计算可以用时间戳来中转。计算两个日期相差的天数,可以取得相差的时间戳后除以“24小时*60分*60”秒来得到,但用strtotime()更简洁
4、了解用PEAR创建日历。这里略去。
知识点:网络上有关于date('Y-m-d',-800)来计算1970年前的时间,但WINDOW系统不支持负值,因此总会返回1970-1-1子夜。
*/

#PHP5必须先设置默认区。
date_default_timezone_set('ETC/GMT-8');
$nowdate='2010-02-23';
$lassdate = '2010-02-22';

echo 'strftime()函数输出的'.strftime('%Y-%m-%d %H:%M:%S',time()).'<br />';
echo 'date()函数输出的'.date('Y-m-d H:i:s',time()).'<br />';
//检查日期:boolean checkdate(int month,int day,int year)
$d='2010-2-31';
echo $d.'是'.(checkdate(2,31,2010)?'有效日期!':'无效日期!').'<br />';


//确定当月天数
echo '本月有'.date('t',time()).'天<br />'; //28天
//确定任意给定的月份的天数
$d='2008-02-01'; //闰年,或$d='2008-02';不需要输入天也可以
$d=strtotime($d);
echo '2008年2月有'.date('t',$d).'天<br />'; //29天

$d=getdate(); //getdate() 取得日期/时间信息。
echo '<pre>';
print_r($d);
echo '</pre>';

//echo date("Y-m-d H:i:s",-8000);
//setlocale(LC_ALL,'zh_CN.gb2312'); //setlocale函数对下面的没有影响。
#测试strftime,mktime函数。
echo strftime('今天是:%Y-%m-%d %H:%M:%S').'<br />';
echo strtotime('now').'<br />'; // 等于time(),但strtotime使用范围更灵活,参下文.
echo '测试还原昨天时间:'.date('Y-m-d',strtotime($lassdate)).'<br />'; //可以把字串型日期转成时间戳再用date转回原格式。
$x=strtotime($lassdate);
$y=mktime(0,0,0,'2','22','2010'); //mktime(hour,minute,second,month,day,year,is_dst) 返回一个日期的 Unix 时间戳。
echo 'strtotime()得到的昨天的时间戳是:'.$x.',mktime()得到的昨天时间戳是:'.$y.(($x==$y)?',二者相等':',二者不相同').'<br />'; //相等。

#显示1970年前的日期
$time_int=strtotime('1929-2-10');
echo date("Y-m-d ",$time_int).'<br />'; //在MYSQL中与date()函数相同功能的是date_format('1996-02-05 11:07:45','%Y-%m-%d')或for_format()

/*时间运算:
*请使用方法三。其它方法只供参考。 *
*/
#1、今天是23号,获得前天的时间,即减两天。
$predate=2;
$pretime=$predate*24*60*60; //2天的时间戳。
echo date('前天是:Y-m-d',time()-$pretime).'<br />'; //前天是:2010-02-21

#2、两个日期相差的天数。(php时间计算的的基础都是秒钟,把握这个规律后可以将时差换算成分钟,小时等均可)
$olddate = '2010-02-11'; //如果要用mktime函数,则要用explode拆解日期。
$oldtime = strtotime($olddate);
$passtime = time()-$oldtime; //经过的时间戳。
echo '你在网上泡了'.floor($passtime/(24*60*60)).'天了'.'<br />'; //12天。

#3、去年这个时侯。使用时要考虑闰年:平年365天,闰年366天。
#方法一:用减去全年天数的时间戳来获取。
$yDate=1;
$yDate_Y=date('Y',time())-1; //年份-1,即去年
$yDateYMD="$yDate_Y-01-01";
$yYMD=strtotime($yDateYMD); //去年的1月1号时间戳。
$d=date('L',$yYMD)?366:365; //是否是闰年
$yYearTime=$d*24*60*60;
$yYear=date('Y-m-d',time()-$yYearTime);
echo "去年的今天:$yYear<br />"; //2009-02-23

#方法二:用直接截取当前日期的年份减一,但不严谨,没有考虑到闰年。
#计算60年前的今天。忽略当中经过的闰年。
$yDate_Y=$yDate_Y-59;
$md=explode('-',date('Y-m-d'));
$yYMD="$yDate_Y-{$md[1]}-{$md[2]}";
echo "60年前的今天:$yYMD <br />"; //1950-02-23

#方法三:用strtotime()和GNU日期语法---------推荐!
//3天后; //当前时间为2010-02-23
$d=strtotime('3 days');
echo '3天后'.date('Y-m-d',$d)."<br />";
//3天前:
$d=strtotime('-3 days');
echo '3天前'.date('Y-m-d',$d)."<br />"; //2010-02-20
//一个月前:
$d=strtotime('-1 months');
echo '一个月前'.date('Y-m-d',$d)."<br />"; //2010-01-23

//2个月后:
$d=strtotime('2 months');
echo '二个月后'.date('Y-m-d',$d)."<br />"; //2010-04-23

//1年前:
$d=strtotime('-1 years');
echo '1年前'.date('Y-m-d',$d)."<br />"; //2009-02-23

//2小时前:
$d=strtotime('-2 hours');
echo '目前:'.date('Y-m-d H:i:s',time()).',2小时前'.date('Y-m-d H:i:s',$d)."<br />"; //目前:2010-02-23 13:38:49,2小时前2010-02-23 11:38:49

#DateTime构造函数:object DateTime([string $time [,dateTimeZone $timezone])
$date = new DateTime('2010-02-23 12:26:36');
echo $date->format('Y-m-d H:i:s')."<br />"; //和date()函数相同。2010-02-23 12:26:36
//重设时间:
//1、重设日期: boolean setDate(int year,int month,int day)
//2、重设时间: boolean setDate(int hour,int minute[,int second])
$date->setDate(2010,2,28);
echo $date->format('Y-m-d H:i:s')."<br />"; //2010-02-28 12:26:36
//日期计算,相当于上面的strtotime()
$date->modify("+7 hours");
echo $date->format('Y-m-d H:i:s')."<br />"; //2010-02-28 19:26:36
$date->modify("3 days");
echo $date->format('Y-m-d H:i:s')."<br />"; //2010-03-03 19:26:36 //从上面被改过的28号开始

/*PHP5在WIN不支持money_format函数?
setlocale(LC_MONETARY,'zh_CN');
echo money_format("%i",786.56);//?Fatal error: Call to undefined function money_format()
*/
?>

Read More