Rumah pembangunan bahagian belakang tutorial php 关于Thinkphp框架视图模型调用的一些有关问题总结

关于Thinkphp框架视图模型调用的一些有关问题总结

Jun 13, 2016 am 11:01 AM
gt this topic

关于Thinkphp框架视图模型调用的一些问题总结

对于tp框架中视图模型的调用在项目中比较常用,这次的毕业设计中对于碰到了一些问题写下总结:

?

一、自定义DAO的ORM的Model定义在视图调用时出现异常

?

当把Model定义成形如

class UserModel extends Model {	private $ormObj;		/**	 * 	 * 构造函数	 */	function __construct(){				$this->ormObj=M('User');			}}
Salin selepas log masuk

然后是视图模型的定义:

class MentionviewModel extends ViewModel {	    public $viewFields = array(       'Mention'=>array('id','tid','uid'),       'Topic'  =>  array('create_time','from'=>'topic_from','content','status','_on'=>'Mention.tid=Topic.id'),       'User'  =>  array('nickname','homepage','avatar','_on'=>'Topic.uid=User.id')    );    }
Salin selepas log masuk

而输出的SQL语句确是:

SELECT Mention.id AS id,Mention.uid AS uid,Mention.tid AS tid,Topic.create_time AS create_time,Topic.from AS topic_from,Topic.content AS content,User.avatar AS avatar,User.nickname AS nickname,User.homepage AS homepage FROM fl_mention Mention JOIN Topic ON Mention.tid=Topic.id JOIN User ON Topic.uid=User.id WHERE Topic.status=1 and Mention.uid=1 ORDER BY Mention.id desc LIMIT 0,20
Salin selepas log masuk

?对于要取别名的表名丢失了,这种DAO式的ORM调用时在视图模型中会出现找不到表名的情况。

?

在父类ViewModel中有这样一个函数,是提取表名的:

