189 8069 5689

sqlserver带的表,sql server保存表

如何查询一个SqlServer数据库中有哪些表格?

当我们建立Sql Server 连接之后,可以通过如下语句得到当前Sql server中所有的数据的名称:

创新互联建站是一家专注于成都网站设计、网站建设与策划设计,永昌网站建设哪家好?创新互联建站做网站,专注于网站建设十多年,网设计领域的专业建站公司;建站业务涵盖:永昌等地区。永昌做网站价格咨询:028-86922220

use master

select [name] from [sysdatabases] order by [name]

go

我们通过查询其中一个数据库aspnetpager,就可以得到这个数据库中的所有的表名了,语句如下:

use aspnetpager

select [id], [name] from [sysobjects] where [type] = 'u' order by [name]

为什么我用SQLServer创建数据库时,里面自带一些表,并且删除不了?

这些是系统带的一些表格,不用管它,这些是记录操作记录,历史文件数据什么的,不用理.也不让删

查看sqlserver数据库有哪些表

--查询数据库里所有表名和字段名的语句

--SQL

查询所有表名:

SELECT

NAME

FROM

SYSOBJECTS

WHERE

TYPE='U'

SELECT

*

FROM

INFORMATION_SCHEMA.TABLES

--查询表的所有字段名:

SELECT

NAME

FROM

SYSCOLUMNS

WHERE

ID=OBJECT_ID('

表名'

)

SELECT

*

FROM

INFORMATION_SCHEMA.TABLES

SELECT

*

FROM

INFORMATION_SCHEMA.VIEWS

SELECT

*

FROM

INFORMATION_SCHEMA.COLUMNS

---------以下为其他数据库查询表----------

--ORACLE

查看所有表名:

SELECT

TABLE_NAME

FROM

USER_TABLES

--ACCESS

查看所有表名:

SELECT

NAME

FROM

MSYSOBJECTS

WHERE

TYPE=1

AND

FLAGS=0

--MSYSOBJECTS

是系统对象,默认情况是隐藏的。通过工具、选项、视图、显示、系统对象可以使之显示出来。

sqlserver查询数据库中有多少个表

1、查询SQL中的所有表:SelectTABLE_NAMEFROM数据库名称.INFORMATION_SCHEMA.TABLESWhereTABLE_TYPE='BASETABLE'执行之后,就可以看到数据库中所有属于自己建的表的名称2、查询SQL中所有表及列:Selectdbo.sysobjects.nameasTable_name,dbo.syscolumns.nameASColumn_nameFROMdbo.syscolumnsINNERJOINdbo.sysobjectsONdbo.syscolumns.id=dbo.sysobjects.idWhere(dbo.sysobjects.xtype='u')AND(NOT(dbo.sysobjects.nameLIKE'dtproperties'))3、在Sql查询分析器,还有一个简单的查询方法:EXECsp_MSforeachtable@command1="sp_spaceused'?'"执行完之后,就可以看到数据库中所有用户表的信息4、查询总存储过程数:selectcount(*)总存储过程数fromsysobjectswherextype='p'附:xtype类型D=默认值或DEFAULT约束F=FOREIGNKEY约束L=日志FN=标量函数IF=内嵌表函数P=存储过程PK=PRIMARYKEY约束(类型是K)RF=复制筛选存储过程S=系统表TF=表函数TR=触发器U=用户表UQ=UNIQUE约束(类型是K)V=视图X=扩展存储过程另:在sqlserver中取得某个数据库中所有表名的sql语句selectsysobjects.namefromsysobjects.xtype='U';SELECTnameWHERE(xtype='U')在数据库的sysobjects表里有这个数据库全部表的信息,xtype值为'U'的就是表名注意:一般通过上述方法获得全部用户表示都会有一个dtproperties表,SQLSERVER默认它也是用户表,想要从用户表中排出,需要加上限定条件status0,即:select*fromsysobjectswherextype='U'andstatus0

sqlserver的系统表

1、查看表和试图

SELECT * FROM sys.objects WHERE object_id = object_id('表名或视图名')

在sqlserver中一般可通过查询sys.objects系统表来得知结果,不过可以有更方便的方法

如下:

if object_id('tb_table') is not null

print 'exist'

else

