CPgsqlColumnSchema
| 包 | system.db.schema.pgsql |
|---|---|
| 继承 | class CPgsqlColumnSchema » CDbColumnSchema » CComponent |
| 源自 | 1.0 |
| 版本 | $Id: CPgsqlColumnSchema.php 2799 2011-01-01 19:31:13Z qiang.xue $ |
| 源码 | framework/db/schema/pgsql/CPgsqlColumnSchema.php |
CPgsqlColumnSchema描述PostgreSQL表的列元数据。
公共属性
| 属性 | 类型 | 描述 | 定义在 |
|---|---|---|---|
| allowNull | boolean | 该列是否可以为null | CDbColumnSchema |
| autoIncrement | boolean | 该列是否为自增列 | CDbColumnSchema |
| dbType | string | 该列的数据类型。 | CDbColumnSchema |
| defaultValue | mixed | 该列的默认值 | CDbColumnSchema |
| isForeignKey | boolean | 该列是否为外键 | CDbColumnSchema |
| isPrimaryKey | boolean | 该列是否为主键 | CDbColumnSchema |
| name | string | 列名(无引号)。 | CDbColumnSchema |
| precision | integer | 该列数据的精度,若它是一个数。 | CDbColumnSchema |
| rawName | string | 原始列名。它被引用了以便在SQL查询中使用。 | CDbColumnSchema |
| scale | integer | 该列数据的规模,若它是一个数。 | CDbColumnSchema |
| size | integer | 该列的大小。 | CDbColumnSchema |
| type | string | 该列的HP类型。 | CDbColumnSchema |
公共方法
受保护方法
| 方法 | 描述 | 定义在 |
|---|---|---|
| extractDefault() | 提取列的默认值。 | CPgsqlColumnSchema |
| extractLimit() | 从列类型中提取大小、精确度和规模。 | CDbColumnSchema |
| extractType() | 从数据类型中提取PHP类型。 | CPgsqlColumnSchema |
方法详细
extractDefault()
方法
|
protected void extractDefault(mixed $defaultValue)
| ||
| $defaultValue | mixed | 从元数据中获得的默认值。 |
源码: framework/db/schema/pgsql/CPgsqlColumnSchema.php#44 (显示)
protected function extractDefault($defaultValue)
{
if($defaultValue==='true')
$this->defaultValue=true;
else if($defaultValue==='false')
$this->defaultValue=false;
else if(strpos($defaultValue,'nextval')===0)
$this->defaultValue=null;
else if(preg_match('/^\'(.*)\'::/',$defaultValue,$matches))
$this->defaultValue=$this->typecast(str_replace("''","'",$matches[1]));
else if(preg_match('/^-?\d+(\.\d*)?$/',$defaultValue,$matches))
$this->defaultValue=$this->typecast($defaultValue);
// else is null
}
提取列的默认值。 该值会被转换到正确的PHP类型。
extractType()
方法
|
protected void extractType(string $dbType)
| ||
| $dbType | string | 数据类型 |
源码: framework/db/schema/pgsql/CPgsqlColumnSchema.php#25 (显示)
protected function extractType($dbType)
{
if(strpos($dbType,'[')!==false || strpos($dbType,'char')!==false || strpos($dbType,'text')!==false)
$this->type='string';
else if(strpos($dbType,'bool')!==false)
$this->type='boolean';
else if(preg_match('/(real|float|double)/',$dbType))
$this->type='double';
else if(preg_match('/(integer|oid|serial|smallint)/',$dbType))
$this->type='integer';
else
$this->type='string';
}
从数据类型中提取PHP类型。