搜索
系统检测到您的用户名不符合规范:

实现利用ThinkPHP中定义的model直接创建表

浏览:8400 发布日期:2014年07月01日 分类:系统代码 关键字: sql createTable
方便调试测试,或者做实验
Model.Class.PHP
DB.Class.PHP
两个文件中增加了createTable的代码
使用示例:
$user = D('object');
$return = $user->createTable();
Model.Class.PHP 增加以下代码
/**
* 创建表
* @access public
*/
public function createTable()
{
$fields = $this->fields;
if(empty($fields))
{
return false;
}
$types = $fields["_type"];
if(empty($types))
{
return false;
}
$mainKey = $fields["_pk"];
unset($fields["_type"]);
unset($fields["_pk"]);
$fields = array_values($fields);
if(count($fields) != count($types))
{
return false;
}
$options = array();
$options = $this->_parseOptions($options);
return $this->db->createTable($options,$fields, $types, $mainKey);
}

DB.Class.PHP 增加以下代码
/**
* 创建表
* @access public
*/
public function createTable($options,$files,$types,$mainKey)
{
$this->model = $options['model'];
$sql = "CREATE TABLE ".$this->parseTable($options['table'])."(";
$types = $this->parseTypes($types);
if($types === false)
{
log("functrion createTable,类型错误,请检查".$this->model.".class.php数据模型定义");
return false;
}
$hasMainKey = false;
$i=1;
$count = count($files);
foreach($files as &$value)
{
$sql .= $value . " " . $types[$value];
if($value === $mainKey)
{
$hasMainKey = true;
$sql .= " PRIMARY KEY";
}
if($i < $count)
{
$sql .= ",";
}
++$i;
}
unset($value);
$sql .= ")";
if(!$hasMainKey && !empty($mainKey))
{
log("functrion createTable,定义的主键名未包含在列名中");
return false;
}
return $this->execute($sql);
}
评论() 相关
后面还有条评论,
评论支持使用[code][/code]标签添加代码
您需要登录后才可以评论 登录 | 立即注册
收藏
wudijimao
积分:114 等级:LV1
热点推荐
(追記) (追記ここまで)
最新更新

我们

合作

网站

信息

ThinkPHP 是一个免费开源的,快速、简单的面向对象的 轻量级PHP开发框架 ,创立于2006年初,遵循Apache2开源协议发布,是为了敏捷WEB应用开发和简化企业应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长为国内最领先和最具影响力的WEB应用开发框架,众多的典型案例确保可以稳定用于商业以及门户级的开发。

AltStyle によって変換されたページ (->オリジナル) /