thinkphp mysql语句

1、不定义方法,直接渲染模板。
对于没有任何实际逻辑的操作方法,我们只需要直接定义对应的模板文件就行了,比如表单页面,这个页面一般不会有变量向模板中输出,所以,我们没有必要再去写一个对应的空方法然后$this->display()了。

2、简介create方法。
假设我们实例化的模型为$model,那么ThinkPHP可以直接通过$model->add()的方式向数据库中添加数据,那么如果我们在$model->add()之前调用$model->create()方法,这样有什么意义呢?create()方法的意义只有一个“确保写入数据库的数据安全和有效”。
其中,数据的自动验证便是借助create方法来实现的。值得一提的是,用create方法实现自动验证,需要我们定义模型**Model.class.php,然后在实例化的时候使用D()方法进行实例化。

3、使用对象的方法插入数据。
可能你常常用下面的方式(数组方式)插入数据
$Form = D('Form');
$data['title'] = 'ThinkPHP';
$data['content'] = '表单内容';
$Form->add($data);
其实ThinkPHP还支持对象的方式直接向数据库插入数据,如下:
$Form = D('Form');
$Form->title = 'ThinkPHP';
$Form->content = '表单内容';
$Form->add();

4、不指定条件对数据更新。
$Form = M("Form"); // 要修改的数据对象属性赋值
$data['id'] = 5;
$data['title'] = 'ThinkPHP';
$data['content'] = 'ThinkPHP3.1版本发布';
$Form->save($data); // 根据条件保存修改的数据

save方法会自动识别数据对象中的主键字段,并作为更新条件。当然,你也可以显式的传入更新条件,也就是我们最常用的方法:
$Form = M("Form");
// 要修改的数据对象属性赋值
$data['title'] = 'ThinkPHP';
$data['content'] = 'ThinkPHP3.1版本发布';
$Form->where('id=5')->save($data); // 根据条件保存修改的数据
其实还有对象的方式,就像上面提到的,插入数据,用对象的方式一样:

$Form = M("Form");
// 要修改的数据对象属性赋值
$Form->title = 'ThinkPHP';
$Form->content = 'ThinkPHP3.1版本发布';
$Form->where('id=5')->save(); // 根据条件保存修改的数据
并且,可以将主键字段包含在要保存的数据里,这样就可以不需要写where了
$Form = M("Form");

// 要修改的数据对象属性赋值
$Form->id = 5;
$Form->title = 'ThinkPHP';
$Form->content = 'ThinkPHP3.1版本发布';
$Form->save(); // 根据数据对象中的主键保存修改的数据

5、单个字段值的修改。
 有些时候,我们只需要修改某个字段的值,就可以使用setField方法,而不需要每次都调用save方法。
$Form = M("Form"); // 更改title值
$Form->where('id=5')->setField('title','ThinkPHP');

6、强大的增减字段值运算。
ThinkPHP中,可以对某个字段的数据直接执行增减操作。
对于统计字段,系统还提供了更加方便的setInc和setDec方法。
$User = M("User"); // 实例化User对象
$User->where('id=5')->setInc('score',3); // 用户的积分加3
$User->where('id=5')->setInc('score'); // 用户的积分加1
$User->where('id=5')->setDec('score',5); // 用户的积分减5
$User->where('id=5')->setDec('score'); // 用户的积分减1

7、不使用where来执行删除。
$User->delete('1,2,5'); // 删除主键为1,2和5的用户数据。
这种用法可以用在类似于签到时候,用户积分自动增加的例子上。

$this->assign()方法之单参数的使用在ThinkPHP的手册中,有关于assign()方法的使用,这里对其作用不再叙述。而我们要讨论的是,assign方法如果只有一个参数的使用情况。
IndexAction.class.php1.<?php
class IndexAction extends Action {
     public function index(){
       $var_array = array("color" => "blue";
                    "size"  => "medium";
                    "shape" => "sphere");
       $this->assign($var_array);
       $this->display();
     }
}

?>
前台页面:
<html>
     {$color} //这里输出blue
</html>

由上面的例子可以看出,框架是将参数数组中的每一个键值对当成“参数”=>“值”的形式赋值到模板里了
所以,如果需要赋值到模板上的值很多的话,不妨用这种方式
注意:
由于这是隐式地赋值,要注意参数重名哦!特别是id、name这一类数据库常用的字段

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThinkPHP 中进行高级的 MySQL 操作,可以使用模型来实现。模型是一种对象关系映射(ORM)工具,它允许你通过 PHP 代码来操作数据库,而不需要编 SQL 语句。 以下是一些常见的 ThinkPHP 模型操作: 1. 查询数据 使用模型的 select() 方法可以查询数据库中的数据。例如: ``` $users = UserModel::select(); ``` 可以使用 where() 方法添加查询条件。例如: ``` $users = UserModel::where('age', '>', 18)->select(); ``` 可以使用 find() 方法查询单条数据。例如: ``` $user = UserModel::where('id', 1)->find(); ``` 2. 插入数据 使用模型的 save() 方法可以插入数据到数据库中。例如: ``` $user = new UserModel; $user->name = 'John'; $user->age = 20; $user->save(); ``` 3. 更新数据 使用模型的 save() 方法可以更新数据库中的数据。例如: ``` $user = UserModel::where('id', 1)->find(); $user->name = 'John Smith'; $user->save(); ``` 可以使用 update() 方法更新多条数据。例如: ``` UserModel::where('age', '>', 18)->update(['is_adult' => true]); ``` 4. 删除数据 使用模型的 delete() 方法可以删除数据库中的数据。例如: ``` $user = UserModel::where('id', 1)->find(); $user->delete(); ``` 可以使用 destroy() 方法删除多条数据。例如: ``` UserModel::where('age', '<', 18)->destroy(); ``` 以上是一些常见的 ThinkPHP 模型操作,你还可以使用其他高级操作,如聚合查询、关联查询等。具体可参考 ThinkPHP 的官方文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值