sqlserver用户表
❶ 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_admpdevice '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中如何保证每个用户的表不互相影响
这个你无须担心,数据库本身具备上锁功能,如果一个用户在修改一条语句没有执行完成前,其他用户是无法执行其他操作的。只是他们执行的时间非常快,我们感觉不出来而已
❸ sqlserver 如何去掉用户表名的前缀
-- 对于 SQL Server 2000,表所属的架构与所有者是一致的,更改表的所有者即可
exec sp_changeobjectowner 'Tianqi.[OrdersTable]', 'dbo'
-- 对于 SQL Server 2005,表所属的架构与所有者是分离的,需要将表移动到指定架构下
ALTER SCHEMA dbo TRANSFER [Tianqi].[OrdersTable];
-- 为了管理方便,修改表的所有者
ALTER AUTHORIZATION ON object::[Tianqi].[Tianqi].[OrdersTable] TO SCHEMA OWNER;
❹ sqlserver 怎么查询表属于哪个用户,或者说,某用户名可访问那些表
打开sql管理工具, ——安全性——登录名——右击用户,查看属性——可以看到用户映射几个数据库。
❺ 如何在sqlserver系统表中获得用户表的修改时间,MSSQL,数据库
如果你希望知道用户表的结构的修改时间,
你可以到系统表中去找,比如:sysobjects,syscolumns
如果你希望或者表中数据的修改时间,那么没有的,只有自己维护一个数据修改列,在程序中维护,或者通过触发器维护。
❻ 如图设计SQLServer数据库表,一个基础的用户信息表(不用设计)!
设计成树形的可以,就像行政区域树一样,可以上网查一下,每个职位设置代码,再用代码关联起来的。
❼ 请问SQLServer2005 中的用户名 在哪个系统数据库的什么表中
SELECT
name,
isntname
--1
=
帐户是
Windows
群组或
Windows
使用者
0=SQL
Server
使用者。
FROM
sys.sysusers
WHERE
islogin
=
1
--
1
=
帐户是具有登入帐户的
Windows
群组、Windows
使用者或
SQL
Server
使用者。
AND
hasdbaccess
=
1
--
1
=
帐户有资料库存取权。
AND
(issqluser=1
--
1
=
帐户是
SQL
Server
使用者。
OR
isntname=1)
--
1
=
帐户是应用程式角色。
--或用
SELECT
Name,
type_desc
FROM
sys.database_principals
WHERE
type
IN('S','U','G')
AND
Sid
IS
NOT
null
❽ 在sqlserver里查询的时候,怎么实现多个用户id显示出用户表的用户名
第一个表结构有问题:我理解的应该是id为一个字段,menbers为一个字段(表B的外键)
id menbers(id和menbers为联合主键)
1 1
1 2
1 3
1 6
1 8
2 2
...
我不理解你表A menber字段s是怎能存储的,不是数组吧?这个我不清楚。
查询的时候直接select A.id B.name from A , B where A.menbers = B.id;就行
❾ 如何用sql语句遍历一个用户表,然后在数据表为每个用户添加一条新记录
sql语句遍历一个用户表 涉及到循环操作 ,添加纪录就是简单的insert操作
不同的数据库的稍有不同。
还要处理数据库表主键的不同设置情况。
循环操作+添加操作的案例:(oracle)
1:主键采用自加方式实现
delete from whilestu1;
commit;
DECLARE
num1 number;
maxstuid number;
age number;
begin
num1 := 1;
WHILE num1 <= 100 LOOP
--获取最大的stuid
select max(stuid) + 1 into maxstuid from whilestu1;
--dbms_output.put_line(maxstuid);
if maxstuid is null then
maxstuid := 1;
--dbms_output.put_line('r');
end if;
age := ROUND(DBMS_RANDOM.VALUE(18, 40), 0);
--插入数据
insert into whilestu1
(stuid, stuName, age)
values
(maxstuid, '学员' || cast(maxstuid as varchar2(50)), age);
commit;
num1 := num1 + 1;
END LOOP;
end;
/
2:使用触发器声称主键的方式
CREATE OR REPLACE TRIGGER trg_whilestu2
BEFORE INSERT OR UPDATE OF stuid
ON whilestu2
FOR EACH ROW
BEGIN
IF INSERTING THEN
SELECT SEQ_whilestu2.NEXTVAL INTO :NEW.stuid FROM DUAL;
ELSE
RAISE_APPLICATION_ERROR(-20020, '不允许更新ID值!');
END IF;
END;
/
delete from whilestu2;
select * from whilestu2;
commit;
--select SEQ_whilestu2.Nextval from al;
DECLARE
num1 number;
maxstuid number;
age number;
begin
num1 := 1;
WHILE num1 <= 100 LOOP
age := ROUND(DBMS_RANDOM.VALUE(18, 40), 0);
select SEQ_whilestu2.Currval + 1 into maxstuid from al;
--插入数据
insert into whilestu2
(stuName, age)
values
('学员' || cast(maxstuid as varchar2(50)), age);
commit;
num1 := num1 + 1;
END LOOP;
end;
/
3:使用GUID生成主键的方式
select sys_guid() from al;
DECLARE
num1 number;
--maxstuid number;
age number;
stuid raw(16);
begin
num1 := 1;
WHILE num1 <= 100 LOOP
age := ROUND(DBMS_RANDOM.VALUE(18, 40), 0);
select sys_guid() into stuid from al;
--插入数据
insert into whilestu3
(stuid, stuName, age)
values
(stuid, '学员' || cast(num1 as varchar2(50)), age);
commit;
num1 := num1 + 1;
END LOOP;
end;
/