Heim PHP-Framework YII Der Unterschied zwischen dao und ar in yii2

Der Unterschied zwischen dao und ar in yii2

Nov 05, 2019 pm 01:20 PM
yii2

Active Record(AR)是一个流行的对象-关系映射(ORM)技术。每个AR 类代表一个数据表(或视图),数据表(或视图)的列在AR 类中体现为类的属性,一个AR 实例则表示表中的一行。常见的CRUD 操作作为AR 的方法实现。

Der Unterschied zwischen dao und ar in yii2

因此,我们可以以一种更加面向对象的方式访问数据。$c = new CDbCriteria();是ActiveRecord的一种写法,使ActiveRecord更加灵活,而拼装sql则是最常见不过,下面看两个例子。     (推荐学习:yii教程

注意:AR 并非要解决所有数据库相关的任务。它的最佳应用是模型化数据表为PHP 结构和执行不包含复杂SQL 语句的查询。对于复杂查询的场景,应使用Yii DAO。 

$criteria = new CDbCriteria;       
//函数方式 
$criteria->addCondition("id=1"); //查询条件,即where id = 1   
$criteria->addInCondition('id', array(1,2,3,4,5)); //代表where id IN (1,23,,4,5,);   
$criteria->addNotInCondition('id', array(1,2,3,4,5));//与上面正好相法,是NOT IN   
$criteria->addCondition('id=1','OR');//这是OR条件,多个条件的时候,该条件是OR而非AND   
$criteria->addSearchCondition('name', '分类');//搜索条件,其实代表了。。where name like '%分类%'   
$criteria->addBetweenCondition('id', 1, 4);//between 1 and 4    
     
$criteria->compare('id', 1);    //这个方法比较特殊,他会根据你的参数自动处理成addCondition或者addInCondition,   
                                //即如果第二个参数是数组就会调用addInCondition   
$criteria->addCondition("id = :id");   
$criteria->params[':id']=1;   
      
//属性方式   
$criteria->select = 'id,parentid,name'; //代表了要查询的字段,默认select='*';   
$criteria->join = 'xxx'; //连接表   
$criteria->with = 'xxx'; //调用relations    
$criteria->limit = 10;    //取1条数据,如果小于0,则不作处理   
$criteria->offset = 1;   //两条合并起来,则表示 limit 10 offset 1,或者代表了。limit 1,10   
$criteria->order = 'xxx DESC,XXX ASC' ;//排序条件   
$criteria->group = 'group 条件';   
$criteria->having = 'having 条件 ';   
$criteria->distinct = FALSE; //是否唯一查询
Nach dem Login kopieren

Yii数据访问对象(DAO)建立在PHP的数据对象(PDO)扩展上,使得在一个单一的统一的接口可以访问不同的数据库管理系统(DBMS)。使用Yii的DAO开发的应用程序可以很容易地切换使用不同的数据库管理系统,而不需要修改数据访问代码。下面是DAO的例子:

示例代码

/**
     * 关于DAO的例子
     * 获取所有用户名
     */
    public function getUsernames ()
    {
        $sqlStatement = ' SELECT `username` FROM `testdrive`.`tbl_user` ';
        $this->command = $this->connection->createCommand($sqlStatement);
        return $this->command->queryAll();
    }
    /**
     *
     * 添加一个用户
     */
    public function addUser ()
    {
        $sqlStatement = " INSERT INTO `tbl_user` (`username`, `password`, `email`) VALUES ('test', 'test', 'test@test.com') ";
        $this->command = $this->connection->createCommand($sqlStatement);
        return $this->command->execute();
    }
Nach dem Login kopieren

有几点注意的地方:

1,与DAO方式结果区别是:DAO方式 数组中的每一个元素仍是数组。而通过CDbCriteria方式,数组中的元素是对象。

2,即使该功能很强大,仍有一些需求不能满足,此时仍需sql语句。比如select avg(num) amount from ****。

3,打印运行后的结果,可更深入yii这么做是如何实现的

Das obige ist der detaillierte Inhalt vonDer Unterschied zwischen dao und ar in yii2. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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)

Yii mit Docker: Containerisierung und Bereitstellung Ihrer Anwendungen Yii mit Docker: Containerisierung und Bereitstellung Ihrer Anwendungen Apr 02, 2025 pm 02:13 PM

Zu den Schritten zum Containerieren und Bereitstellen von YII -Anwendungen mit Docker gehören: 1.. Erstellen Sie eine Dockerfile und definieren Sie den Bildaufbauprozess; 2. Verwenden Sie DockerCompon, um YII -Anwendungen und MySQL -Datenbank zu starten. 3.. Die Bildgröße und -leistung optimieren. Dies beinhaltet nicht nur spezifische technische Operationen, sondern auch die Arbeitsprinzipien und Best Practices von Dockerfile, um eine effiziente und zuverlässige Bereitstellung zu gewährleisten.

YII -Sicherheitshärtung: Schutz Ihrer Anwendungen vor Schwachstellen YII -Sicherheitshärtung: Schutz Ihrer Anwendungen vor Schwachstellen Apr 03, 2025 am 12:18 AM

