免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1111 | 回复: 0
打印 上一主题 下一主题

oracle学习步骤2_应用3(查询表,表结构) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-23 02:10 |只看该作者 |倒序浏览
可以查询user_tabless,里面有个num_rows列
SQL的语句是:select table_name,num_rows from user_tables
不过提醒下,num_rows列并不是实时更新的,要想比较精确的结果查新之前最好先ANALYZE下analyze table xxx compute statistics;但是对于数据库来说,随便ANALYZE并不好,会改变一些策略
所以统计信息还是要count(*),不想用各种触发器,函数的我用了一个很鹾的办法,先用
SELECT 'SELECT ''' ||TABLE_NAME||''',COUNT(*)  FROM '||TABLE_NAME||' union all' FROM USER_TABLES;生成每个表的count(*)的查询语句,再把查出的结果再运行一遍,就可以得出想要的结果了

附Oracle中查看所有的表,用户表,列名,主键,外键的方法:
引用http://www.cntxk.com/CataNews/64/info9872.html
在Oracle中查看所有的表:
select * from tab/dba_tables/dba_objects/cat;
看用户建立的表 : 
select table_name from user_tables;  //当前用户的表
select table_name from all_tables;  //所有用户的表
select table_name from dba_tables;  //包括系统表
select * from user_indexes //可以查询出所有的用户表索引

查所有用户的表在all_tables
主键名称、外键在all_constraints
索引在all_indexes
但主键也会成为索引,所以主键也会在all_indexes里面。
具体需要的字段可以DESC下这几个view,dba登陆的话可以把all换成dba

1、查找表的所有索引(包括索引名,类型,构成列):
select t.*,i.index_type from user_ind_columns t,user_indexes i where t.index_name = i.index_name and t.table_name = i.table_name and t.table_name = 要查询的表
2、查找表的主键(包括名称,构成列):
select cu.* from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'P' and au.table_name = 要查询的表
3、查找表的唯一性约束(包括名称,构成列):
select column_name from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'U' and au.table_name = 要查询的表
4、查找表的外键(包括名称,引用表的表名和对应的键名,下面是分成多步查询):
select * from user_constraints c where c.constraint_type = 'R' and c.table_name = 要查询的表
查询外键约束的列名:
select * from user_cons_columns cl where cl.constraint_name = 外键名称
查询引用表的键的列名:
select * from user_cons_columns cl where cl.constraint_name = 外键引用表的键名
5、查询表的所有列及其属性
select t.*,c.COMMENTS from user_tab_columns t,user_col_comments c where t.table_name = c.table_name and t.column_name = c.column_name and t.table_name = 要查询的表
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP