资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

SQLserver对应表,sqlserver 查询表名

查看sqlserver数据库有哪些表

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

网站制作、建网站找专业网站制作公司创新互联建站:定制网站、模板网站、仿站、小程序定制开发、软件开发、成都app软件开发公司等。做网站价格咨询创新互联建站:服务完善、10余年建站、值得信赖!网站制作电话:18980820575

--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数据库中各表之间的关系

sql中表关联的建立方法:

1、最常用的一种:

减少重复数据.表A中拥有外键,表B的数据基本是不允许删除的.这时选择对

INSERT

UPDATE

强制关系即可.

2、其次,是增加一个从属表.

如果表A删除一条记录时,表B中也随着删除一条相关联的记录,那么外键关系中,表A的主键是表B的外键。这种关系,实际上表B是表A的从属表(即表A是父表),选择对

INSERT

UPDATE

强制关系时,如果向表B中插入数据,表A中必须已经存在对应的记录。选择级联删除相关的字段时,删除表A中的一条记录,就会删除对应的表B中的一条记录。

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 每个数据库 用户

Excel里的数据转换datatable后,怎么把datatable里的数据导入sqlserver

1、打开你的SQLserver对应的表,随便检索上1-10条记录,然后把它另存为excel格式列表,此表就是你的一个模板;

2、打开此模板表,再打开你已经转换好的datatable表,让后表按照模板表的格式调整字段次序及对应的值;

3、当把datatable表重新调整好后,再另存为一份;

4、打开SQLserver编辑面板,导入即可。如果出现报错,记录对应的行号,修改或删除excel表中的对应行,再导入。

sqlserver字段模糊查询A表全名对应B表关键字

你好,很高兴能够给你解答问题,给一个mysql写法,

UPDATE test_taba a set a.g="关键字" where EXISTS (SELECT * from test_tabb b WHERE a.addr LIKE CONCAT('%',b.addr,'%'))

test_taba表(id,addr,g列)类似你的A表

test_tabb表(addr)类似B表

希望可以帮助到你


文章标题:SQLserver对应表,sqlserver 查询表名
标题网址:http://cdkjz.cn/article/hogggj.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220