美文网首页
thinkPHP中对数据库操作的几种简单方法

thinkPHP中对数据库操作的几种简单方法

作者: 夏天与你䒑江河不渡 | 来源:发表于2017-12-13 21:25 被阅读0次

访问方式http://localhost/tp5/public/index.php/index/index/db

注:find()和select()的区别就是,find()只会显示出第一条数据的值

原生查询

<?php
namespace app\index\controller;
use think\Request;
use think\Db;

class Index
{
    public function index()
    {
        //return '';
    }
    public function db() {
      //插入数据,返回的是影响的行数
      //$result = Db::execute('insert into think_data (name, status) values ("周杰伦", 1)');
      //查询数据,返回的是查询出的数组
      $result = Db::query('select * from think_data');
      dump($result);
    }
}

构造器查询

public function db() {
      //插入记录
      //$result = Db::table('think_data')->insert(['name' => '张天爱', 'status' => 1]);

      //更新数据
      //$result = Db::table('think_data')->where('id', 1)->update(['name' => '刘德华', 'status' => 0]);

      //查询所有、部分
      //$result = Db::table('think_data')->select();
      $result = Db::table('think_data')->where('id', 2)->select();
      dump($result);
    }

还可以使用name方法,此时不需要使用前缀码,即Db::name('data'),其他不需要改动,效果是一样的。
使用助手函数,创建一个$db对象,可以进一步简化构造器查询的代码,但是使用助手函数,会大幅度增加内存的占用(每次使用,都会新生成一个$db对象),所以,我们应该尽量少使用助手函数。

//使用助手函数调用
      $db = db('data');
      $result = $db->insert(['name' => '黄渤', 'status' => 1]);
      dump($result);

使用链式操作来实现对数据库的复杂操作

public function db() {
      //一个有限制的查询
      $list = Db::name('data')->where('status', 1)->field('id, ', 'name')->order('id', 'desc')->limit(2)->select();
      dump($list);
    }

通过定义模型来操作数据库

通过定义一个新的模型,在controller(控制器目录)的同级目录下定义一个Model文件夹,定义一个User.php文件。
然后就可以在控制器目录下新建相关的触发器了。

<?php
  namespace app\index\controller;
  use app\index\model\User as UserModel; //当模型名称与触发器名称相同时,需要改名称

  /**
   *定义触发器来使用模型
   */
  class User
  {
    public function add() {
      $user['name'] = '雾里看花';
      $user['email'] = 'kanhua@qq.com';
      $user['birthday'] = strtotime('1991-6-12');
      if($result = UserModel::create($user)) {
        return '用户新增成功';
      } else {
        return '用户新增失败';
      }
    }
  }

使用模型实现批量操作

public function addList() {
      $user = new UserModel();
      $list = [
        ['name' => '镜花水月', 'email' => 'jinghua@qq.com', 'birthday' => strtotime('1972-12-11')],
        ['name' => '水月洞天', 'email' => 'shuiyue@qq.com', 'birthday' => strtotime('1972-1-23')]
      ];

      if($user->saveAll($list)) {
        return '批量插入成功';
      } else {
        return '批量插入失败';
      }
    }

相关文章

网友评论

      本文标题:thinkPHP中对数据库操作的几种简单方法

      本文链接:https://www.haomeiwen.com/subject/anyoixtx.html