


YII dynamic model (dynamic table name) supports analysis, yii model_PHP tutorial
Jul 12, 2016 am 08:55 AMYII dynamic model (dynamic table name) support analysis, yii model
This article analyzes the YII dynamic model (dynamic table name) support mechanism. Share it with everyone for your reference, the details are as follows:
Add dynamic model support to YII framework
The data model in the Yii framework uses a static mechanism. If you want to use the model method to operate a certain data table, you must create a model class corresponding to the data table in advance (located in the protected/models directory). In this way, there are This brings some inconvenience to our work, such as only displaying the data table, or the data table is dynamically generated, or it is necessary to realize the separation of reading and writing in the data table model, (such as data writing and data presentation logic May be defined in different models to improve performance, such as separation of front and back).
In order to solve this problem, after repeated debugging, I have extended dynamic data table model support for Yii. When using it, simply provide the table name and you can operate it as an ordinary data table model. Of course, it brings The problem is that there is no data verification. Even so, it brings great convenience to data display. If you have any questions during use, you can contact the author at zhangxugg@163.com at any time for discussion or to obtain the source code.
The processing method is as follows:
Please place the DbTable.php I provided in the protected/models/ directory, and then you can use it anywhere.
Generate new record:
$memo = new DTable('{{memo}}'); $memo->msg = 'this is content'; $memo->save(); //last insertid echo $memo->id ;
Read existing records:
$memo = DTable::model('{{memo}}')->findByPk(12); $memo->msg = "modefid content"; $memo->save(); //使用非默認(rèn)數(shù)據(jù)庫(kù),需要在 config/main.php 文件中定義數(shù)據(jù)庫(kù)連接,如: 'components' => array( 'db-other'=>array( 'class' => 'CDbConnection', 'connectionString' => 'mysql:host=localhost;dbname=cdcol;charset=utf8', 'username' => 'root', 'password' =>'', 'tablePrefix' => '', 'autoConnect' => false, ), ); DTable::$db = Yii::app()->getComponent('db-other'); $memo = DTable::model('{{memo}}')->findByPk(12);
Dynamic model supports for Yii framework 1.1.10
/** * DTable class file. * @author zhangxugg@163.com * @since Yii 1.1.10 * @package application.models * @version $Id DTable.php 1 2012-03-24 23:29 $ DTable provides dynamic table model supports for some application entironment such as dynamic-generated database tables, or simple read actions. please contact zhangxugg@163.com for the source code. new record : $model = new DTable('table_name'); //use table prefix: $model = new DTable('{{table_name}}'); $model->id = $id; $model->name = 'zhangxugg@163.com'; $model->save(); update: $model = DTable::model('{{table_name}}') $model->name = 'zhangxugg@163.com' $model->save(); $list = $model->findAll(); use non-default database connection : DTable::$db = Yii::app()->getCompoments('db-extra'); tips : you must define the database connection informations in config/main.php 'components' => array( 'db-extra' => array( 'class' => 'CDbConnection', 'connectionString' => 'mysql:host=localhost;dbname=cdcol;charset=utf8', 'username' => 'root', 'password' =>'', 'tablePrefix' => '', 'autoConnect' => false, ), ) DTable source code : class DTable extends CActiveRecord { private static $tableName ; public function __construct($table_name = '') { if($table_name === null) { parent::__construct(null); } else { self::$tableName = $table_name ; parent::__construct(); } } public static function model($table_name='') { self::$tableName = $table_name ; return parent::model(__CLASS__); } public function tableName() { return self::$tableName; } } */
Readers who are interested in more Yii-related content can check out the special topics on this site: "Introduction to Yii Framework and Summary of Common Techniques", "Summary of Excellent PHP Development Framework", "Basic Tutorial for Getting Started with Smarty Templates", "php Date and Time" Usage Summary", "php object-oriented programming introductory tutorial", "php string (string) usage summary", "php mysql database operation introductory tutorial" and "php common database operation skills summary"
I hope this article will be helpful to everyone’s PHP program design based on the Yii framework.
Articles you may be interested in:
- Summary of the use of filters in PHP's Yii framework
- Advanced use of Views in PHP's Yii framework
- Detailed explanation of the Controller controller in PHP's Yii framework
- Yii database cache instance analysis
- Summary of usage of uploading images in Yii framework
- Yii method to enable fragment caching
- Detailed explanation of attribute injection and method injection of component behavior in PHP's Yii framework
- Detailed explanation of how to use behavioral Behaviors in PHP's Yii framework
- In-depth explanation of PHP's Yii framework Property (Property)
- Interpretation of the request and response processing flow in PHP's Yii framework
- YII Framework filter usage analysis

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In the current information age, big data, artificial intelligence, cloud computing and other technologies have become the focus of major enterprises. Among these technologies, graphics card rendering technology, as a high-performance graphics processing technology, has received more and more attention. Graphics card rendering technology is widely used in game development, film and television special effects, engineering modeling and other fields. For developers, choosing a framework that suits their projects is a very important decision. Among current languages, PHP is a very dynamic language. Some excellent PHP frameworks such as Yii2, Ph