public function getTableName()    {        if(empty($this->trueTableName)) {            $tableName = '';            foreach ($this->viewFields as $key=>$view){                // 获取数据表名称                $class  =   $key.'Model';                $Model  =  class_exists($class)?new $class():M($key);                $tableName .= $Model->getTableName();                // 表别名定义                $tableName .= !empty($view['_as'])?' '.$view['_as']:' '.$key;                // 支持ON 条件定义                $tableName .= !empty($view['_on'])?' ON '.$view['_on']:'';                // 指定JOIN类型 例如 RIGHT INNER LEFT 下一个表有效                $type = !empty($view['_type'])?$view['_type']:'';                $tableName   .= ' '.strtoupper($type).' JOIN ';                $len  =  strlen($type.'_JOIN ');            }            $tableName = substr($tableName,0,-$len);            $this->trueTableName    =   $tableName;        }        return $this->trueTableName;    }
Salin selepas log masuk

这里函数看到会去调用该类的超类Model的 $Model->getTableName() 这个函数:

?

public function getTableName()    {        if(empty($this->trueTableName)) {            $tableName  = !empty($this->tablePrefix) ? $this->tablePrefix : '';            if(!empty($this->tableName)) {                $tableName .= $this->tableName;            }else{                $tableName .= parse_name($this->name);            }            $tableName .= !empty($this->tableSuffix) ? $this->tableSuffix : '';            if(!empty($this->dbName))                $tableName    =  $this->dbName.'.'.$tableName;            $this->trueTableName    =   strtolower($tableName);        }        return $this->trueTableName;    }
Salin selepas log masuk

这个函数中这个语句empty($this->trueTableName)便是提取表名的

下面给出解决方案一:

class UserModel extends Model {		protected $trueTableName = 'fl_user';  	private $ormObj;		/**	 * 	 * 构造函数	 */	function __construct(){				$this->ormObj=M('User');			}}
Salin selepas log masuk

?在该类中加入protected $trueTableName = 'fl_user'; 这个属性使触发getTablename函数时可以找到对应的表名;

解决方案二:

function __construct(){			parent::__construct();	$this->ormObj=M('User');		}
Salin selepas log masuk

?在子类中将覆盖掉的父类构造函数重新引入

?

?

?

?

二、自连接表的视图模型调用:

?

形如:

class TopicviewModel extends ViewModel {	    public $viewFields = array(       'topic'=>array('id'=>'root_id','content'=>'root_content'),       'Topic'  =>array('id'=>'topic_id','create_time','from'=>'topic_from','content','status','_on'=>'topic.id=topic.rootid')          );    }
Salin selepas log masuk

上面的语句执行的sql如下:

SELECT topic.id AS root_id,Topic.id AS topic_id FROM fl_topic topic JOIN fl_topic Topic ON topic.id=Topic.rootid
Salin selepas log masuk

这句sql语句的错误很明显:因为sql是不区分大小写的,所以会直接报??Not unique table/alias: 'Topic'的错误。

?

继续来看这个函数:

 public function getTableName()    {        if(empty($this->trueTableName)) {            $tableName = '';            foreach ($this->viewFields as $key=>$view){                // 获取数据表名称                $class  =   $key.'Model';                $Model  =  class_exists($class)?new $class():M($key);                $tableName .= $Model->getTableName();                // 表别名定义                $tableName .= !empty($view['_as'])?' '.$view['_as']:' '.$key;                // 支持ON 条件定义                $tableName .= !empty($view['_on'])?' ON '.$view['_on']:'';                // 指定JOIN类型 例如 RIGHT INNER LEFT 下一个表有效                $type = !empty($view['_type'])?$view['_type']:'';                $tableName   .= ' '.strtoupper($type).' JOIN ';                $len  =  strlen($type.'_JOIN ');            }            $tableName = substr($tableName,0,-$len);            $this->trueTableName    =   $tableName;        }        return $this->trueTableName;    }
Salin selepas log masuk

上面的函数对于前面的‘topic’索引只是做了工厂方式的模型生成。而其中的class_exists是不区分大小写的,而数组的索引是区分大小写的,我们可以利用这个特性,把同一个表的引用用仅大小写不同的索引表示

再在后面跟上_as属性即可:

?

下面代码:

public $viewFields = array(       'topic'=>array('id'=>'root_id','content'=>'root_content','_as'=>'root_topic'),       'Topic'  =>  array('id'=>'topic_id','create_time','from'=>'topic_from','content','status','_on'=>'root_topic.id=topic.rootid')    );
Salin selepas log masuk

?这样便可得到正确的sql语句了

SELECT root_topic.id AS root_id,Topic.id AS topic_id FROM fl_topic root_topic JOIN fl_topic Topic ON root_topic.id=topic.rootid
Salin selepas log masuk

?

tp的确是国内一款少有的成熟的框架~~但有些地方还是要用些另类的技巧来使用,自连接表的视图模型使用总觉得还是比较尴尬的,期待有更好的方式可以达到自连接的目的

?

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah perbezaan antara Huawei GT3 Pro dan GT4? Apakah perbezaan antara Huawei GT3 Pro dan GT4? Dec 29, 2023 pm 02:27 PM

Ramai pengguna akan memilih jenama Huawei apabila memilih jam tangan pintar Antaranya, Huawei GT3pro dan GT4 adalah pilihan yang sangat popular. Apakah perbezaan antara Huawei GT3pro dan GT4? 1. Rupa GT4: 46mm dan 41mm, bahan cermin kaca + badan keluli tahan karat + cangkang belakang gentian resolusi tinggi. GT3pro: 46.6mm dan 42.9mm, bahannya ialah kaca nilam + badan titanium/badan seramik + cangkerang belakang seramik 2. GT4 yang sihat: Menggunakan algoritma Huawei Truseen5.5+ terkini, hasilnya akan lebih tepat. GT3pro: Penambahan elektrokardiogram ECG dan saluran darah serta keselamatan

Betulkan: Alat snipping tidak berfungsi dalam Windows 11 Betulkan: Alat snipping tidak berfungsi dalam Windows 11 Aug 24, 2023 am 09:48 AM

Mengapa Alat Snipping Tidak Berfungsi pada Windows 11 Memahami punca masalah boleh membantu mencari penyelesaian yang betul. Berikut ialah sebab utama Alat Snipping mungkin tidak berfungsi dengan betul: Focus Assistant dihidupkan: Ini menghalang Snipping Tool daripada dibuka. Aplikasi rosak: Jika alat snipping ranap semasa pelancaran, ia mungkin rosak. Pemacu grafik lapuk: Pemacu yang tidak serasi mungkin mengganggu alat snipping. Gangguan daripada aplikasi lain: Aplikasi lain yang sedang berjalan mungkin bercanggah dengan Alat Snipping. Sijil telah tamat tempoh: Ralat semasa proses naik taraf boleh menyebabkan penyelesaian mudah ini sesuai untuk kebanyakan pengguna dan tidak memerlukan sebarang pengetahuan teknikal khusus. 1. Kemas kini apl Windows dan Microsoft Store

Cara Membetulkan Ralat Tidak Dapat Menyambung ke App Store pada iPhone Cara Membetulkan Ralat Tidak Dapat Menyambung ke App Store pada iPhone Jul 29, 2023 am 08:22 AM

Bahagian 1: Langkah Penyelesaian Masalah Awal Menyemak Status Sistem Apple: Sebelum menyelidiki penyelesaian yang rumit, mari kita mulakan dengan asas. Masalahnya mungkin tidak terletak pada peranti anda; Lawati halaman Status Sistem Apple untuk melihat sama ada AppStore berfungsi dengan betul. Jika terdapat masalah, anda hanya boleh menunggu Apple membetulkannya. Semak sambungan Internet anda: Pastikan anda mempunyai sambungan internet yang stabil kerana isu "Tidak dapat menyambung ke AppStore" kadangkala boleh dikaitkan dengan sambungan yang lemah. Cuba tukar antara Wi-Fi dan data mudah alih atau tetapkan semula tetapan rangkaian (Umum > Tetapkan Semula > Tetapkan Semula Tetapan Rangkaian > Tetapan). Kemas kini versi iOS anda:

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出php提交表单通过后,弹出的对话框怎样在当前页弹出而不是在空白页弹出?想实现这样的效果:而不是空白页弹出:------解决方案--------------------如果你的验证用PHP在后端,那么就用Ajax;仅供参考:HTML code

Bagaimana untuk mencipta topik dalam kafka Bagaimana untuk mencipta topik dalam kafka Jan 17, 2024 pm 04:56 PM

Langkah-langkah untuk kafka untuk mencipta topik: 1. Pasang dan konfigurasikan Kafka 2. Buat Topik 3. Sahkan penciptaan Topik 4. Konfigurasikan parameter Topik; Pengenalan terperinci: 1. Pasang dan konfigurasikan Kafka Mula-mula, pastikan Kafka telah dipasang dengan betul dan ia berjalan Mengikut keperluan dan persekitaran, konfigurasikan parameter Kafka, dsb.

Artikel untuk memahami panduan ini dan mengejar 70% orang hadapan Artikel untuk memahami panduan ini dan mengejar 70% orang hadapan Sep 06, 2022 pm 05:03 PM

Seorang rakan sekerja tersekat kerana pepijat yang ditunjukkan oleh masalah penunjuk Vue2 ini menyebabkan fungsi anak panah digunakan, mengakibatkan ketidakupayaan untuk mendapatkan prop yang sepadan. Dia tidak tahu apabila saya memperkenalkannya kepadanya, dan kemudian saya sengaja melihat kumpulan pertukaran bahagian hadapan Setakat ini, sekurang-kurangnya 70% pengaturcara bahagian hadapan masih tidak memahaminya anda pautan ini. Jika semuanya tidak jelas saya belum belajar bagaimana untuk melakukannya, sila berikan saya mulut yang besar.

Adakah watch4pro lebih baik atau gt? Adakah watch4pro lebih baik atau gt? Sep 26, 2023 pm 02:45 PM

Watch4pro dan gt masing-masing mempunyai ciri yang berbeza dan senario yang berkenaan Jika anda menumpukan pada fungsi yang komprehensif, prestasi tinggi dan penampilan yang bergaya, dan sanggup menanggung harga yang lebih tinggi, maka Watch 4 Pro mungkin lebih sesuai. Jika anda tidak mempunyai keperluan fungsi yang tinggi dan memberi lebih perhatian kepada hayat bateri dan harga yang berpatutan, maka siri GT mungkin lebih sesuai. Pilihan terakhir harus diputuskan berdasarkan keperluan peribadi, belanjawan dan keutamaan Adalah disyorkan untuk mempertimbangkan dengan teliti keperluan anda sendiri sebelum membeli dan merujuk kepada ulasan dan perbandingan pelbagai produk untuk membuat pilihan yang lebih termaklum.

Mari kita bincangkan mengapa Vue2 boleh mengakses atribut dalam pelbagai pilihan melalui ini Mari kita bincangkan mengapa Vue2 boleh mengakses atribut dalam pelbagai pilihan melalui ini Dec 08, 2022 pm 08:22 PM

Artikel ini akan membantu anda mentafsir kod sumber vue dan memperkenalkan sebab anda boleh menggunakan ini untuk mengakses sifat dalam pelbagai pilihan dalam Vue2. Saya harap ia akan membantu semua orang.

See all articles