1、原生sql

$options=Db::table('__MALL_POST__')
->alias('m')
->join('__MALL_CATEGORY_VALUE__ v','m.id = v.itemid')
->join('__MALL_CATEGORY_OPTION__ o','v.oid = o.oid')
->where('m.id',$articleId)
->select();

参见 :https://www.kancloud.cn/manual/thinkphp5/118083

2、输出刚执行的sql语句

(1)原生sql执行后

$options=Db::table('__MALL_POST__')
->alias('m')
->join('__MALL_CATEGORY_VALUE__ v','m.id = v.itemid')
->join('__MALL_CATEGORY_OPTION__ o','v.oid = o.oid')
->where('m.id',$articleId)
->select();

echo Db::table('__MALL_POST__')->getLastSql();    //测试thimkcmf环境,需要先执行上述sql语句以后才能 getLastSql();  直接Db::table('__MALL_POST__')->getLastSql(); 返回的是上一次执行的sql语句 不是本次操作的。

(2)有model

$model= new Model();

$result=$model->where($where)->select();

echo $model->getLastSql();

3、多对多关联

目的:在文章表输出所属分类的自定义参数及参数的值,mall_category_option 表存储了分类的自定义属性主键oid, mall_category_value里存放了文章设置的属相的值(属性id:oid,文章id:itemid)

model中:

/**
* 关联分类属性和属相值表
*/
public function options(){
      //当前模型通过中间表mall_category_value 与 MallCategoryOptionModel关联
      //第三个参数应该是中间表的字段名,MallCategoryOptionModel的外键
      //第四个参数应该是中间表的字段名,当前模型(mall_post表)的外键
      //这种关联有什么意义????
     return $this->belongsToMany('MallCategoryOptionModel', 'mall_category_value', 'oid', 'itemid');
}

Controller:

$article=$model->where($where)->find();    //根据id读取文章

$options=$article['options'];//有这句的时候才关联,关联结果不能读取中间表

foreach($options as $key=>$v){ //返回的是wb_mall_category_option表里通过中间表关联的数据,无法获取中间表数据,如果需要的是中间表数据需要用其他方法
     echo $v['oid'].$v['value']."<BR>";
}

显然belongsToMany无法实现目的。

参考:https://www.kancloud.cn/manual/thinkphp5/142359,我这里无法使用 ->pivot 获取中间表数据,可能是版本原因。

最后用table实现

$options=Db::table('__MALL_CATEGORY_VALUE__')
->alias('v')
->join('__MALL_CATEGORY_OPTION__ o','v.oid = o.oid')
->where('v.itemid',$articleId)
->field('v.value vvalue,name')
->select();

4、添加与更新

1、有model

(1)取出数据并更新

$user = User::get(1);
$user->name     = 'thinkphp';
$user->email    = 'thinkphp@qq.com';
$user->save();

(2)直接更新

$cartModel->save($post,['id' => 1]); //['id' => 1,.....] 是更新条件

$cartModel->allowField(true)->save($_POST,['id' => 1]); //过滤post数组中的非数据表字段数据
$user->allowField(['name','email'])->save($_POST, ['id' => 1]); //指定字段

(2)通过数据库类更新数据

$user->where('id', 1)->update($post);
$user->update(['id' => 1, 'name' => 'thinkphp']);

  save是model方法,update是数据库类的方法,使用方法不同。

2、原生sql

$config = Db::getConfig();
$sql="REPLACE INTO ".$config['prefix']."mall_comment (itemid,mallid,buyer,seller) VALUES ('$oid','$itemid','$userid','$t[user_id]')" ;
Db::execute($sql);  // 返回影响行数  
DB::getLastInsID();//返回主键

具体参见:thinkphp5数据库操作方法小结:http://www.cnblogs.com/djiz/p/8249956.html

经测试目前使用版本

Db::execute 并不支持多个参数
仅支持,Db::execute($sql,[]) 数组是绑定参数 

支持
Db::query('select * from think_user where id=?',[8]); Db::execute('insert into think_user (id, name) values (?, ?)',[8,'thinkphp']); 

也支持命名占位符绑定,例如:

Db::query('select * from think_user where id=:id',['id'=>8]); Db::execute('insert into think_user (id, name) values (:id, :name)',['id'=>8,'name'=>'thinkphp']);

要想插入后返回主键 需要使用 $payid=DB::getLastInsID();

3、新增,在同一实例连续多次新增

$model->data($post)->save();   //用这个插入比较保险

$model->data($post)->isUpdate(false)->save();   //多次插入用这个

原因如下:

for (i=0;i<3;i++){  //模拟一下新增,实际应用中不可能这么循环

$model->save($post);  //  第一次 生成的sql 是 insert   ,后边生成的sql是update,应为第一次插入后 有了主键 $model->id;

}

查看https://www.kancloud.cn/manual/thinkphp5/135188   给出方案

注意不要在同一个实例里面多次新增数据,如果确实需要多次新增,那么可以用下面的方式:$user           = new User;
$user->name     = 'thinkphp';
$user->email    = 'thinkphp@qq.com';
$user->save();
$user->name     = 'onethink';
$user->email    = 'onethink@qq.com';
// 第二次开始必须使用下面的方式新增
$user->isUpdate(false)->save()

View Code

于是 改成如下

for (i=0;i<3;i++){  //模拟一下新增,实际应用中不可能这么循环

$model->isUpdate(false)->save($post);  //  这次生成的三个sql都是insert,但是从第二个开始 insert了主键 (报错),还是因为第一次插入就有了主键$model->id;

}

