利用查询来创建新表的限制
2009-06-01 13:16:12 来源:WEB开发网在Oracle数据库中,可以利用Create Table语句中嵌套子查询来实现基于已有的表或者视图来创建新表。这个功能可能对于大部分用户来说,不会感到陌生。但是在使用这个语句的过程中,需要遵循哪些限制条件呢?对于这一点,可能不少数据库管理员没有一个清晰的认识。为此,笔者就在这里给大家总结一下,利用查询来创建表时需要遵守的一些限制。
限制条件一:不能够改变数据类型与长度。
在利用子查询来创建新表的时候,数据库管理员可以修改新表中列的名称,但是不能够修改列的数据类型和长度。新表中所有列的数据类型和长度必须与查询列一致。如数据库管理员从一个员工信息表中获取员工姓名、员工出生日期等信息创建一个新表。如果在员工信息表中员工出生日期是一个日期型的字段,那么在新表中就必须也是日期型的数据类型。在创建新表的过程中,数据库管理员不能够修改数据类型。
那么如果系统管理员需要更改数据类型,如想把日期型的数据调整为字符型的数据,难道就没有其他办法了吗?其实,通过一些其他方法,这个需求仍然可以实现。上面的限制条件说,新表中的数据类型必须与查询列中的数据类型相同,而不是说跟基表中的数据类型相同。为此如果数据库管理员想要把日期型的数据(基表中的数据类型)调整为字符型的数据类型(新表中的数据类型),那么只需要在查询语句中,利用日期字符转换函数,将日期型的数据转换为字符型的数据即可。在创建新表时,数据类型是以查询列为准,而不是以基表中列的数据类型为准。所以通过在查询语句中使用数据类型转换函数,就可以改变新表中的数据类型。
限制条件二:不能够复制约束条件与列的默认值。
在基表中,可能某些字段有约束条件,如唯一性约束等等。某些字段也可能设置了默认值,如系统的当前时间等等。但是,如果利用子查询来创建信标的话,那么这些字段的约束条件、默认值等等都不会在新表中体现出来。也就是说,这些内容需要数据库管理员在新表创建后手工重新建立。如果有需要的话,要对照基表的约束条件与默认值,分别在新表的字段中进行定义。这个没有取巧的方法。至少到限制为止,笔者还没有找到可以利用其他方法来突破这个限制。为此数据库管理员在利用子查询来创建这个新表的时候,要特别注意这个约束条件。特别是默认值,不少管理员在利用这个方法创建新表后,会忘记重新设置相关列的默认值。
更多精彩
赞助商链接