--------------------我的一点学习笔记(基于2005)----------

---用户定义数据类型
create type postcode
from varchar(6) null  --创建用户定义数据类型
go
select * from information_schema.domains ----获取用户定义数据类型信息
select * from information_schema.column_domain_usage ---查看用户定义数据类型的使用情况
drop type postcode ---删除用户定义数据类型


---同义词
create synonym tb11 for tb ---创建

select * from sys.synonyms   ----查询同义词信息

drop synonym tb11  ---删除


if....else用法

if month(getdate())<7
begin
print('上半年')
select(getdate())
end
else
begin
print('下半年')
select(getdate())
end

--while,continue,break用法

declare @i int
set @i=1
while @i<20
begin
 set @i=@i+1
 if @i<=19
 continue
 print @i
end

declare @i int
set @i=1
while @i<20
begin
 if @i=19
 break
 print @i
 set @i=@i+1
end

----try...catch用法
begin try
   select 1/0
end try
begin catch
   print'打印错误'
end catch

---raiserror的用法
begin try
  raiserror('生成一个错误消息',11,1)
end try
begin catch
  select error_message() as 错误消息,
         error_severity() as严重级别,
         error_state() as state;
end catch

---使用sp_addmessage存储过程添加自定义错误
exec sp_addmessage 50001,15, N'new user defined error message!',us_english
exec sp_addmessage 50001,15, N'新增用户自定义错误消息!'
exec sp_dropmessage 50001,'all'

---使用sp_altermessage存储过程修改用户定义错误消息
exec sp_altermessage 50001,'with_log',true'

---2005查看数据库信息
select * from sys.databases

exec sp_helpdb

--查看数据库空间使用情况
exec sp_spaceused

--创建数据库时指定数据文件
create database db
on
primary(name=db,
        filename='C:/program files/mircosoft SQL server/mssql10.mssqlserver/mssql/data/db.mdf',
        size=100MB
        maxsize=200
        filegrowth=20)
go
--解释下上面的参数:
  
--primary关键字,指定关联<文件定义>列表用于定义主要数据文件,一个数据库只能有一个主文件,如果没有指定primary,那么create database 语句中列出的第一个文件将成为主文件。

--name关键字,用于指定数据文件的逻辑名称

--filename关键字,指定数据文件的操作系统文件名。其后面的参数是创建数据文件时定义的物理文件的路径名和文件名。

--size关键字,指定数据文件的大小。

--maxsize关键字,指定数据文件可以增长到的最大大小。

--unlimitted关键字,上面的例子中省略掉了。若指定了,则代表指定定义的数据文件将增长到磁盘变满为止。

--filegrowth关键字,指定数据文件的增长增量,其值不能超过maxsize设置。0表示不增长。,默认值为MB。如果指定为%,则增量大小为发生时文件大小的指定百分比,如果没有指定,默认值为10%。

--在创建数据库时指定文件组
create database db
on
primary(name=db1,
        filename='C:/program files/mircosoft SQL server/mssql10.mssqlserver/mssql/data/db1.mdf',
        size=100MB
        maxsize=200
        filegrowth=20),
filegroup filegroup1
(name=db2,
        filename='C:/program files/mircosoft SQL server/mssql10.mssqlserver/mssql/data/db2.mdf',
        size=100MB
        maxsize=200
        filegrowth=20)
go

--创建数据库时指定事务日志文件

create database db
on
primary(name=db1,
        filename='C:/program files/mircosoft SQL server/mssql10.mssqlserver/mssql/data/db1.mdf',
        size=100MB
        maxsize=200
        filegrowth=20),
log on(
  name=dblog,
        filename='C:/program files/mircosoft SQL server/mssql10.mssqlserver/mssql/data/db_log.ldf',
        size=10MB
        maxsize=20
        filegrowth=2)
go

--获取约束信息
select * from information_schema.constraint_column_usage---可以获取指定数据库中的所有约束的信息以及约束与列的对应关系
go

select * from information_schema.constraint_table_usage---查询结果中只包含表和约束的对应关系,并没有约束对应的列信息
go

select * from information_schema.table_constraints---查询结果中只包含表和约束的对应关系,并没有约束对应的列信息
go

select * from information_schema.key_column_usage---可以获取指定数据库中的所有键约束的列信息,包括主键约束中的主键列,唯一约束中的唯一键列和外键约束中的引用列
go

select * from sys.key_constraints----获取约束信息

select * from sys.foreign_keys--获取表中的外键约束

select * from sys.foreign_key_columns--获取外键约束的列信息

select * from information_schema.referential_constraints--获取外键约束信息

select * from information_schema.check_constraints--获取检查约束信息

