博主信息
可乐随笔
博文
85
粉丝
0
评论
0
访问量
22127
积分:0
P豆:180

【Thinkphp】Thinkphp 常用数据库操作

2023年01月16日 11:46:27阅读数:120博客 / 可乐随笔/ PHP实战

Thinkphp 常用数据库操作

数据库操作官方文档:

https://www.kancloud.cn/manual/thinkphp6_0/1037533

1.查询数据

// ! 1.单条数据查询 : find()        // * 1.1 table方法必须指定完整的数据表名        // $users = Db::table('user')->find(4);        // $users = Db::table('user')->where('id', 1)->find();        // $users = Db::table('user')->where('name', '老李')->find();        // $users = Db::table('user')->where('id','>',3)->find();        //         // * 1.2 数组条件        // $users = Db::table('user')->where(        //     [        //         'name' => '老马',        //         'id' => 6        //     ]        // )->find();        // * 1.3 链式条件        // $users = Db::table('user')        // ->where('id','>',6)        // ->where('name','=', '老马')        // ->find();        // print_r($users);        // ? 更多查询表达式,参见官方手册:https://www.kancloud.cn/manual/thinkphp6_0/1037537        // ! 2.多条数据查询 select()        // $users = Db::table('user')->select();        // $users = Db::table('user')->where('id', '>', 3)->select();        //* 2.1 查询结果转数组        // $users = Db::table('user')->where('id', '>', 3)->select()->toArray();        // * 2.2 返回指定字段 field        // $users = Db::table('user')->field('id,name')->where('id', '>', 3)->select()->toArray();        // $users = Db::table('user')->field('id as uid,name')->where('id', '>', 3)->select()->toArray();        // $users = Db::table('user')->where('name', '老马')->select();        // * 2.3 查询某字段,返回一维数组        // $users = Db::table('user')->where('id','>',3)->column('name');        // * 2.4 查询某个值,返回字符串        // $users = Db::table('user')->where('id','=',3)->value('name');        // print_r($users);        // * 2.6 将数据库中某行复制到新列        // $users = Db::table('user')->select();        // foreach($users as $user)        // {        //     $rst = Db::table('user')->where('id', $user['id'])->update(['nickname' => $user['name']]);        // }        // print_r($rst);        // * 2.7 查询条件 '=' , '!=' , '<>' , '>' , '<' , 'like'        // $users = Db::table('user')->where('name','like','%张%')->select();        // $users = Db::table('user')->where('name','like','_张_')->select();        // print_r($users);        // * 2.8 区间查询 between && not between        // $users = Db::table('user')->where('id','between','8,12')->select();        // print_r($users);        // * 2.9 指定查询 in        // $users = Db::table('user')->where('id','in','5,8,9')->select();        // print_r($users);        // * 2.10 table() 包含表前缀,name()不包含表前缀,但需要在数据库配置中,配置前缀        // $adv = Db::table('adver')->order('sort desc,id desc')->select();        // print_r($adv);        // * 2.11 翻页\获取多少条,limit(),1个参数,表示获取多少条,2个参数表示,从第一个数字开始,获取多少条        // $shops = Db::table('shop')->limit(10,10)->order('id')->select()->toArray();        // ? limit方法需要计算页码起始数,不如page()方法方便        // $shops = Db::table('shop')->page(4,10)->order('id')->select()->toArray();        // $shops = Db::table('shop')->page(4)->limit(10)->order('id')->select()->toArray();        // print_r($shops);        // * 2.12 聚合查询        // $count = Db::table('user')->count();        // $count = Db::table('shop')->count('id');        // $count = Db::table('shop')->max('price');        // $count = Db::table('shop')->where('price','>',2000)->max('sales');        // * 查询已完成订单实际付款总金额        $count = Db::table('order')->where('status','=',9)->sum('sj_price');        print_r($count);

2.添加数据

// ! 3. 添加数据        // $data = [        //     'name' => '老张2',        //     'sex' => 1,        //     'age' => 30,        //     'phone' => '13902233333'        // ];        // 成功:返回 1 ,失败不返回        // $result = Db::table('user')->insert($data);        // if ($result) {        //     return '添加成功';        // } else {        //     return '添加失败';        // }        // 添加成功后,返回 user 主键 (这里返回:id)        // $id = Db::table('user')->insertGetId($data);        // if (empty($id)) {        //     return '添加失败';        // } else {        //     print_r($id);        // }

3.修改数据

// ! 4. 修改数据,限定条件        // $data = [        //     'name' => '小丽',        //     'sex' => 0,        //     'age' => 30,        //     'phone' => '13902233333'        // ];        // $update = Db::table('user')->where('id', '=', 1)->update($data);        // * 修改单独的值,用自增 inc +         // $update = Db::table('user')->where('id', 1)->inc('loginNum', 1)->update();

