当前位置:Gxlcms > 数据库问题 > MSSQL基础

MSSQL基础

时间:2021-07-01 10:21:17 帮助过:2人阅读

前言

最近看到一些关于sql的汇总博客,觉得还是很不错的。于是心血来潮,也想写一篇自己对这方面的一些认识(主要是点出一下自己比较少用demo写的,一般都是直接改设计时的,例如建表、该字段名)。

一、数据库建立语句

create database dbTask
on primary
(
	name=‘dbTask_data‘,
	filename=‘D:\DBData\DATA\dbTask_data.mdf‘,
	size =5mb,
	maxsize=200mb,
	filegrowth=15%
)
log on 
(
	name=‘dbTask_log‘,
	filename=‘D:\DBData\LOG\dbTask_log.ldf‘,
	size=1mb,
	filegrowth=1mb
)
go

  其中的一些注解就不标了。对于一些说on primary (指定文件组)这个可以省略,默认就是primary。个人写的时候,我一直是写上的,不然会报错误(name附近有语法错误)。也没有其他系统或电脑来测试,所以暂未确认是否必须。建议默认写上。

二、表操作

1)建表:

USE DBTask
GO
IF NOT EXISTS(SELECT 1 FROM sysobjects WHERE id=OBJECT_ID(‘[tbInfo]‘))
BEGIN
CREATE TABLE [dbo].[tbInfo](
	[Id] [varchar](100) NOT NULL,
	[SendUserId] [varchar](100) NULL,
	[UserId] [varchar](100) NULL,
	[Title] [varchar](100) NULL,
	[Time] [datetime] NULL,
	[Description] [varchar](2000) NULL,
 )
declare @CurrentUser sysname
select @CurrentUser = user_name()
execute sp_addextendedproperty ‘MS_Description‘, ‘信息表‘,‘user‘,@CurrentUser,‘table‘,‘tbInfo‘
execute sp_addextendedproperty ‘MS_Description‘, ‘标题‘,‘user‘,@CurrentUser,‘table‘,‘tbInfo‘,‘column‘,‘Title‘

end
go

  sysobject为系统自带表,OBJECT_ID为系统函数。"execute sp_addextendedproperty ‘MS_Description‘, ‘信息表‘,‘user‘,@CurrentUser,‘table‘,‘tbInfo‘"

是给表添加描述信息,更新表的MS_Description属性,还是比较实用的。"execute sp_addextendedproperty ‘MS_Description‘, ‘标题‘,‘user‘,@CurrentUser,‘table‘,‘tbInfo‘,‘column‘,‘Title‘"则是给列添加备注信息。

2)删表语句:

USE DBTask
GO
IF NOT EXISTS(SELECT 1 FROM sysobjects WHERE id=OBJECT_ID(‘[tbInfo]‘))
BEGIN
drop table tbInfo
end
go

3)更新表列信息:

一下为一些常见的修改集合,不做过多说明

ALTER TABLE tbInfo ADD address nvarchar(50) NULL; --添加表列
go
    
alter table tbInfo alter column address nvarchar(100); --修改表列字段类型
go

exec   sp_rename   ‘tbInfo.[address]‘,‘Addr‘,‘column‘;  --修改表列名
go

exec  sp_rename ‘tbInfo‘, ‘tbInformation‘, ‘object‘;  --重命名表
go

alter table tbInformation drop column Addr; --删除表列
go 

  三、数据操作

1)数据查询是经常用到,主要有单表查询(比较简单)。多表查询---主要是嵌套查询或者是级联查询(left join、Inner join、right join)。如果使用Union查询的时候注意所有字段应该相互对应;Union和Union All 的区别(排序)。因为常用,所以略。

2)、数据库更新:update tableName set columnName=value where columnName1=value2;Insert table(col1,col2,col3) value(val1,val2,val3),注意select into from与insert into select的使用与区别。

3)、数据删除:delete ,truncate

四、其他

存储过程,函数、触发器等,比较繁琐,暂时先不写,下次在说(感觉烂尾了)

 

MSSQL基础

标签:

人气教程排行