ThinkPHP 关联模型中查询某条记录的父级(非查询子级)

数据表

id      cat_name      cat_pid

76     手机、数码     0

84     手机配件        76

86     蓝牙耳机        84

从属关系 : 蓝牙耳机  =>(上一级)  手机配件   =>(上一级)  手机、数码(顶级了)

关联模型

namespace Admin\Model;
use Think\Model\RelationModel;
class CategoryModel extends RelationModel
{
	protected $_link = array(
          ‘Category‘ => array(     //表名
              ‘mapping_type‘=>self::BELONGS_TO,   //关键.这个是查询父级的  而HAS_MANY则是查询子级的
              ‘mapping_name‘=>‘_parent‘, //自定义
              ‘mapping_order‘=>‘cat_sort‘,
              ‘parent_key‘=>‘cat_pid‘,//关键.父级关联的字段名 
          ),
	);
}

控制器中的代码:
public function search()
{    $category = D(‘Category‘);  //要用D方法.才能使用关联模型
  $id = 86;   //这时候86这个id是数据表中最底层的一级.
  $this->id = $category->where(‘id=‘.$id)->order(‘cat_sort‘)->relation(true)->select();   //这时候查询出来的是86的上一级.即id=84,手机配件
  $lastPid = $category->relationGet(true);   //如果希望在完成的查询基础上,在进行关联查询.则使用relationGet()方法  //dump($lastPid);  //这时候的$lastPid就是最顶层的数据(id=76,手机,数码).(前提是数据表为三层结构.如果是两层结构,则$this->id就已经到顶层了,就不需要在使用relationGET()方法)   //假如再来一次,就能查询到更高的父级,前提是数据表为四层结构,以此类推  //$lastLastPid = $category->relationGet(true);   }

时间: 2024-08-14 18:01:33

ThinkPHP 关联模型中查询某条记录的父级(非查询子级)的相关文章

通过 JDBC 向指定的数据表中插入一条记录,查询记录

//通过 JDBC 向指定的数据表中插入一条记录 /*  * 1.Statement: 用于执行SQl语句的对象  *  通过Connection 的createStatement()方法来获取  *  通过executeUptate(sql) 可执行sql语句  *  传入的sql 可以是 insert , update, delete 但不能是select  * 2.Connection 和 Statement 需要关闭  *  需要在finally中关闭  * 3.关闭的顺序:先关闭后获取

Laravel关联模型中has和with区别

本篇文章给大家带来的内容是关于Laravel关联模型中has和with区别(详细介绍),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 首先看代码: 1 2 3 4 5 6 $userCoupons = UserCoupons::with(['coupon' => function($query) use($groupId){     return $query->select('id', 'group_id', 'cover', 'group_number', 'group_

thinkphp关联模型的用法

HAS_ONE(值得注意的是,这是主动关联,外键必须是被关联的表): 1 <?php 2 namespace Home\Model; 3 use Think\Model\RelationModel; 4 class TagModel extends RelationModel{ 5 protected $_link =array( 6 'artag'=>array(//关联的数据表 7 'mapping_type'=>self::HAS_ONE,//一对一 8 'class_name'

ThinkPHP 关联模型(二十)

原文:ThinkPHP 关联模型(二十) ThinkPHP关联模型 两表关联查询:Message 和  user  关联条件uid(参考手册:模型->关联模型) 步骤: 一:创建Message表自定义的Mode  --->Home\Lib\Model\MessageModel.class.php <?php class MessageModel extends RelationModel{ //这是自动填充 protected $_auto=array( array('time','ti

oracle随机抽取表中的n条记录

采样表扫描(sample table scan):扫描返回表中随机采样数据,这种访问方式需要在FROM语句中包含SAMPLE选项或者SAMPLE BLOCK选项. 注:从Oracle8i开始Oracle提供采样表扫描特性 2.使用sample获得随机结果集 2.1.语法: SAMPLE [ BLOCK ](sample_percent)[ SEED (seed_value) ] SAMPLE选项:表示按行采样来执行一个全表扫描,Oracle从表中读取特定百分比的记录,并判断是否满足WHERE子句

mysql 查询一条记录的下一条和上一条记录

如果ID是主键或者有索引,可以直接查找: 方法一: 查询上一条记录的SQL语句(如果有其他的查询条件记得加上other_conditions以免出现不必要的错误): select * from table_a where id = (select id from table_a where id < {$id} [and other_conditions] order by id desc limit 1) [and other_conditions]; 查询下一条记录的SQL语句(如果有其他的

php实现只保留mysql中最新1000条记录

这篇文章主要介绍了php实现只保留mysql中最新1000条记录的方法和相关示例及数据库结构,十分的全面,有需要的小伙伴可以参考下. ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 <?php mysql_connect("localhost","root","root"); mysql_select_db("test"); //保留最新的1000条记录 $

mySQL中插入多条记录

用一条INSERT向SQL中插入多条记录 2008-12-22 10:07:01|  分类: 记事本_编程技术|举报|字号 订阅 Sql 语法: 插入多行记录 Insert Into TableName1 ( column1 ,column2 ) Select column1,column2 From TableName2 Insert Into TableName ( column1,column2 ) Values ( value1,value2 ) , ( value3,value4 )

裴东辉-oracle查询一条记录,使用rownum。

oracle查询一条记录,使用rownum   select * from t_wry_jbxx   where  wryjc='PDH' and rownum<=1   order by wrybh DESC; 裴东辉-oracle查询一条记录,使用rownum.