Heim 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元

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Erfahren Sie mehr über einführende Codebeispiele für die Python-Programmierung Erfahren Sie mehr über einführende Codebeispiele für die Python-Programmierung Jan 04, 2024 am 10:50 AM

Erfahren Sie anhand einführender Codebeispiele mehr über die Python-Programmierung. Python ist eine leicht zu erlernende und dennoch leistungsstarke Programmiersprache. Für Anfänger ist es sehr wichtig, die einführenden Codebeispiele der Python-Programmierung zu verstehen. In diesem Artikel finden Sie einige konkrete Codebeispiele, die Ihnen den schnellen Einstieg erleichtern. Print HelloWorldprint("HelloWorld") Dies ist das einfachste Codebeispiel in Python. Mit der Funktion print() wird der angegebene Inhalt ausgegeben

PHP-Variablen in Aktion: 10 Anwendungsbeispiele aus der Praxis PHP-Variablen in Aktion: 10 Anwendungsbeispiele aus der Praxis Feb 19, 2024 pm 03:00 PM

PHP-Variablen speichern Werte während der Programmlaufzeit und sind für den Aufbau dynamischer und interaktiver WEB-Anwendungen von entscheidender Bedeutung. Dieser Artikel wirft einen detaillierten Blick auf PHP-Variablen und zeigt sie anhand von 10 Beispielen aus der Praxis. 1. Benutzereingaben speichern $username=$_POST["username"];$passWord=$_POST["password"]; Dieses Beispiel extrahiert den Benutzernamen und das Passwort aus der Formularübermittlung und speichert sie zur weiteren Verarbeitung in Variablen. 2. Legen Sie den Konfigurationswert $database_host="localhost";$database_username="username";$database_pa fest

Beispiele für Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung Beispiele für Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung Mar 04, 2024 pm 04:54 PM

„Beispiele zur Go-Sprachprogrammierung: Codebeispiele in der Webentwicklung“ Mit der rasanten Entwicklung des Internets ist die Webentwicklung zu einem unverzichtbaren Bestandteil verschiedener Branchen geworden. Als Programmiersprache mit leistungsstarken Funktionen und überlegener Leistung wird die Go-Sprache von Entwicklern in der Webentwicklung zunehmend bevorzugt. In diesem Artikel wird anhand spezifischer Codebeispiele erläutert, wie die Go-Sprache für die Webentwicklung verwendet wird, damit die Leser die Go-Sprache besser verstehen und zum Erstellen ihrer eigenen Webanwendungen verwenden können. 1. Einfacher HTTP-Server Beginnen wir zunächst mit a

Java implementiert einen einfachen Blasensortierungscode Java implementiert einen einfachen Blasensortierungscode Jan 30, 2024 am 09:34 AM

Das einfachste Codebeispiel für die Blasensortierung in Java ist ein allgemeiner Sortieralgorithmus. Seine Grundidee besteht darin, die zu sortierende Reihenfolge durch Vergleich und Austausch benachbarter Elemente schrittweise anzupassen. Hier ist ein einfaches Java-Codebeispiel, das zeigt, wie die Blasensortierung implementiert wird: publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Jul 05, 2023 pm 09:57 PM

Huawei Cloud Edge Computing Interconnection Guide: Java-Codebeispiele zur schnellen Implementierung von Schnittstellen Mit der rasanten Entwicklung der IoT-Technologie und dem Aufstieg des Edge Computing beginnen immer mehr Unternehmen, der Anwendung von Edge Computing Aufmerksamkeit zu schenken. Huawei Cloud bietet Edge-Computing-Dienste und stellt Unternehmen äußerst zuverlässige Computerressourcen und eine praktische Entwicklungsumgebung zur Verfügung, wodurch Edge-Computing-Anwendungen einfacher zu implementieren sind. In diesem Artikel erfahren Sie, wie Sie die Huawei Cloud Edge Computing-Schnittstelle schnell über Java-Code implementieren. Zuerst müssen wir die Entwicklungsumgebung vorbereiten. Stellen Sie sicher, dass Sie das Java Development Kit installiert haben (

Vom Anfänger bis zum Experten: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache Vom Anfänger bis zum Experten: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache Mar 04, 2024 pm 03:09 PM

Titel: Vom Anfänger zur Meisterschaft: Code-Implementierung häufig verwendeter Datenstrukturen in der Go-Sprache. Datenstrukturen spielen eine wichtige Rolle in der Programmierung und sind die Grundlage der Programmierung. In der Go-Sprache gibt es viele häufig verwendete Datenstrukturen, und die Beherrschung der Implementierung dieser Datenstrukturen ist entscheidend, um ein guter Programmierer zu werden. In diesem Artikel werden die häufig verwendeten Datenstrukturen in der Go-Sprache vorgestellt und entsprechende Codebeispiele gegeben, um den Lesern den Einstieg bis zur Beherrschung dieser Datenstrukturen zu erleichtern. 1. Array Array ist eine grundlegende Datenstruktur, bei der es sich um eine Gruppe desselben Typs handelt.

So schreiben Sie mit PHP Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem So schreiben Sie mit PHP Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem Aug 06, 2023 pm 04:49 PM

So schreiben Sie mit PHP den Funktionscode für die Bestandsverwaltung im Bestandsverwaltungssystem. Die Bestandsverwaltung ist für viele Unternehmen ein unverzichtbarer Bestandteil. Für Unternehmen mit mehreren Lagern ist die Bestandsverwaltungsfunktion besonders wichtig. Durch die ordnungsgemäße Verwaltung und Nachverfolgung des Lagerbestands können Unternehmen den Lagerbestand auf verschiedene Lager verteilen, die Betriebskosten optimieren und die Effizienz der Zusammenarbeit verbessern. In diesem Artikel erfahren Sie, wie Sie mit PHP Code für Lagerverwaltungsfunktionen schreiben und erhalten relevante Codebeispiele. 1. Richten Sie die Datenbank ein, bevor Sie mit dem Schreiben des Codes für die Lagerverwaltungsfunktion beginnen.

Anleitung und Beispiele: Erfahren Sie, wie Sie den Auswahlsortierungsalgorithmus in Java implementieren Anleitung und Beispiele: Erfahren Sie, wie Sie den Auswahlsortierungsalgorithmus in Java implementieren Feb 18, 2024 am 10:52 AM

Code-Schreibanleitung und Beispiele für die Java-Auswahlsortierung Die Auswahlsortierung ist ein einfacher und intuitiver Sortieralgorithmus. Die Idee besteht darin, jedes Mal das kleinste (oder größte) Element aus den unsortierten Elementen auszuwählen und es auszutauschen, bis alle Elemente sortiert sind. Dieser Artikel enthält eine Anleitung zum Schreiben von Code für die Auswahlsortierung und fügt spezifischen Java-Beispielcode hinzu. Algorithmusprinzip Das Grundprinzip der Auswahlsortierung besteht darin, das zu sortierende Array in zwei Teile zu unterteilen: sortiert und unsortiert. Dabei wird jeweils das kleinste (oder größte) Element aus dem unsortierten Teil ausgewählt und am Ende des sortierten Teils platziert. Wiederholen Sie das oben Gesagte

See all articles