1、 表名操作
在一个数据库中,如果部署了多个项目,那么我们可以使用表前缀解决问题
‘DB_PREFIX' =>‘think_’
tp中默认的表前缀是think_
如:数据库表名
我们接下来需要在配置文件config.php中,添加以下选项:
项目就可以正常工作。
tableName:
如:数据表名是sp_categorys,但是这个表对应的模型是 CategoryModel,那么,我不想改动文件名和类的前提下,还想使用这个模型。
trueTableName:
如:所有数据表的表前缀是sp,但某个表没有表前缀,如表名:goods,而不是sp_goods。
在子类模型中,添加trueTableName属性,表示是数据库的真实表名
2、 事务处理
在tp中,模型对象使用以下三个方法实现事务处理:
l $User->startTrans() :开启事务
l $User->commit() :提交事务
l $User->rollback() :回滚事务
什么情况下使用事务:
要么都成功,要么都失败
程序有一个文件,里面保存上百个人员的信息,我们需要使用php程序对文件中的人员信息入库。
3、 ActiveRecord
简称:AR模式
AR模式的核心:
1) 将数据表映射到类
2) 将字段映射到类属性
3) 将数据映射到类对象
class Goods{
private $id;
private $name;
private $content;
public function __set($name,$value){
$this->$name=$value;
}
public function __get($name){
return $this->$name;
}
public function insert(){
$sql=”insert into goods values(null,‘$this->name’,’$this->content’)”;
}
public function fetch($id){
$sql=”select * from goods where id=’$id’”;
$row=$db->query($sql);
$this->id=$row[‘id’];
$this->name=$row[‘name’];
}
}
$goods=new Goods();
$goods->name=’’;
$goods->content=’’;
$goods->insert();
--------------------------------------------------------------------
$goods=new Goods();
$goods->id=8;
$goods->delete();
$goods=new Goods();
$goods->fetch(8);
echo $goods->name;
TP中AR模式
1) 增加数据
l $User = M("User");
l $User->name = 'ThinkPHP';
l $User->email = 'ThinkPHP@gmail.com';
l $User->add();
2) 修改数据
l $User->find(1);
l $User->name = 'TOPThink';
l $User->save();
3) 删除数据
l $User->delete(8);
4) 查询数据
l $User = M("User");
l $User->find(8);
l echo $User->name;
l echo $User->email;
TP中AR模式的原理:
我们可以看到,在这几个操作时,直接对对象的属性赋值,如:$category->name=’abc’,但$category对象下并没有这些属性。原因:魔术方法。
下面,我们一起看一下父类Model中的魔术方法:
可以看出,当我们为某个对象的属性进行赋值时,会自动执行__set方法,这个方法将这个传递过来的属性名保存在当前对象的data属性数组中,并赋值
当对对象取值,会自动执行__get方法,首先判断当前对象data属性数组中是否有这个元素,如果有,返回它的值,否则返回null,
综上所述:
我们为对象赋值的属性和值都是存储在当前对象$data属性中.
add方法举例:
可以看出,如果我们之前调用add方法时没有传递参数data,会首先判断data是否为空,如果为空,再判断当前对象下data属性是否不为空,如果不为空,将$this->data属性数组中的值赋值给参数data.
4、 联贯操作
l where
l order
l limit
l field
l group
语法:
$对象->方法1()->方法2()->方法n()->select();
以上方法在使用时没有顺序上的要求
但是最后的方法必须是select();
5、 统计查询
l count :查询数据总行数
l max :取最大值
l min :取最小值
l avg :平均值
l sum :求和
以上方法与select或find方法平级的方法
一、 实用项
1、 设置trace信息
1) 开启调试模式
2) 开启跟踪信息机制
config.php配置文件
2、 session和cookie
在tp中,它又封装了一些方法用于操作session和cookie
1) session相关方法
l session('name','value'); :添加一个新的session,并赋值
l $value = session('name'); :获取指定的session的值
l session('name',null); :删除指定的session的值
l session(null); :清空所有session的值
l session('?name'); :判断指定的session是否存在
在tp中,session机制默认是开启的,可以通过更改配置文件来控制
2) cookie的相关方法
l cookie('name','value'); :添加一个新的cookie并赋值
l cookie('name','value',3600); :添加一个新的cookie并赋值,同时指定有效期
l $value = cookie('name'); :获取指定cookie的值
l cookie('name',null); :删除指定cookie的值
session案例:
项目登录案例:
在项目中添加公共控制器CommonAction,用于验证session登录,以后,所有需要验证的模块的控制器都继承这个公共控制器。
3、 文件载入
1) 函数文件
(1)common.php
Common/common.php
文件位置:
文件内容:
引用函数:
如果关闭调试模式,我们发现,在common.php文件中定义的函数会被写入到runtime.php文件中。下次执行时,会直接从runtime.php文件中查找并执行,也就是说,如果函数文件common.php发生改变,用户不会看到最新结果。
(2)config.php
LOAD_EXT_FILE=“user”
文件位置:
文件内容:
配置文件:
我们在Common目录下创建其它函数文件,在程序中,如果直接使用,发现调用了未定义函数,说明Common目录下的文件,除了common.php之外,都不会被自动加载。我们可这样做,修改配置文件,添加配置选项:LOAD_EXT_FILE=’引用文件的列表’,这样就可以程序中直接使用函数了,同时,我们可以看出,使用这个方法加载的函数不会被写入到runtime.php文件中,所以函数的内容发生改变后,用户可以立即看到最新结果。
(3)load(‘@.user’);
Common/user.php
文件位置:
程序:
这种方式的好处在于,需要使用什么样的文件,就去载入哪个文件,而不需要每次载入多余的文件。
2) 类文件
(1)import(‘ORG.Util.User’);
ORG/Util/User.class.php
文件位置:
控制器:
运行:
(2) import(‘@.Common.User’);
Lib/Common/User.class.php
文件位置:
控制器:
总结:
将自定义类文件放在tp框架中,使用:
import(‘ORG.Util.User’);
将自定义类文件放在项目中,使用:
import (‘@.Common.User’);
4、 验证码
在tp框架程序中,有一个文件,如下图所示,Image.class.php,可以帮助我们实现验证码的输出功能
Image类的使用方式:
(1) 在用户控制器UserAction中添加一个动作用于显示验证码:
(2) 修改模板中的验证码图片加载路径,让路径指向控制器中的方法
(3) 运行程序,并输入验证码
(4)对用户输入的验证码进行校验,注意,Image类在保存session验证码时使用了md5加密,所以用户输入的验证码在判断时,也需要使用md5加密,再进行比较
同时,Image类也提供了方法可以输出中文验证码
(1) 先将simhei.ttf字体库文件从fonts文件夹复制到与Image类同级目录下
(2) 创建控制器动作,用于显示中文验证码
(3) 显示与验证,与上题相同
5、 数据分页
1) 在tp中,有一个类:Page.class.php,可以实现数据分页功能
2)具体步骤
l $User = D(“User”);
l $count = $User->count();
l $page = new Page($count,25);
l $show = $Page->show();
l $list = $User->limit($Page->firstRow.',.$Page->listRows)->select();
l $this->assign('list',$list);
l $this->assign('page',$show);
l $this->display();
代码:
模板:
运行:
3) 可以通过分页对象的setConfig方法改变分页样式
l setConfig
l header
l prev
l next
l first
l last
在setConfig方法中,可以直接修改分页对象的config属性数组
我们可以在分页对象调用show方法之前,通过setConfig修改文字样式
运行: