


PHP reads the table structure and automatically generates PHP classes
When I usually write projects, I often encounter operating databases. The most troublesome thing every time I operate a database is to write a table mapping class. Based on the rules, I wrote an automatically generated small demo:
<code><span><?php</span><span>// 数据库配置参数</span><span>$db_config</span> = <span>array</span>( <span>'host'</span> => <span>'127.0.0.1'</span>, <span>'port'</span> => <span>3306</span>, <span>'username'</span> => <span>'root'</span>, <span>'password'</span> => <span>''</span>, <span>'dbname'</span> => <span>'joe_db'</span>, <span>'charset'</span> => <span>'utf8'</span> ); <span>$tablePre</span> = <span>'joe_'</span>; <span>// 表前缀</span><span>$tableName</span> = <span>'users'</span>; <span>// 表名</span><span>$res</span> = linkdb(<span>$db_config</span>, <span>$tablePre</span> . <span>$tableName</span>); <span>$className</span> = <span>$tableName</span> . <span>'Dmodel'</span>; <span>$fileName</span> = <span>$tableName</span> . <span>'.dm.class.php'</span>; <span>$annStr</span> = addAnnotation(<span>$fileName</span>, <span>$tableName</span>, <span>'用户session表'</span>); <span>$classStr</span> = readTableStr(<span>$res</span>, <span>$className</span>,<span>$annStr</span>); <span>// 写入文件</span><span>$file</span> = fopen(<span>$fileName</span>, <span>"w+"</span>); fwrite(<span>$file</span>, <span>$classStr</span>); fclose(<span>$file</span>); <span>/** * 根据表结构初始化表对象 * *<span> @param</span> unknown $res *<span> @param</span> unknown $className *<span> @return</span> string */</span><span><span>function</span><span>readTableStr</span><span>(<span>$res</span>, <span>$className</span>, <span>$annStr</span>=<span>''</span>)</span> {</span><span>$result</span> = <span>'<?php '</span> . <span>"\n"</span>; <span>$result</span> .= <span>$annStr</span>; <span>$result</span> .= <span>"class $className \n{"</span>; <span>// 变量</span><span>foreach</span> (<span>$res</span><span>as</span><span>$v</span>) { <span>$result</span> .= <span>"\n"</span> . <span>'private $_'</span> . strtolower(<span>$v</span>[<span>'Field'</span>]) . <span>";//"</span> . <span>$v</span>[<span>'Comment'</span>] . <span>$v</span>[<span>'Type'</span>]; } <span>$result</span> .= <span>"\n"</span>; <span>// get set</span><span>foreach</span> (<span>$res</span><span>as</span><span>$v</span>) { <span>$result</span> .= <span>"\n public function set"</span> . <span>$v</span>[<span>'Field'</span>] . <span>'($_'</span> . strtolower(<span>$v</span>[<span>'Field'</span>]) . <span>"){"</span>; <span>$result</span> .= <span>"\n"</span> . <span>' $this->_'</span> . strtolower(<span>$v</span>[<span>'Field'</span>]) . <span>'=$_'</span> . strtolower(<span>$v</span>[<span>'Field'</span>]) . <span>";"</span>; <span>$result</span> .= <span>"\n }"</span>; <span>$result</span> .= <span>"\n public function get"</span> . <span>$v</span>[<span>'Field'</span>] . <span>'(){'</span>; <span>$result</span> .= <span>"\n"</span> . <span>' return $this->_'</span> . strtolower(<span>$v</span>[<span>'Field'</span>]) . <span>";"</span>; <span>$result</span> .= <span>"\n }"</span>; <span>$result</span> .= <span>"\n"</span>; } <span>$result</span> .= <span>" \n }"</span>; <span>$result</span> .= <span>" \n ?>"</span>; <span>return</span><span>$result</span>; } <span>/** * 添加类注释 * *<span> @param</span> unknown $fileName *<span> @param</span> unknown $fun *<span> @param</span> unknown $des *<span> @param</span> unknown $date *<span> @param</span> unknown $author */</span><span><span>function</span><span>addAnnotation</span><span>(<span>$fileName</span>, <span>$fun</span>, <span>$des</span>)</span> {</span><span>$annStr</span> = <span>"\n/**"</span>; <span>$annStr</span> .= <span>"\n* 文件名:"</span> . <span>$fileName</span>; <span>$annStr</span> .= <span>"\n* 功能: 模型层-表-"</span> . <span>$fun</span>; <span>$annStr</span> .= <span>"\n* 描述: "</span> . <span>$des</span>; <span>$annStr</span> .= <span>"\n* 日期: "</span> . date(<span>'y-m-d'</span>, time()); <span>$annStr</span> .= <span>"\n* 版权: Copyright ? 2016 github.com/JoeXiong All Rights Reserved"</span>; <span>$annStr</span> .= <span>"\n* @author JoeXiong"</span>; <span>$annStr</span> .= <span>"\n*/"</span>; <span>return</span><span>$annStr</span>; } <span>/** * * 连接数据库,查询表结构 * *<span> @param</span> unknown $array * 数据库连接参数 *<span> @param</span> unknown $tableName * 表名 */</span><span><span>function</span><span>linkdb</span><span>(<span>$array</span>, <span>$tableName</span>)</span> {</span><span>$mysql_server_name</span> = <span>$array</span>[<span>'host'</span>]; <span>// 改成自己的mysql数据库服务器</span><span>$mysql_username</span> = <span>$array</span>[<span>'username'</span>]; <span>// 改成自己的mysql数据库用户名</span><span>$mysql_password</span> = <span>$array</span>[<span>'password'</span>]; <span>// 改成自己的mysql数据库密码</span><span>$mysql_database</span> = <span>$array</span>[<span>'dbname'</span>]; <span>// 改成自己的mysql数据库名</span><span>$conn</span> = mysql_connect(<span>$mysql_server_name</span>, <span>$mysql_username</span>, <span>$mysql_password</span>) <span>or</span><span>die</span>(<span>"error connecting"</span>); <span>// 连接数据库</span> mysql_query(<span>"set names "</span> . <span>$array</span>[<span>'charset'</span>]); <span>// 数据库输出编码</span> mysql_select_db(<span>$mysql_database</span>); <span>// 打开数据库</span><span>$sql</span> = <span>"SHOW FULL COLUMNS FROM $tableName"</span>; <span>$res</span> = mysql_query(<span>$sql</span>); <span>$res</span> = dataTable(<span>$res</span>); <span>return</span><span>$res</span>; } <span>/** * 返回到表集合 * *<span> @param</span> query $query *<span> @return</span> array */</span><span><span>function</span><span>dataTable</span><span>(<span>$query</span>)</span> {</span><span>if</span> (<span>$query</span>) { <span>$ListTable</span> = <span>array</span>(); <span>while</span> (<span>$rows</span> = mysql_fetch_array(<span>$query</span>, MYSQL_ASSOC)) { array_push(<span>$ListTable</span>, <span>$rows</span>); } <span>return</span><span>$ListTable</span>; } <span>else</span> { <span>return</span><span>0</span>; } } <span>/** * 调试函数 * *<span> @param</span> unknown $msg */</span><span><span>function</span><span>show_bug</span><span>(<span>$msg</span>)</span> {</span><span>echo</span><span>'<pre class="brush:php;toolbar:false">'</span>; var_dump(<span>$msg</span>); <span>echo</span><span>''; }
The final effect:
<code><span><?php</span><span>/** * 文件名:users.dm.class.php * 功能: 模型层-表-users * 描述: 用户session表 * 日期: 16-06-27 * 版权: Copyright ? 2016 github.com/JoeXiong All Rights Reserved *<span> @author</span> JoeXiong */</span><span><span>class</span><span>usersDmodel</span> {</span><span>private</span><span>$_userid</span>; <span>// int(11) unsigned</span><span>private</span><span>$_username</span>; <span>// 用户名varchar(50)</span><span>private</span><span>$_password</span>; <span>// 密码varchar(32)</span><span>private</span><span>$_email</span>; <span>// 邮箱varchar(80)</span><span>private</span><span>$_mobile</span>; <span>// 手机号码varchar(20)</span><span>private</span><span>$_ip</span>; <span>// 用户注册IDvarchar(30)</span><span>private</span><span>$_status</span>; <span>// 帐号状态tinyint(1) unsigned</span><span>private</span><span>$_areaid</span>; <span>// 区域Id,10001为本区;10002为qq用户;10003为新浪微博用户smallint(5) unsigned</span><span>private</span><span>$_addtime</span>; <span>// 创建时间int(10) unsigned</span><span>public</span><span><span>function</span><span>setUserId</span><span>(<span>$_userid</span>)</span> {</span><span>$this</span>->_userid = <span>$_userid</span>; } <span>public</span><span><span>function</span><span>getUserId</span><span>()</span> {</span><span>return</span><span>$this</span>->_userid; } <span>public</span><span><span>function</span><span>setUserName</span><span>(<span>$_username</span>)</span> {</span><span>$this</span>->_username = <span>$_username</span>; } <span>public</span><span><span>function</span><span>getUserName</span><span>()</span> {</span><span>return</span><span>$this</span>->_username; } <span>public</span><span><span>function</span><span>setPassWord</span><span>(<span>$_password</span>)</span> {</span><span>$this</span>->_password = <span>$_password</span>; } <span>public</span><span><span>function</span><span>getPassWord</span><span>()</span> {</span><span>return</span><span>$this</span>->_password; } <span>public</span><span><span>function</span><span>setEmail</span><span>(<span>$_email</span>)</span> {</span><span>$this</span>->_email = <span>$_email</span>; } <span>public</span><span><span>function</span><span>getEmail</span><span>()</span> {</span><span>return</span><span>$this</span>->_email; } <span>public</span><span><span>function</span><span>setMobile</span><span>(<span>$_mobile</span>)</span> {</span><span>$this</span>->_mobile = <span>$_mobile</span>; } <span>public</span><span><span>function</span><span>getMobile</span><span>()</span> {</span><span>return</span><span>$this</span>->_mobile; } <span>public</span><span><span>function</span><span>setIP</span><span>(<span>$_ip</span>)</span> {</span><span>$this</span>->_ip = <span>$_ip</span>; } <span>public</span><span><span>function</span><span>getIP</span><span>()</span> {</span><span>return</span><span>$this</span>->_ip; } <span>public</span><span><span>function</span><span>setStatus</span><span>(<span>$_status</span>)</span> {</span><span>$this</span>->_status = <span>$_status</span>; } <span>public</span><span><span>function</span><span>getStatus</span><span>()</span> {</span><span>return</span><span>$this</span>->_status; } <span>public</span><span><span>function</span><span>setAreaId</span><span>(<span>$_areaid</span>)</span> {</span><span>$this</span>->_areaid = <span>$_areaid</span>; } <span>public</span><span><span>function</span><span>getAreaId</span><span>()</span> {</span><span>return</span><span>$this</span>->_areaid; } <span>public</span><span><span>function</span><span>setAddTime</span><span>(<span>$_addtime</span>)</span> {</span><span>$this</span>->_addtime = <span>$_addtime</span>; } <span>public</span><span><span>function</span><span>getAddTime</span><span>()</span> {</span><span>return</span><span>$this</span>->_addtime; } } <span>?></span></span></code>
The above introduces how PHP reads table structures and automatically generates PHP classes, including the relevant content. I hope it will be helpful to friends who are interested in PHP tutorials.

Hot AI Tools

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

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

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

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



MySQL is an open source relational database management system. 1) Create database and tables: Use the CREATEDATABASE and CREATETABLE commands. 2) Basic operations: INSERT, UPDATE, DELETE and SELECT. 3) Advanced operations: JOIN, subquery and transaction processing. 4) Debugging skills: Check syntax, data type and permissions. 5) Optimization suggestions: Use indexes, avoid SELECT* and use transactions.

You can open phpMyAdmin through the following steps: 1. Log in to the website control panel; 2. Find and click the phpMyAdmin icon; 3. Enter MySQL credentials; 4. Click "Login".

MySQL is an open source relational database management system, mainly used to store and retrieve data quickly and reliably. Its working principle includes client requests, query resolution, execution of queries and return results. Examples of usage include creating tables, inserting and querying data, and advanced features such as JOIN operations. Common errors involve SQL syntax, data types, and permissions, and optimization suggestions include the use of indexes, optimized queries, and partitioning of tables.

MySQL is chosen for its performance, reliability, ease of use, and community support. 1.MySQL provides efficient data storage and retrieval functions, supporting multiple data types and advanced query operations. 2. Adopt client-server architecture and multiple storage engines to support transaction and query optimization. 3. Easy to use, supports a variety of operating systems and programming languages. 4. Have strong community support and provide rich resources and solutions.

Redis uses a single threaded architecture to provide high performance, simplicity, and consistency. It utilizes I/O multiplexing, event loops, non-blocking I/O, and shared memory to improve concurrency, but with limitations of concurrency limitations, single point of failure, and unsuitable for write-intensive workloads.

MySQL and SQL are essential skills for developers. 1.MySQL is an open source relational database management system, and SQL is the standard language used to manage and operate databases. 2.MySQL supports multiple storage engines through efficient data storage and retrieval functions, and SQL completes complex data operations through simple statements. 3. Examples of usage include basic queries and advanced queries, such as filtering and sorting by condition. 4. Common errors include syntax errors and performance issues, which can be optimized by checking SQL statements and using EXPLAIN commands. 5. Performance optimization techniques include using indexes, avoiding full table scanning, optimizing JOIN operations and improving code readability.

MySQL's position in databases and programming is very important. It is an open source relational database management system that is widely used in various application scenarios. 1) MySQL provides efficient data storage, organization and retrieval functions, supporting Web, mobile and enterprise-level systems. 2) It uses a client-server architecture, supports multiple storage engines and index optimization. 3) Basic usages include creating tables and inserting data, and advanced usages involve multi-table JOINs and complex queries. 4) Frequently asked questions such as SQL syntax errors and performance issues can be debugged through the EXPLAIN command and slow query log. 5) Performance optimization methods include rational use of indexes, optimized query and use of caches. Best practices include using transactions and PreparedStatemen

Effective monitoring of Redis databases is critical to maintaining optimal performance, identifying potential bottlenecks, and ensuring overall system reliability. Redis Exporter Service is a powerful utility designed to monitor Redis databases using Prometheus. This tutorial will guide you through the complete setup and configuration of Redis Exporter Service, ensuring you seamlessly build monitoring solutions. By studying this tutorial, you will achieve fully operational monitoring settings