百度后发现 http://www.thinkphp.cn/topic/43590.html   说不能把$post放到save方法里

于是改成

$model->data($post)->isUpdate(false)->save();

解决。

看来$model->data($post)->save() 和 直接$model->save($post) 是不一样的,用 $model->data($post)->save() 比较保险

4、where 组合条件

$model->where("CONCAT(path,'-') like '%-".$vo['id']."-%'")  或者使用闭包

$queryFun = function($query)use($catid){
   if($catid){
      $query->where('path','like','%-'.$catid.'-%')->whereor('catid',$catid);
   }
};

$model->where($queryFun)->select();

转载于:https://www.cnblogs.com/djiz/p/8157301.html

thinkphp 5数据库操作相关推荐

  1. thinkphp的数据库操作(上)

    如果想了解更多相关知识,可以前往我的个人博客看看:eyes++的个人空间 一:连接数据库与模型初探 ThinkPHP 采用内置抽象层将不同的数据库操作进行封装处理,数据抽象层基于 PDO 模式,无须针 ...

  2. php读取excel中数据库,ThinkPHP 框架实现的读取excel导入数据库操作示例

    本文实例讲述了ThinkPHP 框架实现的读取excel导入数据库操作.分享给大家供大家参考,具体如下: 入口文件中: require_once VENDOR_PATH.'PHPExcel/PHPEx ...

  3. ThinkPHP 数据库操作(一) : 连接数据库

    ThinkPHP内置了抽象数据库访问层,把不同的数据库操作封装起来,我们只需要使用公共的Db类进行操 作,而无需针对不同的数据库写不同的代码和底层实现,Db类会自动调用相应的数据库驱动来处理.采用 P ...

  4. thinkphp mysql操作数据库_thinkPHP数据库操作

    thinkPHP如果要对数据库操作,一般来说首先要做的是在配置文件中链接数据库,然后用M方法实例化一张表,然后就是对表的操作了 可以开启调试功能查看程序执行的sql语句: 1.开启调试功能(默认是已经 ...

  5. ThinkPHP(7)——数据库操作

    连接数据库 实例化模型 实例化基础模型 实例化自定义模型 实例化空模型 增删改查 add select update delete order排序 field字段选择 limit page分页 gro ...

  6. ThinkPHP 数据库操作之数据表模型和基础模型 ( Model )

    一.定义数据表模型 1.模型映射 要测试数据库是否正常连接,最直接的办法就是在当前控制器中实例化数据表,然后使用 dump 函数输出,查看数据库的链接状态.代码: public function te ...

  7. 开源作品ThinkJDBC—一行代码搞定数据库操作

    1 简介 ThinkJD,又名ThinkJDBC,一个简洁而强大的开源JDBC操作库.你可以使用Java像ThinkPHP框架的M方法一样,一行代码搞定数据库操作.ThinkJD会自动管理数据库连接, ...

  8. ThinkPHP6项目基操(20.实战部分 数据库操作返回值总结)

    数据库操作返回值总结 0. 前言 1. Db类操作数据库 1.1 新增 1.2 更新 1.3 删除 1.3.1 单条删除 1.3.2 批量删除 1.4 查询 1.4.1 单笔记录 1.4.2 多笔记录 ...

  9. thinkjdbc 关闭_ThinkJD: ThinkJD,又名ThinkJDBC,一个强大的开源JDBC/ORM操作库,让你尽可能简洁地用一行代码搞定数据库操作。...

    1 简介 ThinkJD,又名ThinkJDBC,一个简洁而强大的开源JDBC操作库.你可以使用Java像ThinkPHP框架的M方法一样,一行代码搞定数据库操作.ThinkJD会自动管理数据库连接, ...

最新文章

  1. 秋色园QBlog技术原理解析:性能优化篇:用户和文章计数器方案(十七)
  2. 数据中心的清洁与扫除
  3. self-attention竟然没用?
  4. Pod详解-生命周期-容器探测
  5. 数据库问题解决后,应用面对的挑战
  6. 5g消息服务器,《5G消息白皮书》内容解读:5G消息是什么服务?
  7. conda虚拟环境中安装ipython
  8. 【转】Mongodb 学习笔记
  9. 测试Markdown
  10. 1 MLP-Mixer: An all-MLP Architecture for Vision
  11. post发送请求参数注意的问题
  12. RN与原生交互(一)——基本页面跳转
  13. 小白入门视频处理笔记:1. *.avi文件读入matlab后的数据结构
  14. NailTech 公司网站制作思路
  15. 白话空间统计三十:地统计学(1)起源
  16. 银河麒麟服务器操作系统常用问题及解决方案
  17. vue在调用摄像头扫码(vue-qrcode-reader)
  18. 【学术相关】人工智能300年!LSTM之父万字长文:详解现代AI和深度学习发展史...
  19. 网易教育论坛:“状元”在美读大学:中国孩子都被教傻了
  20. 最常见的20道jQuery经典面试题

热门文章

  1. javascript实例_网页空降与抖动
  2. 常见的6种JavaScript设计模式
  3. springboot工程打包时将application.properties放在jar包外
  4. css --- 使用scss生成常用的基本css样式
  5. javascript --- vue中简单的模板渲染
  6. react --- 按需加载组件
  7. Hadoop源码解析之: TextInputFormat如何处理跨split的行
  8. 二、ceph编译源码、单机搭建调试环境
  9. JavaFX 的 UI 控件集 ControlsFX
  10. 读取exchange邮件的未读数(转载)