Im YII -Framework kann die Anwendung durch die folgenden Schritte geschützt werden: 1) Aktivieren Sie den CSRF -Schutz, 2) Eingabeüberprüfung implementieren und 3) Verwenden Sie die Ausgangsausgabe. Diese Maßnahmen schützen vor CSRF-, SQL -Injektions- und XSS -Angriffen durch Einbettung von CSRF -Token, Definieren von Überprüfungsregeln und automatischen HTML -Escapes, um die Sicherheit der Anwendung zu gewährleisten.

Der aktuelle Zustand von Yii: Ein Blick auf seine Popularität Der aktuelle Zustand von Yii: Ein Blick auf seine Popularität Apr 13, 2025 am 12:19 AM

YiiremainSpopularButislessFavoredThanLaravel, Withabout14KgithuBStars.itexcelSinperformanceAndactiveCord, ButhasasterLearningCurveAnDasAlleRecosystem.itssidealfordeViornitizefficiency.System.

YII -Interview Fragen: Ace Ihr PHP -Framework -Interview YII -Interview Fragen: Ace Ihr PHP -Framework -Interview Apr 06, 2025 am 12:20 AM

Wenn Sie sich auf ein Interview mit YII Framework vorbereiten, müssen Sie die folgenden wichtigen Wissenspunkte kennen: 1. MVC -Architektur: Verstehen Sie die kollaborative Arbeit von Modellen, Ansichten und Controllern. 2. ActiveCord: Beherrschen Sie die Verwendung von ORM -Tools und vereinfachen Sie die Datenbankvorgänge. 3.. Widgets und Helfer: Mit integrierten Komponenten und Helferfunktionen vertraut und die Benutzeroberfläche schnell erstellen. Wenn Sie diese Kernkonzepte und Best Practices beherrschen, können Sie sich im Interview abheben.

YII -Datenbankverwaltung: Erweiterte aktive Datensätze und Migrationen YII -Datenbankverwaltung: Erweiterte aktive Datensätze und Migrationen Apr 05, 2025 am 12:17 AM

Advanced ActivereCord- und Migrationstools im YII -Framework sind wichtig, um Datenbanken effizient zu verwalten. 1) Advanced ActivereCord unterstützt komplexe Abfragen und Datenoperationen wie zugehörige Abfragen und Stapel -Updates. 2) Das Migrationstool wird verwendet, um Änderungen der Datenbankstruktur zu verwalten und sichere Aktualisierungen des Schemas sicherzustellen.

YII: Ein starker Rahmen für die Webentwicklung YII: Ein starker Rahmen für die Webentwicklung Apr 15, 2025 am 12:09 AM

YII ist ein Hochleistungs-PHP-Framework für schnelle Entwicklung und effiziente Codegenerierung. Zu den Kernmerkmalen gehören: MVC -Architektur: YII nimmt die MVC -Architektur an, um Entwicklern dabei zu helfen, die Anwendungslogik zu trennen und den Code zu erleichtern, um die Wartung und Erweiterung zu erleichtern. Komponentierung und Codegenerierung: Durch Komponentierungen und Codeerzeugung reduziert YII die sich wiederholende Arbeit von Entwicklern und verbessert die Entwicklungseffizienz. Leistungsoptimierung: YII verwendet die Latenzbelastungs- und Caching -Technologien, um einen effizienten Betrieb unter hohen Lasten zu gewährleisten, und bietet leistungsstarke ORM -Funktionen, um Datenbankvorgänge zu vereinfachen.

YII RESTFOR API -Entwicklung: Best Practices & Authentifizierung YII RESTFOR API -Entwicklung: Best Practices & Authentifizierung Apr 09, 2025 am 12:13 AM

Die Entwicklung einer erholsamen API im YII -Framework kann in den folgenden Schritten erreicht werden: Definieren eines Controllers: Verwenden Sie Yii \ rest \ actionController, um einen Ressourcencontroller wie UserController zu definieren. Authentifizierung konfigurieren: Stellen Sie die Sicherheit der API sicher, indem Sie den HTTPbearer -Authentifizierungsmechanismus hinzufügen. Paging und Sortierung implementieren: Verwenden Sie YII \ Data \ ActiveAvedataprovider, um eine komplexe Geschäftslogik zu verarbeiten. Fehlerbehandlung: Konfigurieren Sie YII \ Web \ ERRAGEHANDLER, um Fehlerantworten anzupassen, z. B. die Behandlung, wenn die Authentifizierung fehlschlägt. Leistungsoptimierung: Verwenden Sie den Caching -Mechanismus von YII, um häufig zugängliche Ressourcen zu optimieren und die API -Leistung zu verbessern.

Yii 2.0 Deep Dive: Leistungsstimmen & Optimierung Yii 2.0 Deep Dive: Leistungsstimmen & Optimierung Apr 10, 2025 am 09:43 AM

Zu den Strategien zur Verbesserung der Anwendungsleistung von YII2.0 gehören: 1. Datenbankabfrageoptimierung, Verwenden von QueryBuilder und ActiveCord, um bestimmte Felder und Limit -Ergebnissätze auszuwählen; 2. Caching -Strategie, rationale Verwendung von Daten, Abfrage und Seitencache; 3.. Durch diese Methoden kann die Leistung von YII2.0 -Anwendungen erheblich verbessert werden.

See all articles