PHP FOR MYSQL 代码生成助手(根据Mysql里的字段自动生成类文件的)


Posted in PHP onJuly 23, 2011

根据 Mysql 里的字段 自动生成 类文件:

但需要导入:

require_once ./db/ez_sql_core.php;
require_once ./db/ez_sql_mysql.php;

帮助文档:http://jvmultimedia.com/docs/ezsql/ez_sql_help.htm 

上图 :

PHP FOR MYSQL 代码生成助手(根据Mysql里的字段自动生成类文件的)

核心代码:

<?php 
class db{ 
/********************************************************************** 
* Author: fangjun (fangjunai@163.com) 
* Name..: PHP_For_MySQL_Helper v1.0 
* Desc..: 自动生成数据库操作类 
* Date..: 2011-7-22 
/**********************************************************************/ 
private $db_server = 'localhost'; 
private $db_username = 'root'; 
private $db_password = ''; 
private $primary_key = null; 
//初始化 
public function __construct(){ 
$this->db_conn = mysql_connect($this->db_server,$this->db_username,$this->db_password) or die('Error:'.mysql_error()); 
} 
//返回所以的数据库名称 
public function db_list(){ 
$databasename = array(); 
$i=0; 
$list = mysql_list_dbs($this->db_conn); 
while ($row = mysql_fetch_object($list)) { 
$databasename[$i] = $row->Database; 
$i++; 
} 
mysql_close(); 
return $databasename; 
} 
//返回所以的数据库名称 
public function table_list($databasename){ 
$tablename = array(); 
$i=0; 
$result = @mysql_list_tables($databasename); 
while($row = mysql_fetch_array($result,MYSQL_NUM)){ 
$tablename[$i] = $row[0]; 
$i++; 
} 
mysql_free_result($result); 
mysql_close(); 
return $tablename; 
} 
//返回表里的字段 
public function field_list($databasename,$tablename){ 
$fieldname = array(); 
$v = 0; 
mysql_select_db($databasename,$this->db_conn); 
$rel = mysql_query("select * from ".$tablename); 
for($i=0;$i<mysql_num_fields($rel);$i++){ 
$meta = mysql_fetch_field($rel); 
if($meta){ 
if($meta->primary_key==1){ 
$this->primary_key = $meta->name; 
}else{ 
$fieldname[$v] = $meta->name; 
$v++; 
} 
} 
} 
mysql_close(); 
return $fieldname; 
} 
public function showclass($databasename,$tablename){ 
$field = $this->field_list($databasename,$tablename); 
$this->primary_key; 
$key = null; 
$val = null; 
$sql = null; 
$tmp = null; 
$html = '////////////////////////////////////<br/>'; 
$html = $html.'//使用方法<br/>'; 
$html = $html.'// 导入<br/>'; 
$html = $html.'// ez_sql:http://jvmultimedia.com/docs/ezsql/ez_sql_help.htm'; 
$html = $html.'// require_once \'./db/ez_sql_core.php;<br/>'; 
$html = $html.'// require_once \'./db/ez_sql_mysql.php;<br/>'; 
$html = $html.'// $db = new ezSQL_mysql($cfg_db_user,$cfg_db_pass,$cfg_db_name,$cfg_db_host);<br/>'; 
$html = $html.'// $db->query(\'set names utf8\');<br/>'; 
$html = $html.'// 调用<br/>'; 
$html = $html.'// $forum = new Forum($db);<br/>'; 
$html = $html.'// $forum->save($Posts);<br/>'; 
$html = $html.'////////////////////////////////////<br/><br/><br/>'; 
$html = $html.'// 作者:<br/>'; 
$html = $html.'// 备注:<br/>'; 
$html = $html.'// 创建时间:'.date('Y-m-d H:i:s').'<br/>'; 
$html = $html.'<PRE> class '.$tablename.'{<br/>'; 
$html = $html.'<br/>'; 
$html = $html.' private $db'; 
$html = $html.'<br/>'; 
$html = $html.'<br/>'; 
$html = $html.' //实例化 <br/>'; 
$html = $html.' public function '.$tablename.'($db){<br/>'; 
$html = $html.' $this->db = $db;<br/>'; 
$html = $html.' }<br/>'; 
$html = $html.'<br/>'; 
$html = $html.' //保存记录<br/>'; 
$html = $html.' public function save($arry){<br/>'; 
for($i=0;$i<count($field);$i++){ 
$key = $key.$field[$i].','; 
$val = $val.'\'{$arry['.$field[$i].']}\','; 
} 
$sql = "\"insert into ".$tablename." (".rtrim($key,",").")values(".rtrim($val,",").")\""; 
$html = $html.' $sql='.$sql.';<br/>'; 
$html = $html.' return $this->db->query($sql);<br/>'; 
$html = $html.' }<br/>'; 
$html = $html.'<br/>'; 
$html = $html.' //根据主键更新记录 <br/>'; 
$html = $html.' public function update($arry){<br/>'; 
for($i=0;$i<count($field);$i++){ 
$tmp = $tmp.$field[$i].'=\'{$arry['.$field[$i].']}\','; 
} 
$sql = "\"update ".$tablename." set ".rtrim($tmp,",")." where ".$this->primary_key.'=".$arry['.$this->primary_key.']'; 
$html = $html.' $sql='.$sql.';<br/>'; 
$html = $html.' return $this->db->query($sql);<br/>'; 
$html = $html.' }<br/>'; 
//PostID='{$Posts['PostID']}'"; 
$html = $html.'<br/>'; 
$html = $html.' //根据主键删除记录 <br/>'; 
$html = $html.' public function delete($'.$this->primary_key.'){<br/>'; 
$sql = "\"delete from ".$tablename." where ".$this->primary_key."=\".$".$this->primary_key; 
$html = $html.' $sql='.$sql.';<br/>'; 
$html = $html.' return $this->db->query($sql);<br/>'; 
$html = $html.' }<br/>'; 
$html = $html.'<br/>'; 
$html = $html.' //根据主键查询一条记录 <br/>'; 
$html = $html.' public function getQueryById($'.$this->primary_key.'){<br/>'; 
$sql = "\"select * from ".$tablename." where ".$this->primary_key."=\".$".$this->primary_key; 
$html = $html.' $sql='.$sql.';<br/>'; 
$html = $html.' return $this->db->get_row($sql);<br/>'; 
$html = $html.' }<br/>'; 
$html = $html.'<br/>'; 
$html = $html.' //查询全部记录 <br/>'; 
$html = $html.' public function getQuery(){<br/>'; 
$sql = "\"select * from ".$tablename."\""; 
$html = $html.' $sql='.$sql.';<br/>'; 
$html = $html.' return $this->db->get_results($sql);<br/>'; 
$html = $html.' }<br/>'; 
$html = $html.'<br/>'; 
$html = $html.'<br/>'; 
$html = $html.'}</PRE>'; 
echo $html; 
} 
} 
?> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title> PHP For MySQL Helper v1.0 </title> 
<style> 
body{ font-size:14px;} 
h3{ padding:0px; margin:0px; background-color:#333; color:#FFF;font-size:14px; } 
.dblist,.tablelist,.show{width:100%;padding:10px 0;} 
a:link {} 
a:hover {color:#F00} 
</style> 
</head> 
<body> 
<?php 
ini_set('default_charset', 'utf-8'); 
echo '<div class=\'dblist\'>'; 
echo '<h3>请选择数据库</h3>'; 
//----------------------------------- 
$DB = new db(); 
$dblist = $DB->db_list(); 
for ($row=0;$row<count($dblist);$row++){ 
echo '<a href="?databasename='.$dblist[$row].'">'.$dblist[$row].'</a><br/>'; 
} 
//----------------------------------- 
echo '</div>'; 
echo '<div class=\'tablelist\'>'; 
echo '<h3>请选择表</h3>'; 
//----------------------------------- 
if(isset($_GET['databasename'])){ 
$databasename = $_GET['databasename']; 
$DB = new db(); 
$tablelist = $DB->table_list($databasename); 
for ($i=0;$i<count($tablelist);$i++){ 
echo '<a href="db.php?databasename='.$databasename.'&tablename='.$tablelist[$i].'">'.$tablelist[$i].'</a><br/>'; 
} 
} 
//----------------------------------- 
echo '</div>'; 
echo '<div class=\'show\'>'; 
echo '<h3>自动生成数据类</h3>'; 
//----------------------------------- 
if(isset($_GET['databasename'])&& isset($_GET['tablename'])){ 
$databasename = $_GET['databasename']; 
$tablename = $_GET['tablename']; 
$DB = new db(); 
$DB->showclass($databasename,$tablename); 
} 
//----------------------------------- 
echo '</div>'; 
?> 
</body> 
</html>

代码打包下载
PHP 相关文章推荐
据说是雅虎的一份PHP面试题附答案
Jan 07 PHP
PHP setcookie指定domain参数后,在IE下设置cookie失效的解决方法
Sep 09 PHP
需要注意的几个PHP漏洞小结
Feb 05 PHP
PHP中return 和 exit 、break和contiue 区别与用法
Apr 09 PHP
PHP curl 获取响应的状态码的方法
Jan 13 PHP
php 伪静态之IIS篇
Jun 02 PHP
php调用nginx的mod_zip模块打包ZIP文件
Jun 11 PHP
php递归json类实例
Dec 02 PHP
PHP实现的购物车类实例
Jun 17 PHP
Zend Framework实现具有基本功能的留言本(附demo源码下载)
Mar 22 PHP
支持汉转拼和拼音分词的PHP中文工具类ChineseUtil
Feb 23 PHP
php代码调试利器firephp安装与使用方法分析
Aug 21 PHP
php文档更新介绍
Jul 22 #PHP
php 数据库字段复用的基本原理与示例
Jul 22 #PHP
PHP查询MySQL大量数据的时候内存占用分析
Jul 22 #PHP
PHP性能优化 产生高度优化代码
Jul 22 #PHP
PHP多个版本的分析解释
Jul 21 #PHP
QQ登录 PHP OAuth示例代码
Jul 20 #PHP
模板引擎正则表达式调试小技巧
Jul 20 #PHP
You might like
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
2012/06/17 PHP
ThinkPHP访问不存在的模块跳转到404页面的方法
2014/06/19 PHP
php禁止浏览器使用缓存页面的方法
2014/11/07 PHP
php中动态变量用法实例
2015/06/10 PHP
php实现无限级分类(递归方法)
2015/08/06 PHP
利用laravel搭建一个迷你博客实战教程
2017/08/13 PHP
jQuery 源码分析笔记(7) Queue
2011/06/19 Javascript
js函数setTimeout延迟执行的简单介绍
2013/07/17 Javascript
jquery 合并内容相同的单元格(示例代码)
2013/12/13 Javascript
jQuery实现dialog设置focus焦点的方法
2015/06/10 Javascript
跟我学习javascript的循环
2015/11/18 Javascript
nodejs搭建本地服务器并访问文件的方法
2017/03/03 NodeJs
js实现下一页页码效果
2017/03/07 Javascript
vue2.0项目中使用Ueditor富文本编辑器示例代码
2017/08/14 Javascript
详谈Node.js之操作文件系统
2017/08/29 Javascript
vue全局组件与局部组件使用方法详解
2018/03/29 Javascript
Python多线程编程(二):启动线程的两种方法
2015/04/05 Python
python实现杨辉三角思路
2017/07/14 Python
django加载本地html的方法
2018/05/27 Python
使用python读取csv文件快速插入数据库的实例
2018/06/21 Python
python用opencv批量截取图像指定区域的方法
2019/01/24 Python
Python利用神经网络解决非线性回归问题实例详解
2019/07/19 Python
python实现tail实时查看服务器日志示例
2019/12/24 Python
python中使用you-get库批量在线下载bilibili视频的教程
2020/03/10 Python
Python3 中sorted() 函数的用法
2020/03/24 Python
Python3 ID3决策树判断申请贷款是否成功的实现代码
2020/05/21 Python
学习Python需要哪些工具
2020/09/04 Python
美国维生素、补充剂、保健食品购物网站:Vitacost
2016/08/05 全球购物
大学生个人求职信范文
2013/09/21 职场文书
医院搬迁方案
2014/06/14 职场文书
励志演讲稿200字
2014/08/21 职场文书
领导班子遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
机关作风建设整改方案
2014/10/27 职场文书
群众路线教育实践活动心得体会(教师)
2014/10/31 职场文书
一般基层干部群众路线教育实践活动个人对照检查材料
2014/11/04 职场文书
Android基础入门之dataBinding的简单使用教程
2022/06/21 Java/Android