The Yii framework is an open source PHP Web application framework that provides numerous tools and components to simplify the process of Web application development, of which data query is one of the important components. In the Yii framework, we can use SQL-like syntax to access the database to query and manipulate data efficiently. The query builder of the Yii framework mainly includes the following types: ActiveRecord query, QueryBuilder query, command query and original SQL query

As the Internet continues to develop, the demand for web application development is also getting higher and higher. For developers, developing applications requires a stable, efficient, and powerful framework, which can improve development efficiency. Yii is a leading high-performance PHP framework that provides rich features and good performance. Yii3 is the next generation version of the Yii framework, which further optimizes performance and code quality based on Yii2. In this article, we will introduce how to use Yii3 framework to develop PHP applications.

As the demand for web applications continues to grow, developers have more and more choices in choosing development frameworks. Symfony and Yii2 are two popular PHP frameworks. They both have powerful functions and performance, but when faced with the need to develop large-scale web applications, which framework is more suitable? Next we will conduct a comparative analysis of Symphony and Yii2 to help you make a better choice. Basic Overview Symphony is an open source web application framework written in PHP and is built on

With the continuous development of cloud computing technology, data backup has become something that every enterprise must do. In this context, it is particularly important to develop a highly available cloud backup system. The PHP framework Yii is a powerful framework that can help developers quickly build high-performance web applications. The following will introduce how to use the Yii framework to develop a highly available cloud backup system. Designing the database model In the Yii framework, the database model is a very important part. Because the data backup system requires a lot of tables and relationships

The main differences between Laravel and Yii are design concepts, functional characteristics and usage scenarios. 1.Laravel focuses on the simplicity and pleasure of development, and provides rich functions such as EloquentORM and Artisan tools, suitable for rapid development and beginners. 2.Yii emphasizes performance and efficiency, is suitable for high-load applications, and provides efficient ActiveRecord and cache systems, but has a steep learning curve.

The steps to containerize and deploy Yii applications using Docker include: 1. Create a Dockerfile and define the image building process; 2. Use DockerCompose to launch Yii applications and MySQL database; 3. Optimize image size and performance. This involves not only specific technical operations, but also understanding the working principles and best practices of Dockerfile to ensure efficient and reliable deployment.

With the rapid development of the Internet, APIs have become an important way to exchange data between various applications. Therefore, it has become increasingly important to develop an API framework that is easy to maintain, efficient, and stable. When choosing an API framework, Yii2 and Symfony are two popular choices among developers. So, which one is more suitable for API development? This article will compare these two frameworks and give some conclusions. 1. Basic introduction Yii2 and Symfony are mature PHP frameworks with corresponding extensions that can be used to develop
