Thinkphp学習で通ったいくつかのピット(更新)
ページをめくるクラス自体には3番目のパラメータがあり、ページを分けてジャンプするパラメータがあります.
*@param array$totalRows合計レコード数
*@param array$listRows 1ページあたりのレコード数を表示
*@param array$parameterページングジャンプのパラメータ
1.get方式であれば、何も設定する必要がなく、パラメータが自動的にURLについていく
2.postではコントローラにパラメータをページングクラスに書き込んで、対応するページングコードを生成する必要があります.
(以前クエリーを試してみたときに条件をセッションに保存し、ページをめくるときに保存した値をクエリー条件とし、条件を判断してセッションを更新したが、その時はできなかった)
2.alert後のリフレッシュについて
ボタンをクリックしてリフレッシュする場合は、ボタンタイプがbottonでなければリフレッシュされません
3.viewページで判断
TPで{if xxxx}{elseif condition="xxx"/}
後に1つ追加する必要があります/
4.ThinkphpにおけるVolistの文字化けしの問題
(1)ページのエンコード設定エラー
(2)出力配列フォーマットエラー、例えばインデックス配列をキー値で出力
findクエリの値は、1次元配列です
selectクエリの値は、2 D配列で、1番目のレイヤはインデックス配列、2番目のレイヤは関連配列です.
5.__PUBLIC__,图片存放地址在数据库
__PUBLIC__这种常量是需要通过php内核解析的,将其存进数据库,先解析你的自定义变量后,就不会去解析取出来的__PUBLIC__了,所以不应把常量存数据库
6.Lib 和TPl 中模版的不同,前者是实现的模版 php ,后者是显示的模版html
dirname(__FILE__) php中定义了一个很有用的常数,即__file__这个内定常数是当前php程序的就是完整路径(路径+文件名)。即使这个文件被其他文件引用(include或require),__file__始终是它所在文件的完整路径,而不是引用它的那个文件完整路径。请看下面例子:/home/data/demo/test/a.php$the_full_name=__FILE__;$the_dir=dirname(__FILE__);echo $the_full_name; //返回/home/data/demo/test/a.phpecho $the_dir; //返回/home/data/demo/test?>home/data/demo/b.php echo $the_full_name; //返回/home/data/demo/echo $the_dir; //返回/home/data/demo/test而不是/home/data/demo/?>test/a.php 而不是/home/data/demo/b.php简单地说:__FILE__ 返回当前路径+文件名dirname(__FILE__) 返回当前文件路径的路径部分dirname(dirname(__FILE__));得到的是文件上一层目录名(不含最后一个“/”号)例如,当前文件是/home/data/demo/test.php ,则__FILE__ 得到的就是完整路径即 /home/data/demo/test.php ,而
dirname(__FILE__)得到路径部分即/home/data/demo (后面没有“/”号)
7.命名范围的使用
class UserModel extends CommonModel{
protect $_scope=array(
/*命名范围的标识名=>array(
'属性'=>'值',
支持的方法有:where limit field order table page having group disinct),*/
);
}
1 /*'命名范围的标识名'=>array(
'属性'=>'值',
支持的方法有:where limitfield order table page having goup distinct
)*/
2 先在模型类中设置成一个数组并在常用的方法
3 然后在控制器中调用如where field order table pagehaving group distinct中使用
4 后面调用到的sql筛选条件会将前面的覆盖,scope可以和普通连贯方法混合使用
如多次调用limit,只有最后一条limit生效
5 优点 一次定义多次调用
项目中项目主管定好名称后可以让多人分工合作时CURD操作不会混乱
8.过滤查询之distinct方法
1 语法 distinct方法用来过滤相同信息,属性为true过滤和false不过滤
2 例子 $data=M('user')->distinct(true)->field('score')->order('scoreasc')->select();
9.union()用于合并两个或多个 SELECT 语句的结果集
获取user表 的字段,必须与 union() 中获取的字段相同,对应字段的类型也要相同,顺序也必须相同.
union() 的第二个参数默认 =false ,表示不会将重复数据隐藏; =ture ,表示将会隐藏重复数据
union() 可以进行连贯操作
字符串方法:
$data= M('user')->field('user_name,id')
->union('select user_name,id from wp_info');
数组方法:
$data= M('user')->field('user_name’)->
union(array('field'='user_name','table'='wp_info'),true);
10.多表查询join()支持字符串和数组且join()中的表都必须加前缀(写全称)
字符串方式: M(‘user')->join('mk_userinfo Onmk_userinfo.user_id=mk_user.id')->select();
Left join 左关联
Right join 右关联
inner join 内联(ThinkPHP3.2 默认采用 INNER JOIN 方式)
M('user')->join('Right join mk_userinfo Onmk_userinfo.user_id=mk_user.id')->select();
多表关联添加join
数组方式: M('user')->join(array('mk_userinfo On mk_userinfo.user_id=mk_user.id'))-select();
11.使用phpexcle导入数据库时,数据量过大造成的问题
(1)导入速度过慢,以致于超过原本的30秒
(2)phpexcle大数据量情况下内存溢出
解决方法:
设置导入时长:
(1)修改php的配置文件 php.ini 文件找到 php.ini 这个文件,然后在这个文件中找到:max_execution_time = 30 ;这一行,将数字 30 设置成你想要的值,单位是秒。(也可以直接修改为:max_execution_time=0;//无限制)注意这样修改完后需要重启一下服务器。 (2)使用 ini_set() 函数对于那些不能够修改 php.ini 的朋友来说,你可以使用ini_set()这个函数来改变你的最大执行时间限制值,在程序的顶部加入如下代码:ini_set('max_execution_time','100');以上设置的为100秒,你也可以设置为0,那么就是不限制执行的时间。 (3)使用set_time_limit() 函数
在程序的顶部加入:set_time_limit(100);则表示最大执行时间设置为了100秒,当然也可以将参数设置为0,意思同上。set_time_limit 函数特别说明:void set_time_limit ( int $seconds ) 该函数的作用是设置允许脚本运行的时间,单位为秒。如果超过了此设置,脚本返回一个致命的错误。默认值为30秒,或者是在php.ini的max_execution_time被定义的值,如果此值存在。当此函数被调用时, set_time_limit()会从零开始重新启动超时计数器。换句话说,如果超时默认是30秒,在脚本运行了了25秒时调用 set_time_limit(20),那么,脚本在超时之前可运行总时间为45秒。当php运行于安全模式下时,此功能不能生效。除了关闭安全模式(在 php.ini 中将 safe_mode 设置为 off)或改变 php.ini 中的时间限制,没有别的办法。案例:如果没有打开安全模式,设置程序运行时间为25秒。
此部分转载自:http://www.kokojia.com/article/4752.html
在在不进行特殊设置的情况下,phpExcel将读取的单元格信息保存在内存中,我们可以通过PHPExcel_Settings::setCacheStorageMethod()来设置不同的缓存方式,已达到降低内存消耗的目的!1、将单元格数据序列化后保存在内存中PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized; 2、将单元格序列化后再进行Gzip压缩,然后保存在内存中PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip; 3、缓存在临时的磁盘文件中,速度可能会慢一些PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;4、保存在php://tempPHPExcel_CachedObjectStorageFactory::cache_to_phpTemp; 5、保存在memcache中
PHPExcel_CachedObjectStorageFactory::cache_to_memcache
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_memcache; $cacheSettings = array( 'memcacheServer' => 'localhost', 'memcachePort' => 11211, 'cacheTime' => 600 ); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
注意new PHPExcel()の前に付けます.以下のようにします.import("Org.Util.PHPExcel.CachedObjectStorageFactory.php") $PHPExcel = new \PHPExcel_CachedObjectStorageFactory; $cacheMethod = $PHPExcel ::cache_to_phpTemp; $cacheSettings = array('memoryCacheSize'=>'16MB'); $Settings = new \PHPExcel_Settings; $Settings::setCacheStorageMethod($cacheMethod, $cacheSettings); $objReader = new \PHPExcel_IOFactory;
転載先:https://www.cnblogs.com/myx/archive/2013/05/20/phpExcel-setCache.html
12.ajax失効
(1)データ接続エラー
(2)データベースに他のめちゃくちゃなエラーがない