thinkphp/vendor/topthink/think-orm
IQ 779e8b1894 tp6 2019-07-09 17:21:39 +08:00
..
src tp6 2019-07-09 17:21:39 +08:00
.gitignore tp6 2019-07-09 17:21:39 +08:00
LICENSE tp6 2019-07-09 17:21:39 +08:00
README.md tp6 2019-07-09 17:21:39 +08:00
composer.json tp6 2019-07-09 17:21:39 +08:00

README.md

think-orm

ThinkPHP6内置ORM基于PHP7.1+ 的ORM实现主要特性

  • 支持Mysql、Pgsql、Sqlite、SqlServer、Oracle和Mongodb
  • 支持Db类和查询构造器
  • 支持事务
  • 支持模型和关联
  • 事件支持依赖注入
  • 支持使用Db门面对象
  • 支持查询缓存

安装

composer require topthink/think-orm

使用

Db类

use think\facade\Db;
// 数据库配置信息设置(全局有效)
Db::init([
    // 默认数据连接标识
    'default'     => 'mysql',
    // 数据库连接信息
    'connections' => [
        'mysql' => [
            // 数据库类型
            'type'     => 'mysql',
            // 主机地址
            'hostname' => '127.0.0.1',
            // 用户名
            'username' => 'root',
            // 数据库名
            'database' => 'demo',
            // 数据库编码默认采用utf8
            'charset'  => 'utf8',
            // 数据库表前缀
            'prefix'   => 'think_',
            // 数据库调试模式
            'debug'    => true,
        ],
        'mongo' => [
            // 数据库类型
            'type'          => 'mongo',
            // 服务器地址
            'hostname'      => '127.0.0.1',
            // 数据库名
            'database'      => 'demo',
            // 用户名
            'username'      => '',
            // 密码
            'password'      => '',
            // 主键转换为Id
            'pk_convert_id' => true,
            // 数据库调试模式
            'debug'         => true,
            // 端口
            'hostport'      => '27017',
        ],
    ],
]);
// 进行CURD操作
Db::table('user')
	->data(['name'=>'thinkphp','email'=>'thinkphp@qq.com'])
	->insert();	
Db::table('user')->find();
Db::table('user')
	->where('id','>',10)
	->order('id','desc')
	->limit(10)
	->select();
Db::table('user')
	->where('id',10)
	->update(['name'=>'test']);	
Db::table('user')
	->where('id',10)
	->delete();
// 获取数据库SQL日志记录
Db::getSqlLog();    

其它操作参考TP6.0的完全开发手册数据库章节

模型:

namespace app\index\model;

use think\Model;

class User extends Model
{
}

代码调用:

use app\index\model\User;

$user = User::find(1);
$user->name = 'thinkphp';
$user->save();

Db类和模型对比使用

创建Create

  • Db用法

    Db::table('user')
        ->insert([
            'name'  => 'thinkphp',
            'email' => 'thinkphp@qq.com',
        ]);
    
  • 模型用法

    $user        = new User;
    $user->name  = 'thinkphp';
    $user->email = 'thinkphp@qq.com';
    $user->save();
    
  • 或者批量设置

    $user = new User;
    $user->save([
        'name'  => 'thinkphp',
        'email' => 'thinkphp@qq.com',
    ]);
    

读取Read

  • Db用法

    $user = Db::table('user')
        ->where('id', 1)
        ->find();
    //  或者
    $user = Db::table('user')
        ->find(1);
    echo $user['id'];
    echo $user['name'];
    
  • 模型用法

    $user = User::find(1);
    echo $user->id;
    echo $user->name;
    
  • 模型实现读取多个记录

    // 查询用户数据集
    $users = User::where('id', '>', 1)
        ->limit(5)
        ->select();
    
    // 遍历读取用户数据
    foreach ($users as $user) {
        echo $user->id;
        echo $user->name;
    }
    

更新Update

  • Db用法

    Db::table('user')
        ->where('id', 1)
        ->update([
            'name'  => 'topthink',
            'email' => 'topthink@qq.com',
        ]);
    
  • 模型用法

    $user        = User::find(1);
    $user->name  = 'topthink';
    $user->email = 'topthink@qq.com';
    $user->save();
    
  • 或者使用

    $user = User::find(1);
    $user->save([
        'name'  => 'topthink',
        'email' => 'topthink@qq.com',
    ]);
    
  • 静态调用

    User::update([
        'name'  => 'topthink',
        'email' => 'topthink@qq.com',
    ], ['id' => 1]);
    

删除Delete

  • Db用法

    Db::table('user')->delete(1);
    
  • 模型用法

    $user = User::find(1);
    $user->delete();
    
  • 或者静态实现

    User::destroy(1);
    
  • destroy方法支持删除指定主键或者查询条件的数据

    // 根据主键删除多个数据
    User::destroy([1, 2, 3]);
    // 指定条件删除数据
    User::destroy([
        'status' => 0,
    ]);
    // 使用闭包条件
    User::destroy(function ($query) {
        $query->where('id', '>', 0)
            ->where('status', 0);
    });
    

更多模型用法可以参考6.0完全开发手册的模型章节