print'not exist'

如上,可用object_id()来快速达到相同的目的,tb_table就是我将要创建的资源的名称,所以要先判断当前数据库中不存在相同的资源

object_id()可接受两个参数,第一个如上所示,代表资源的名称,上面的就是表的名字,但往往我们要说明我们所要创建的是什么类型的资源,

这样sql可以明确地在一种类型的资源中查找是否有重复的名字,如下:

if object_id('tb_table','u') is not null

print 'exist'

else

print'not exist'

第二个参数 "u" 就表示tb_table是用户创建的表,即:USER_TABLE地首字母简写

查询sys.objects中可得到各种资源的类型名称(TYPE列),这里之举几个主要的例子

u ----------- 用户创建的表,区别于系统表(USER_TABLE)

s ----------- 系统表(SYSTEM_TABLE)

v ----------- 视图(VIEW)

p ----------- 存储过程(SQL_STORED_PROCEDURE)

2、查看表的列名

select * from syscolumns where id=object_id('表名') and name='列名'

3、查看数据库

select * from sys.databases where name = 'student'

4、查看备份设备

"select * from sys.backup_devices where name ='backupdb'

(添加备份设备:exec sp_addumpdevice 'disk','backupdb','d:\\backup\\backupdb.bak')

5、查看数据文件

select name, physical_name dbfile from sys.master_files where database_id=db_id('student')

master数据库中sysdatabases表(是sqlserver中所有的数据库的库名) :

如果你要查询的是所有数据库(用户/系统):

select * from master..sysdatabases

如果你要查询的是用户数据库,则使用:

select * from master..sysdatabases where dbid 4

如果你要查询的是系统数据库,只需要把where字句改为dbid 4即可。

6、查看执行的sql语句

SELECT cacheobjtype,objtype,usecounts,sql

from sys.syscacheobjects where sql not like'%cach%' and sql not like '%sys.%'

2.对应数据库中sysobjects表(反应的是相应数据库中所有的对象):

这个表的用处是最大的,因为它里面存放的有:表(系统/用户)、存储过程(系统/用户)、视图、主键、外键等。

这里就不一一说明了。

比如你sqlserver中有个数据库名叫 test,如果要查询该数据库中的所有表对象:

select * from test..sysobjects where type = ’u’ or type = ’s’

这里的type = ’u’是表示用户表对象,type = ’s’是系统表对象,怎样单独查询用户表对象或者系统表对象就不用说了吧。

如果你要查询的是存储过程当然也分了系统和用户了:

这个是查询数据库中所有存储过程

select * from test..sysobjects where type = ’p’

如果你要查询的是用户存储过程则加上 and category 2 即可。

查询系统存储过程就不用说了吧(category = 2 谁不知道。。。)

查询视图与查询存储过程一样,比如:

你查询的是数据库中所有视图

select * from test..sysobjects where type = ’v’

如果你要查询的是用户视图则加上 and category 2 即可。

其他的就不说了,就把 它们的type给大家说下:

type = ’ pk’ 表示主键。

type = ’ d’ 外键引用。

type = ’uq’ 唯一索引。

下面附录一些常用系统表

名称 地址 说明

sysaltfiles 主数据库 保存数据库的文件

syscharsets 主数据库 字符集与排序顺序

sysconfigures 主数据库 配置选项

syscurconfigs 主数据库 当前配置选项

sysdatabases 主数据库 服务器中的数据库

syslanguages 主数据库 语言

syslogins 主数据库 登陆帐号信息

sysoledbusers 主数据库 链接服务器登陆信息

sysprocesses 主数据库 进程

sysremotelogins主数据库 远程登录帐号

syscolumns 每个数据库 列

sysconstrains 每个数据库 限制

sysfilegroups 每个数据库 文件组

sysfiles 每个数据库 文件

sysforeignkeys 每个数据库 外部关键字

sysindexs 每个数据库 索引

sysmenbers 每个数据库 角色成员

sysobjects 每个数据库 所有数据库对象

syspermissions 每个数据库 权限

systypes 每个数据库 用户定义数据类型

sysusers 每个数据库 用户


新闻标题:sqlserver带的表,sql server保存表
转载来于:http://jkwzsj.com/article/dsipjjd.html

其他资讯