---创建主键约束,唯一约束,检查约束
create table test
(
  id int,
  testname varchar(50),
  sex bit,
  class varchar(50),
  score float default(0)
  constraint pk_test primary key/*这里可以指定是创建聚集或非聚集索引clustered|nonclustered可选项*/(id)
  constraint ix_test unique(testname)
  constraint ck_test check/*这里可以使用 not for replication可选项,用于指定当从其他表中复制数据时,不检查约束条件*/(score>=0)
)
  go


alter table tb
add constraint pk_tb primary key nonclustered (id)
go

alter table tb
add constraint ck_sex check(sex='男' or sex='女')
go

---创建和使用默认约束
alter table tb
add constraint de_test default'test' for test  ---在表tb的列test的默认约束为'test'
go

--创建和使用外键约束
alter table tb
add constraint fk_tb_tb1 foreign key(id)
references tb1(id)
go

--使用dbcc checkident检查和设置表的标识值
create table tb
(
 id int primary key identity,
 name varchar(50)
)
 insert into tb
 select 'a'
 union all
 select 'b'
 union all
 select 'c'
 union all
 select 'd'
go
 dbcc checkident(tb,noreseed)
go


delete from tb where id>2
go
--删除记录后,表tb只剩下两条记录了,但是此时表tb的标识值仍为4,可以用下面的语句重置标识值为2
dbcc checkident(tb,reseed,2)
go

dbcc checkident(tb,noreseed)
go

/*检查标识信息: 当前标识值 '4',当前列值 '4'。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。

(2 行受影响)
检查标识信息: 当前标识值 '4',当前列值 '2'。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。
检查标识信息: 当前标识值 '2',当前列值 '2'。
DBCC 执行完毕。如果 DBCC 输出了错误信息,请与系统管理员联系。*/

drop table tb

---视图with encryption的用法
create view 员工信息简历表
with encryption----这样就创建了加密视图
as
  select
     e.emp_name,e.sex,e.title,d.dep_name
  from
     employees e inner join departments d
  on
     e.dep_id=d.dep_id
go

---获取表和视图信息
select * from information_shcema.tables---查看当前数据库中当前用户有权限查看的所有表和视图信息

---获取视图信息
select * from information_schema.views

---获取列信息
select * from information_schema.columns
如果需要查看指定表或视图的列情况,可以使用下面的语句。
select
 *
from
 information_schema.columns
where
 table_catalog='数据库名'
and
 table_name='表名'

---获取视图中列的信息
select * from information_schema.view_column_usage


---获取列信息
select * from sys.columns

将sys.columns与系统视图sys.objects和sys.types关联,获得列的一些详细信息,例如
select
  o.name as 表名,
  c.name as 列名,
  t.name as 数据类型,
  c.max_length as 长度,
  c.precision as精度,
  c.scale as 小数位数,
  case c.is_nullable when 1 then '是' else '否' end as 是否允许空,
  case c.is_identity when 1 then '是' else '否' end as 标识列,
from
  sys.columns c inner join sys.objects o
on
  o.object_id=c.object_id
inner join
  sys.types t
on
  c.system_type_id=t.system_type_id
where
  o.name='表名' and t.name<>'sysname'
order by
  c.column_id
go

--获取视图中包含表的信息
select * from information_schema.view_table_usage
go
 
--获取所有数据库对象的信息
select * from sys.objects

--绑定规则
exec sp_bindrule '规则名','对象名'
例如
exec sp_bindrule 'sexrule','employees.sex'

--解除绑定规则
exec sp_unbindrule '对象名'

--删除规则
在删除规则前,需要调用sp_unbindrule存储过程解除该规则的绑定,例如

exec sp_unbindrule 'employees.sex'
drop rule sexrule

--查看表的索引信息
exec sp_helpindex tb

--结合sys.indexes和sys.index_columns,sys.objects,sys.columns查询索引所属的表或视图的信息
select
  o.name as 表名,
  i.name as 索引名,
  c.name as 列名,
  i.type_desc as 类型描述,
  is_primary_key as 主键约束,
  is_unique_constraint as 唯一约束,
  is_disabled as 禁用
from
  sys.objects o
inner join
  sys.indexes i
on
  i.object_id=o.object_id
inner join
  sys.index_columns ic
on
  ic.index_id=i.index_id and ic.object_id=i.object_id
inner join
  sys.columns c
on
  ic.column_id=c.column_id and ic.object_id=c.object_id
go

--查询索引的键和列信息
select
  o.name as 表名,
  i.name as 索引名,
  c.name as 字段编号,
from
  sysindexes i inner join sysobjects o
on
  i.id=o.id
inner join
  sysindexkeys k
on
  o.id=k.id and i.indid=k.indid
inner join
  syscolumns c
on
  c.id=i.id and k.colid=c.colid
where
  o.name='表名'

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值