Rumah php教程 php手册 关于ThinkPHP关联模型和视图模型的一些心得

关于ThinkPHP关联模型和视图模型的一些心得

Jun 07, 2016 am 11:40 AM

视图模型更加类似一张表虚拟的表,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。对其中所引用的基础表来说,视图的作用类似于筛选,这是ThinkPHP手册上的说法
视图模型更加类似一张表虚拟的表,视图包含一系列带有名称的列和行数据。但是,视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并且在引用视图时动态生成。对其中所引用的基础表来说,视图的作用类似于筛选,这是ThinkPHP手册上的说法
其实说白了,视图模型就是mysql多表查询而已,视图模型不支持多表更新,删除

而关联模型是多个表查询以后的结果组合,会多次查询mysql,(在执行完主表查询以后,会有个_after_select)之类的操作,然后组合结果集。在一些情况下,关联模型的查询还是比较不错的。
以下是个人使用ThinkPHP的关联模型和视图模型的一些心得和比较
一:性能方面
视图模型,说白了就是关联查询,一次查询多表
关联模型,每次查询一张表,多次查询,然后组合结果集(插入,更新,删除也是一样的。)
个人觉得视图模型性能会好一些(不一定全部都是,没有具体测试过)
二:查询
如果是查询的话,强烈建议使用视图模型来做,写法简单,容易理解和更改,而关联模型的定义方式太多,而且结果集的处理,调试,都不如视图模型要方便。
三:插入,更新,删除
视图模型不支持,关联模型支持,但是在插入,更新的时候,不能使用Model的create方法,还有自动完成,自动更新都失效了,我自己重写了一个create,给大家一些提示,可以自己按照需要更改。**<br>      * 重载create方法,不过滤字段,并且生成需要数据<br>      */<br>     function create($data = '', $type = '') {<br>         // 如果没有传值默认取POST数据<br>         if (empty($data)) {<br>             $data = $_POST;<br>         } elseif (is_object($data)) {<br>             $data = get_object_vars($data);<br>         }<br>         // 验证数据<br>         if (empty($data) || !is_array($data)) {<br>             $this->error = L('_DATA_TYPE_INVALID_');<br>             return false;<br>         }<br>         // 状态<br>         $type = $type ? $type : (!empty($data[$this->getPk() ]) ? self::MODEL_UPDATE : self::MODEL_INSERT);<br>         // 数据自动验证<br>         if (!$this->autoValidation($data, $type)) return false;<br>         // 表单令牌验证<br>         if (!$this->autoCheckToken($data)) {<br>             $this->error = L('_TOKEN_ERROR_');<br>             return false;<br>         }<br>         // 验证完成生成数据对象<br>         if ($this->autoCheckFields) { // 开启字段检测 则过滤非法字段数据<br>             $fields = $this->getDbFields();<br>             foreach ($data as $key => $val) {<br>                 if (MAGIC_QUOTES_GPC && is_string($val)) {<br>                     $data[$key] = stripslashes($val);<br>                 }<br>             }<br>         }<br>         // 创建完成对数据进行自动处理<br>         $data=$this->autoOperation($data, $type);<br>         $data=$this->createData($data);<br>         // 返回创建的数据以供其他调用<br>         return $data;<br>     }<br>  <br>     /**<br>      * 自动表单处理<br>      * @access public<br>      * @param array $data 创建数据<br>      * @param string $type 创建类型<br>      * @return mixed<br>      */<br>     private function autoOperation($data, $type) {<br>         if (!empty($this->options['auto'])) {<br>             $_auto = $this->options['auto'];<br>             unset($this->options['auto']);<br>         } elseif (!empty($this->_auto)) {<br>             $_auto = $this->_auto;<br>         }<br>         // 自动填充<br>         if (isset($_auto)) {<br>             foreach ($_auto as $auto) {<br>                 // 填充因子定义格式<br>                 // array('field','填充内容','填充条件','附加规则',[额外参数])<br>                 if (empty($auto[2])) $auto[2] = self::MODEL_INSERT; // 默认为新增的时候自动填充<br>                 if ($type == $auto[2] || $auto[2] == self::MODEL_BOTH) {<br>                     switch (trim($auto[3])) {<br>                         case 'function': //  使用函数进行填充 字段的值作为参数<br>                         case 'callback': // 使用回调方法<br>                             $args = isset($auto[4]) ? (array)$auto[4] : array();<br>                             if (isset($data[$auto[0]])) {<br>                                 array_unshift($args, $data[$auto[0]]);<br>                             }<br>                             if ('function' == $auto[3]) {<br>                                 $data[$auto[0]] = call_user_func_array($auto[1], $args);<br>                             } else {<br>                                 $data[$auto[0]] = call_user_func_array(array(&$this,<br>                                     $auto[1]<br>                                 ) , $args);<br>                             }<br>                             break;<br>                         case 'field': // 用其它字段的值进行填充<br>                             $data[$auto[0]] = $data[$auto[1]];<br>                             break;<br>                         case 'ignore': // 为空忽略<br>                             if ('' === $data[$auto[0]]) unset($data[$auto[0]]);<br>                             break;<br>  <br>                         case 'string':<br>                         default: // 默认作为字符串填充<br>                             $data[$auto[0]] = $auto[1];<br>                         }<br>                         if (false === $data[$auto[0]]) unset($data[$auto[0]]);<br>                     }<br>             }<br>         }<br>         return $data;<br>     }<br>      <br>     /**<br>      * 生成关联模型需要的数据<br>      */<br>     function createData($data) {<br>         foreach ($data as $k => $v) {<br>             if (in_array($k, $this->fields)) {<br>                 $data['Article'][$k] = $v;<br>                 unset($data[$k]);<br>             }<br>         }<br>         //删除多余字段<br>         unset($data['nid']);<br>         unset($data['create_date']);<br>         return $data;<br>     }就是直接复制的原来的create方法,但是去掉了字段过滤,然后自动验证,自动完成后,createData方法生成最后的数据,我觉得官方应该修改一下这一块,就更好了。

From: http://www.jishutie.net/topic/350464

AD:真正免费,域名+虚机+企业邮箱=0元

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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

Ketahui tentang contoh kod pengenalan untuk pengaturcaraan Python Ketahui tentang contoh kod pengenalan untuk pengaturcaraan Python Jan 04, 2024 am 10:50 AM

Ketahui tentang pengaturcaraan Python dengan contoh kod pengenalan Python ialah bahasa pengaturcaraan yang mudah dipelajari tetapi berkuasa. Bagi pemula, adalah sangat penting untuk memahami contoh kod pengenalan pengaturcaraan Python. Artikel ini akan memberikan anda beberapa contoh kod konkrit untuk membantu anda bermula dengan cepat. Cetak HelloWorldprint("HelloWorld") Ini ialah contoh kod paling mudah dalam Python. Fungsi print() digunakan untuk mengeluarkan kandungan yang ditentukan

Pembolehubah PHP dalam tindakan: 10 contoh penggunaan sebenar Pembolehubah PHP dalam tindakan: 10 contoh penggunaan sebenar Feb 19, 2024 pm 03:00 PM

Pembolehubah PHP menyimpan nilai semasa runtime program dan sangat penting untuk membina aplikasi WEB yang dinamik dan interaktif. Artikel ini melihat secara mendalam pembolehubah PHP dan menunjukkannya dalam tindakan dengan 10 contoh kehidupan sebenar. 1. Simpan input pengguna $nama pengguna=$_POST["nama pengguna"];$passWord=$_POST["kata laluan"] Contoh ini mengekstrak nama pengguna dan kata laluan daripada penyerahan borang dan menyimpannya dalam pembolehubah untuk pemprosesan selanjutnya. 2. Tetapkan nilai konfigurasi $database_host="localhost";$database_username="username";$database_pa

Contoh pengaturcaraan bahasa Go: contoh kod dalam pembangunan web Contoh pengaturcaraan bahasa Go: contoh kod dalam pembangunan web Mar 04, 2024 pm 04:54 PM

"Contoh Pengaturcaraan Bahasa Pergi: Contoh Kod dalam Pembangunan Web" Dengan perkembangan pesat Internet, pembangunan Web telah menjadi bahagian yang amat diperlukan dalam pelbagai industri. Sebagai bahasa pengaturcaraan dengan fungsi berkuasa dan prestasi unggul, bahasa Go semakin digemari oleh pembangun dalam pembangunan web. Artikel ini akan memperkenalkan cara menggunakan bahasa Go untuk pembangunan Web melalui contoh kod tertentu, supaya pembaca boleh memahami dengan lebih baik dan menggunakan bahasa Go untuk membina aplikasi Web mereka sendiri. 1. Pelayan HTTP Mudah Mula-mula, mari kita mulakan dengan a

Java melaksanakan kod isihan gelembung mudah Java melaksanakan kod isihan gelembung mudah Jan 30, 2024 am 09:34 AM

Contoh kod paling ringkas bagi jenis gelembung Java ialah algoritma pengisihan biasa. Idea asasnya ialah melaraskan urutan secara beransur-ansur ke dalam urutan tersusun melalui perbandingan dan pertukaran elemen bersebelahan. Berikut ialah contoh kod Java ringkas yang menunjukkan cara melaksanakan isihan gelembung: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

Panduan Sambungan Pengkomputeran Tepi Awan Huawei: Contoh kod Java untuk melaksanakan antara muka dengan cepat Panduan Sambungan Pengkomputeran Tepi Awan Huawei: Contoh kod Java untuk melaksanakan antara muka dengan cepat Jul 05, 2023 pm 09:57 PM

Panduan Sambungan Pengkomputeran Tepi Awan Huawei: Contoh Kod Java untuk Melaksanakan Antara Muka Dengan Pantas Dengan perkembangan pesat teknologi IoT dan peningkatan pengkomputeran tepi, semakin banyak perusahaan mula memberi perhatian kepada aplikasi pengkomputeran tepi. Huawei Cloud menyediakan perkhidmatan pengkomputeran edge, menyediakan perusahaan dengan sumber pengkomputeran yang sangat boleh dipercayai dan persekitaran pembangunan yang mudah, menjadikan aplikasi pengkomputeran tepi lebih mudah untuk dilaksanakan. Artikel ini akan memperkenalkan cara untuk melaksanakan antara muka pengkomputeran tepi Awan Huawei dengan cepat melalui kod Java. Pertama, kita perlu menyediakan persekitaran pembangunan. Pastikan anda memasang Java Development Kit (

Daripada pemula hingga mahir: Pelaksanaan kod struktur data yang biasa digunakan dalam bahasa Go Daripada pemula hingga mahir: Pelaksanaan kod struktur data yang biasa digunakan dalam bahasa Go Mar 04, 2024 pm 03:09 PM

Tajuk: Dari Permulaan hingga Penguasaan: Pelaksanaan Kod Struktur Data Yang Biasa Digunakan dalam Bahasa Go Struktur data memainkan peranan penting dalam pengaturcaraan dan merupakan asas pengaturcaraan. Dalam bahasa Go, terdapat banyak struktur data yang biasa digunakan, dan menguasai pelaksanaan struktur data ini adalah penting untuk menjadi seorang pengaturcara yang baik. Artikel ini akan memperkenalkan struktur data yang biasa digunakan dalam bahasa Go dan memberikan contoh kod yang sepadan untuk membantu pembaca daripada mula menjadi mahir dalam struktur data ini. 1. Array Array ialah struktur data asas, kumpulan daripada jenis yang sama

Cara menggunakan PHP untuk menulis kod fungsi pengurusan inventori dalam sistem pengurusan inventori Cara menggunakan PHP untuk menulis kod fungsi pengurusan inventori dalam sistem pengurusan inventori Aug 06, 2023 pm 04:49 PM

Cara menggunakan PHP untuk menulis kod fungsi pengurusan inventori dalam sistem pengurusan inventori adalah bahagian yang amat diperlukan dalam banyak perusahaan. Bagi syarikat yang mempunyai berbilang gudang, fungsi pengurusan inventori amat penting. Dengan mengurus dan menjejak inventori dengan betul, syarikat boleh memperuntukkan inventori antara gudang yang berbeza, mengoptimumkan kos operasi dan meningkatkan kecekapan kerjasama. Artikel ini akan memperkenalkan cara menggunakan PHP untuk menulis kod bagi fungsi pengurusan gudang inventori dan memberikan anda contoh kod yang berkaitan. 1. Wujudkan pangkalan data sebelum mula menulis kod untuk fungsi pengurusan gudang inventori.

Panduan dan Contoh: Belajar untuk melaksanakan algoritma isihan pemilihan dalam Java Panduan dan Contoh: Belajar untuk melaksanakan algoritma isihan pemilihan dalam Java Feb 18, 2024 am 10:52 AM

Panduan Menulis Kod Kaedah Isih Pemilihan Java dan Contoh Isihan pemilihan ialah algoritma pengisihan yang mudah dan intuitif Ideanya adalah untuk memilih elemen terkecil (atau terbesar) daripada elemen yang tidak diisih setiap kali dan menukarnya sehingga semua elemen diisih. Artikel ini akan menyediakan panduan menulis kod untuk pengisihan pemilihan dan melampirkan kod sampel Java tertentu. Prinsip Algoritma Prinsip asas isihan pemilihan ialah membahagikan tatasusunan yang hendak diisih kepada dua bahagian, diisih dan tidak diisih Setiap kali, elemen terkecil (atau terbesar) dipilih daripada bahagian yang tidak diisih dan diletakkan di hujung bahagian yang diisih. Ulang perkara di atas

See all articles