select pg_constraint.conname as pk_name from pg_constraint inner join pg_class
on pg_constraint.conrelid = pg_class.oid where pg_class.relname = 'yourtablename' and pg_constraint.contype='p'
这个可以显示yourtablename表的主键
select pg_constraint.conname as pk_name,pg_attribute.attname as colname,pg_type.typname as typename from
pg_constraint inner join pg_class
on pg_constraint.conrelid = pg_class.oid
inner join pg_attribute on pg_attribute.attrelid = pg_class.oid
and pg_attribute.attnum = pg_constraint.conkey[1]
inner join pg_type on pg_type.oid = pg_attribute.atttypid
where pg_class.relname = 'yourtablename'
and pg_constraint.contype='p'
这个可以显示出主键名,和主键关联的字段名,和字段名类型
postgresql的pl/pgsql语言是支持动态sql语句的(说execute immediate的是ecpg所支持的)。但是,要记得重要的一点: 是在pl/pgsql语言中支持。而pl/pgsql语言一个块结构的语言,它以begin ... end为块的开始与结束标识。这也就是说,要执行动态sql语句,就必须放到begin ... end块中,而不要想实现一个单独的动态sql语句。在sql server中,倒是可以轻松的实现,我们可以直接执行一个这样的动态sql:
execute?sp_executesql?n'select?1?as?val'而在postgresql中,就不要有此想法了。当然,sql server的这种动态sql语句的执行方法也有其局限与不便的地方。
在pl/pgsql中,执行动态sql的格式如下(摘录自说明文档):
execute?command-string?[?into?[strict]?target?]?[?using?expression?[,?...?]?];其中,
command-string就是要执行的动态sql语句(一定要记住:这里是sql语句,不是pl/pgsql语句,像raise notice就不能使用);
into子句是把sql查询到的值赋给into指定的变量;
using子句是前面的command-string中替代变量($1, $2, ...)的赋值;
示例:
do?$$
declare
v_c1?integer;
v_c2?integer;
begin
execute?'select?count(*)?as?c1,?count(*)?as?c2?from?(select?1?as?idx?union?select?11?as?idx?union?select?21?as?idx)?s?where?idx?>?$1'?
into?v_c1,?v_c2
using?10;
raise?notice?'%,?%',?v_c1,?v_c2;
可以通过系统表来获取这些信息
什么数据库呢
你会用PLSQL Developer吗 你说的这些要求 这个工具能完成 直接右键点你的表 选择viwe 就可以清楚的看到你所需要的东西了 如果没有PLSQL Developer就按这个名字去网上下一个很小 安装很简单
用户登录
还没有账号?立即注册
用户注册
投稿取消
文章分类: |
|
还能输入300字
上传中....