返回首页

gbase数据、南大通用产品文档:GBase8a_t_gcluster_add_limit_in_exists_optimization

更新日期:2024年09月11日

取值:[0|1]
默认值:1
说明:为exists 子查询增加limit 1,以提升性能。默认打开。
修改方式:
可使用set 语句修改值也可在配置文件中修改值。
适用于session、
global
范围均可。

SQLAllocStmt
在ODBC 3.x 版本中,ODBC 2.x 的函数SQLAllocStmt 已被SQLAllocHandle 代替。有
关详细信息请参阅8.2.3 SQLAllocHandle。

使用 DROP ROW TYPE 语句从数据库中删除现有的名为 ROW 的数据类型。
该语句是 SQL ANSI/ISO 标准的扩展。
语法

GBase 8s SQL 指南:语法
南大通用数据技术股份有限公司 581

元素
描述
限制
语法
owner
ROW 类型所有者的名称
必须是 row_type 的
所有者
所有者名称
row_type 要删除的现有的 ROW 数
据类型的名称
必须存在。另见后面
的用法部分
标识符; 数据
类型
用法
DROP ROW TYPE 语句从 sysxtdtypes 系统目录表中删除指定 row_type 的条
目。您必须是指定名称的 ROW 数据类型的所有者或具有 DBA 权限才可以 使
用 DROP ROW TYPE 语句。
如果您包含可选的 IF EXISTS 关键字,则没有指定名称的 ROW 数据类型在当
前数据库中存在,则数据库服务器不采取任何操作(而不是向应用程序发送异
常)。
如果一个已命名的 ROW 数据类型的名称正在使用中,则不能删除该数据类型。当
以下的任何条件为真时,不能删除已命名的 ROW 数据类型:

任何现有的表或列正在使用已命名的 ROW 数据类型。

已命名的 ROW 数据类型在继承层次结构中是超类型。

在已命名的 ROW 数据类型的列上定义了视图。
要从表中删除名为 ROW 类型的列,请使用 ALTER TABLE。
DROP ROW TYPE 语句不能删除未命名的 ROW 数据类型。
RESTRICT 关键字
RESTRICT 关键字要求同 DROP ROW TYPE 语句使用。如果 row_type 上的从
属性存在,则 RESTRICT 会引起 DROP ROW TYPE 失败。
如果以下任一条件为真,则 DROP ROW TYPE 语句失败并返回错误消息:

已命名的 ROW 数据类型用于现有的表或列。

GBase 8s SQL 指南:语法
南大通用数据技术股份有限公司 582
查看 systables 和 syscolumns 系统目录表来查找是否任何表或数据类型
使用了已命名的 ROW 数据类型。

已命名的 ROW 数据类型在继承层次结构中是超类型。
查找 sysinherits 系统目录表来查看哪一个已命名的ROW 数据类型具有
子类型。
以下语句删除了已命名的 ROW 数据类型 employee_t:
DROP ROW TYPE employee_t RESTRICT