4.删除数据

// ! 5. 删除 Delete , 删除必须增加条件 , 不要用删除功能        // $result = Db::table('user')->where('id', '=', 2)->delete();        // if ($result) {        //     return '删除成功';        // } else {        //     return '删除失败';        // }        // * 软删除 useSoftDelete        // $result = Db::table('user')->where('id',5)->useSoftDelete('status',99)->delete();        // print_r($result);

5. 数据集操作

 // ! 6. 数据集操作        // * 删除数据集最后一条数据,返回被删除的数据        // $users = Db::table('user')->select();        // print_r($users->pop());        // * 指定字段排序        // $users = Db::table('user')->select();        // print_r($users);        // $usersAge = $users->order('age');        // print_r($usersAge);        // * 判断是否为空        // $news = Db::table('news')->select();        // if($news->isEmpty())        // {        //     return '数据集为空';        // } else {        //     print_r($news);        // }

6. 调试语句

// * getLastSql() : 打印原生SQL,执行SQL后再打印        // $user = Db::table('order')        //     ->where('status', '>=',2)        //     ->sum('sj_price');        // print_r($user);        // echo Db::getLastSql();        // * fetchSql() : 执行过程中打印原生SQL        // $user = Db::table('order')        //     ->where('status', '>=',2)        //     ->fetchSql()        //     ->sum('sj_price');        // print_r($user);

7. 多数据库操作

// * connect() : 方法,切换多数据库        // $order = Db::table('order')->select();        // $order = Db::connect('tpshop')->table('order')->select();        // print_r($order);

8. 数据库事务

// * startTrans 事务开启        // ? 事务要求 数据库引擎是: InnoDB, 不支持MyISAM        Db::startTrans();        $data = [            'ooid' => '1234567890',            'uid' => 1,            'price' => 111,            'phone' => '18809511111',            'name' => '欧阳克',            'sj_price' => 111,        ];        $oid = Db::table('order')->insertGetID($data);        // * 事务提交: commit ; 事务回滚: rollback        if (empty($oid)) {            Db::rollback();        }        // 订单联动提交,失败进行事物回滚        $details = Db::table('order_details')->insert([            'oid' => $oid,            'shop_id' => 1,            'price' => 111        ]);        $details = 0;        if (empty($details)) {            Db::rollback();        }        Db::commit();

版权申明:本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!

全部评论

文明上网理性发言,请遵守新闻评论服务协议

条评论
  • ​下面由thinkphp教程栏目给大家介绍ThinkPHP之连接 ,希望对需要的朋友有所帮助!
    下面由thinkphp​教程栏目给大家介绍ThinkPHP 之增删改查,希望对需要的朋友有所帮助!
    下面由thinkphp教程栏目给大家介绍ThinkPHP之存储过程、集、分布式,希望对需要的朋友有所帮助!
    下面由thinkphp​教程栏目给大家介绍ThinkPHP之查询方法、查询语法、链式,希望对需要的朋友有所帮助!
    ​下面由thinkphp教程栏目给大家介绍ThinkPHP之查询事件、事务、监听SQL,希望对需要的朋友有所帮助!
    ​下面由thinkphp教程栏目给大家介绍ThinkPHP之视图查询、子查询、原生查询,希望对需要的朋友有所帮助!
    下面由thinkphp教程栏目给大家介绍ThinkPHP之聚合查询、时间查询、高级查询,希望对需要的朋友有所帮助!
    一个标准的网站一定离不开,在本套课程中我和你一起来揭开ThinkPHP5 的神秘面纱,和你一起愉快的使 ThinkPHP5 ,让变的更愉悦。
    下面由thinkphp框架教程栏目给大家介绍thinkPHP使migrate实现迁移的方法,希望对需要的朋友有所帮助!
    于实现各种的软件是:管理系统;管理系统能直接中的
    access教程:本文为大家介绍了利ADO技术access的方法,具有一定的参考价值,希望可以帮助到大家。
    navicat教程:本文为大家分享了使navicat克隆,具有一定的参考价值,希望能对大家有所帮助。
    Mysql设置户指定ip地址的方法:使grant函,语法为【grant priv_type on mysql.user to 'user'@'host' identified by 'password
    ,本文继续给大家介绍如何PHP进行类有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
    本篇文章给大家带来了关于Python的相关知识,其中主要介绍了使libpcap进行抓包及处理的方法,包括了安装libpcap、使libpcap等等内容,下面一起来看一下,希望对大家有帮助