`

ThinkPHP学习笔记

 
阅读更多

from:http://www.thinkphp.cn/info/233.html

约定:
1.所有类库文件必须使用.class.php作为文件后缀,并且类名和文件名保持一致
2.控制器的类名以Action为后 缀
3.模型的类名以Model为后缀,类名第一个字母须大写
4.数据库表名全部采用小写,

如:
数据表名: 前缀_表名
模型类名: 表名Model 注:这里的表名第一个字母要大写
创建对象: D('表名') 注:这里的表名第一个字母要大写

定义控制器类
class IndexAction extends Action{
public function show(){
echo '这是新的 show 操作';
}
}
然后在浏览器里面输入
http://localhost/myApp/index.php/Index/show/


定义模型类:

class 表名Model extends Model{
[//手动定义字段[可选]
protected $fields = array(
'id',
'username',
'email',
'age',
'_pk'=>'id', //主键
'_autoInc'=>true //是否自增
)
]
}

记录的修改:

$User = D("User") // 实例化 User 对象
$User->find(1) // 查找 id 为 1 的记录
$User->name = 'ThinkPHP' // 把查找到的记录的名称字段修改为 ThinkPHP
$User->save() // 保存修改的数据
更新特定字段的值
$User->setField('name','TopThink','id=1')
同 样可以支持对字段的操作
$User->setField('score','(score+1)','id=1')


新建记录,方法1:
$User = new UserModel() //实例化 User 对象
$User->字 段名 = 字段值 //给字段赋值
$User->add() //添加记录
新建记录,方法2:
$data['字段名'] = 字段值; //给字段赋值
$User = D('User'); //实例化 User 对象
$User->add($data); //$insertId,Add 方法的返回值就是最新插入的主键值,可以直接获取。
新增多条记录:
$User = new UserModel()
$data[0]['name'] = 'ThinkPHP'
$data[0]['email'] = 'sjolzy@chen.com'
$data[1]['name'] = '流年'
$data[1]['email'] = 'chen@sjolzy.cn'
$User>addAll($data)


删除记录

$User->find(2)
$User->delete() // 删除查找到的记录
$User->delete('5,6') // 删除主键为 5、6 的数据
$User->deleteAll() // 删除查询出来的所有数据

记录查询

$User->getDbFields() //获取当前数据字段
$User->findAll(); //查找所有记录
$User->findAll('1,3,8') //查询主键为1,3,8的记录集
$User->count() // 获取记录数
$User->max('score') // 获取用户的最大积分
$User->min('score','score>0') // 获取积分大于 0 的用户的最小积分
$User->avg('字段名') // 获取所有记录的字段值的平均值
$User->sum('字段名 ') // 统计字段值
(以下方法的使用需继承高级模型类)
$User->getN(2,array('score>80')) // 返回符合条件的第 2 条记录
$User->getN(-2,array('score>80')) //还可以获取最后第二条记录
$User->first(array('score>80','score desc')) //如果要查询第一条记录,还可以使用
$User->last(array('score>80','score desc')) // 获取最后一条记录
$User->top(5,array('score desc')) // 获取积分最高的前 5 条记录
$User->getBy('name','liu21st') //跟据字段的字段值来查询记录

$Model = new Model() // 实例化一个 model 对象 没有对应任何数据表
$Model->query("select * from think_user where status=1")//直接使用原生的sql语句

$objrs = $Model->query("select * from think_user where status=1") //自定义查询
$Model->execute("update think_user set name='thinkPHP' where status=1") //用于更新和写入数据的 sql 操作,返回影响的记录数


$User->startTrans() // 启动事务
$User->commit() // 提交事务
$User->rollback() // 事务回滚

模板:

$this->assign('name',$value); //在 Action 类里面使用 assign 方法对模板变量赋值,无论何种变量类型都统一使用 assign 赋值

$this->display() // 输出模版文件

批量赋值,assign的单参数使用
$array['name'] = 'thinkphp'
$array['email'] = 'chen@sjolzy.cn'
$array['phone'] = '12335678'
$this->assign($array)


$this->display() // 调用 User 模块的 read 操作模版
$this->display('edit') // 调用 User 模块的 edit 操作模版
$this->display('Member:read') // 调用 Member 模块的 read 操作模版
$this->display('Xp@User:edit') // 调用 Xp 主题的 User 模块的 edit 操作模版
$this->display('../Member/read.html') // 直接指定模版文件的全名

模板标签:

{ } 或 {// 注释内容 } //模板注释
{$user['name']} //输出数组变量
{$user:name} //输出对象的属性

为了方便模板定义,无论输出的模板变量是数组还是对象,都可以用下列统一方式输出:
{$user.name}
如果是多维数组或者多 层对象属性的输出,请使用下面的定义方式:
{$user['sub']['name']}
{$user:sub:name}

在模板中使用函数:
格式:{$varname|function1|function2=arg1,arg2,### } 或者 {:function(参数1,参数2)}
说明:
{ 和 $ 符号之间不能有空格 ,后面参数的空格就没有问题
###表示模板变量本身的参数位置

系统变量
{$Think.server.script_name } //取得$_SERVER 变量
{$Think.session.session_id|md5 } // 获取$_SESSION 变量
{$Think.get.pageNumber } //获取$_GET 变量
{$Think.cookie.name } //获取$_COOKIE 变量
系统常量
{$Think.const.__FILE__ }
{$Think.const.MODULE_NAME }
特殊变量 ,由 ThinkPHP 系统定义的常量
{$Think.version } //版本
{$Think.now } //现在时间

快捷输出(3.0及以后版本已去掉)
{:function(…)} //执行方法并输出返回值
{~function} //执行方法不输出
{@var} //输出 Session 变量
{&var} //输出配置参数
{%var} //输出语言变量
{.var} //输出 GET 变量
{^var} //输出 POST 变量
{*var} //输出常量

包含外部文件
<include file="$tplName" /> // 用变量控制要导入的模版
<include file="/Apps/home/Tpl/simple/Public/header.html" /> // 使用一个完整的文件名包含
注意:不能变量与字符串混用,如:<include file="User/$tplName" /> //这样是错误的

分享到:
评论

相关推荐

    thinkphp学习笔记

    ### ThinkPHP 学习笔记详解 #### 入口文件配置 在ThinkPHP框架中,入口文件通常是项目启动的第一个脚本,负责初始化环境并加载核心框架文件。以下是对给定示例中的入口文件代码进行详细解释: ```php define('...

    ThinkPHP学习笔记(五)关联的SQL文件

    ThinkPHP学习笔记(五)关联的SQL文件

    thinkphp学习笔记入门到深入篇

    【ThinkPHP学习笔记入门到深入篇】 ThinkPHP是一款基于PHP的开源快速开发框架,它以其简洁的代码结构、高效的性能和强大的功能深受开发者喜爱。这篇笔记涵盖了从基础到深入的多个方面,旨在帮助初学者迅速掌握...

    ThinkPHP学习笔记(四)关联的SQL文件

    本人博客ThinkPHP学习笔记(四)所使用的数据库文件

    个人thinkphp学习笔记

    根据提供的信息,我们可以总结出以下关于ThinkPHP框架的学习知识点: ### 一、数据库配置 在ThinkPHP中,数据库配置通常放在`Common/Conf/config.php`文件内。具体配置如下: - `'DB_TYPE' =&gt; 'mysql'`:指定...

    thinkphp学习笔记参考.pdf

    《深入理解ThinkPHP框架》 ThinkPHP是一个强大的基于PHP的开源Web应用开发框架,它遵循简洁、灵活的设计原则,旨在提高开发效率,降低开发成本。本篇将从基础概念、核心文件、MVC模式、URL访问方式以及模型使用等...

    专题资料(2021-2022年)thinkphp学习笔记分析.doc

    专题资料

    ThinkPHP学习笔记(一)ThinkPHP部署

    【ThinkPHP学习笔记(一):ThinkPHP部署】 在学习ThinkPHP框架时,首先需要搭建一个本地开发环境,这里提到的是使用WAMP Server。WAMP是Windows、Apache、MySQL和PHP的组合,提供了在Windows环境下运行PHP应用的...

    thinkPHP学习笔记之安装配置篇

    在本篇学习笔记中,我们将详细探讨ThinkPHP的安装和配置方法,以及一个简单的实例。 首先,ThinkPHP的安装过程相对简单。在安装时,开发者需要在项目中包含ThinkPHP的核心文件。通常,这是通过在项目中引入ThinkPHP...

    thinkphp3.1.2学习笔记

    在深入探讨ThinkPHP3.1.2学习笔记之前,让我们先了解一下ThinkPHP框架。ThinkPHP是一个基于MVC(Model-View-Controller)模式的简洁、轻量级的PHP开发框架,它强调代码运行效率和开发速度,适用于中小型企业的Web...

    ThinkPHP自学笔记

    《ThinkPHP自学笔记》 ThinkPHP,作为国内广泛使用的开源PHP框架,...通过系统学习,你可以快速上手ThinkPHP,从而更高效地进行Web开发。在实践中不断探索,结合官方文档和社区资源,将使你的ThinkPHP技能更上一层楼。

    thinkphp学习笔记之多表查询

    在学习ThinkPHP框架时,对于多表查询的操作是数据库编程中的一项重要技能。多表查询允许我们从两个或多个相关的数据表中提取并组合数据,以满足复杂的数据处理需求。以下将详细介绍ThinkPHP中进行多表查询的几种方法...

    ThinkPHP开发笔记

    在开发基于ThinkPHP框架的应用程序时,需要注意一系列关键点,以确保代码的高效性和安全性。以下是一些关于ThinkPHP开发的重要...持续学习和实践ThinkPHP框架的文档和最佳实践,将有助于提升开发效率和应用的健壮性。

    自己学习thinkphp笔记心得注意的和常用的地方

    自己学习thinkphp笔记心得注意的和常用的地方,thinkphp 学习a标签url href src等路径,一些比较容易理解并且会忘记的注意点

    从ThinkPHP3.2.3过渡到ThinkPHP5.0学习笔记图文详解

    主要介绍了从ThinkPHP3.2.3过渡到ThinkPHP5.0学习笔记,结合图文形式详细分析了thinkPHP3.2.3框架开发过渡到thinkPHP5.0框架的区别与改进方法,需要的朋友可以参考下

Global site tag (gtag.js) - Google Analytics