怎么用SQL语句获取指定数据库中的所有表名
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么用SQL语句获取指定数据库中的所有表名相关的知识,希望对你有一定的参考价值。
用Sql Server数据库数据库名为test里面有两张表student, course然后我想用SQL语句查找test数据库中所有表的表名,请问怎么实现。
方法如下,以oracle为例:select * from all_tables WHERE owner=\'SCOTT\' ;或者
SELECT * FROM DBA_TABLES WHERE OWNER=\'SCOTT\';
数据字典视图
表和列
DBA_TABLES、ALL_TABLES和USER_TABLES显示了有关数据库表的一般信息。
DBA_TAB_COLUMNS、ALL_TAB_COLUMNS和USER_TAB_COLUMNS显示了每个数据库表的列的信息。
注意:DBA_OBJECTS、ALL_OBJECTS和USER_OBJECTS显示了模式对象的信息,包括表。 参考技术A Select Name FROM SysObjects Where XType='U' orDER BY Name执行这句话就行了~ 参考技术B select Name from 数据库名称(sysobjects) where xtype='u' and status>=0 参考技术C use testselect name from sysobjects where xtype = 'u'
用SQL语句怎么删除表中的所有数据?
参考技术A从一个表中删除数据,使用DELETE语句。从表中删除所有行
DELETE FROM table_name;
或DELETE * FROM table_name;
或DELETE FROM Customers
WHERE cust_id = '10000006';
DELETE不需要列名和通配符,它是删除整行而不是删除列,要删除指定的列,请使用update语句;并且DELETE语句从表中删除行,甚至是删除表中所有行,而不是删除表本身。
如果想删除表中的所有行,可以使用TRUNCATE TABLE语句,完成相同的工作,而速度更快。
扩展资料
drop直接删掉表。
truncate删除的是表中的数据,再插入数据时自增长的数据id又重新从1开始。
delete删除表中数据,可以在后面添加where字句
(1)DELETE语句执行删除操作的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作。TRUNCATE TABLE 则一次性地从表中删除所有的数据并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。
(2) 表和索引所占空间。当表被TRUNCATE 后,这个表和索引所占用的空间会恢复到初始大小,而DELETE操作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。
(3) 一般而言,drop > truncate > delete
(4) 应用范围。TRUNCATE 只能对TABLE;DELETE可以是table和view
(5) TRUNCATE 和DELETE只删除数据,而DROP则删除整个表(结构和数据)。
(6) truncate与不带where的delete :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留,但其状态会变为:invalid。
参考资料: 百度百科 sql
以上是关于怎么用SQL语句获取指定数据库中的所有表名的主要内容,如果未能解决你的问题,请参考以下文章