平时写项目的时候经常会碰到操作数据库,每次操作数据库的时候最麻烦的就是要写一个表映射的类,根据规律总结写了一个自动生成的小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">'; var_dump($msg); echo''; }
最终实现效果:
<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>').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });
以上就介绍了 php 读取表结构自动生成php类,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增强codemodocultion,可验证性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

选择DependencyInjection(DI)用于大型应用,ServiceLocator适合小型项目或原型。1)DI通过构造函数注入依赖,提高代码的测试性和模块化。2)ServiceLocator通过中心注册获取服务,方便但可能导致代码耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)启用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替换loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化进行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)

tomakephpapplicationsfaster,关注台词:1)useopcodeCachingLikeLikeLikeLikeLikePachetoStorePreciledScompiledScriptbyTecode.2)MinimimiedAtabaseSqueriSegrieSqueriSegeriSybysequeryCachingandeffeftExting.3)Leveragephp7 leveragephp7 leveragephp7 leveragephpphp7功能forbettercodeefficy.4)

到ImprovephPapplicationspeed,关注台词:1)启用opcodeCachingwithapCutoredUcescriptexecutiontime.2)实现databasequerycachingusingpdotominiminimizedatabasehits.3)usehttp/2tomultiplexrequlexrequestsandredececonnection.4 limitsclection.4.4

依赖注入(DI)通过显式传递依赖关系,显着提升了PHP代码的可测试性。 1)DI解耦类与具体实现,使测试和维护更灵活。 2)三种类型中,构造函数注入明确表达依赖,保持状态一致。 3)使用DI容器管理复杂依赖,提升代码质量和开发效率。

databasequeryOptimizationinphpinvolVolVOLVESEVERSEVERSTRATEMIESOENHANCEPERANCE.1)SELECTONLYNLYNESSERSAYCOLUMNSTORMONTOUMTOUNSOUDSATATATATATATATATATATRANSFER.3)


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

记事本++7.3.1
好用且免费的代码编辑器

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。