MS-SQL数据库开发常用汇总
0.把长日期转换为短日期 Convert(char(10),getdate(),120)
1.按姓氏笔画排序:

Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as

2.数据库加密:

select encrypt('原始密码')

select pwdencrypt('原始密码')

select pwdcompare('原始密码','加密后密码') = 1--相同;否则不相同 encrypt('原始密码')

select pwdencrypt('原始密码')

select pwdcompare('原始密码','加密后密码') = 1--相同;否则不相同

3.取回表中字段:

declare @list varchar(1000),@sql nvarchar(1000)

select @list=@list+','+b.name from sysobjects a,syscolumns b where a.id=b.id and a.name='表A'

set @sql='select '+right(@list,len(@list)-1)+' from 表A'

exec (@sql)

4.查看硬盘分区:

EXEC master..xp_fixeddrives

5.比较A,B表是否相等:

if (select checksum_agg(binary_checksum(*)) from A)

=

(select checksum_agg(binary_checksum(*)) from B)

print '相等'

else

print '不相等'

6.杀掉所有的事件探察器进程:

DECLARE hcforeach CURSOR GLOBAL FOR SELECT 'kill '+RTRIM(spid) FROM master.dbo.sysprocesses

WHERE program_name IN('SQL profiler',N'SQL 事件探查器')

EXEC sp_msforeach_worker '?'

7.记录搜索:

开头到N条记录

Select Top N * From 表

-------------------------------

N到M条记录(要有主索引ID)

Select Top M-N * From 表 Where ID in (Select Top M ID From 表) Order by ID Desc

----------------------------------

N到结尾记录

Select Top N * From 表 Order by ID Desc

8.如何修改数据库的名称:

sp_renamedb 'old_name', 'new_name'

9:获取当前数据库中的所有用户表

select Name from sysobjects where xtype='u' and status>=0

10:获取某一个表的所有字段

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

11:查看与某一个表相关的视图、存储过程、函数

select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%'

12:查看当前数据库中所有存储过程

select name as 存储过程名称 from sysobjects where xtype='P'

13:查询用户创建的所有数据库

select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name='sa')

或者

select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01

14:查询某一个表的字段和数据类型

select column_name,data_type from information_schema.columns

where table_name = '表名'

[n].[标题]:

Select * From TableName Order By CustomerName

[n].[标题]:

来自
http://dev.csdn.net/develop/article/83/83138.shtm
一、 只复制一个表结构,不复制数据
select top 0 * into [t1] from [t2]
二、 获取数据库中某个对象的创建脚本
1、 先用下面的脚本创建一个函数

if exists(select 1 from sysobjects where id=object_id('fgetscript') and objectproperty(id,'IsInlineFunction')=0)

drop function fgetscript

go


create function fgetscript(

@servername varchar(50) --服务器名

,@userid varchar(50)='sa' --用户名,如果为nt验证方式,则为空

,@password varchar(50)='' --密码

,@databasename varchar(50) --数据库名称

,@objectname varchar(250) --对象名


) returns varchar(8000)

as

begin

declare @re varchar(8000) --返回脚本

declare @srvid int,@dbsid int --定义服务器、数据库集id

declare @dbid int,@tbid int --数据库、表id

declare @err int,@src varchar(255), @desc varchar(255) --错误处理变量


--创建sqldmo对象

exec @err=sp_oacreate 'sqldmo.sqlserver',@srvid output

if @err<>0 goto lberr


--连接服务器

if isnull(@userid,'')='' --如果是 Nt验证方式

begin

exec @err=sp_oasetproperty @srvid,'loginsecure',1

if @err<>0 goto lberr


exec @err=sp_oamethod @srvid,'connect',null,@servername

end

else

exec @err=sp_oamethod @srvid,'connect',null,@servername,@userid,@password


if @err<>0 goto lberr


--获取数据库集

exec @err=sp_oagetproperty @srvid,'databases',@dbsid output

if @err<>0 goto lberr


--获取要取得脚本的数据库id

exec @err=sp_oamethod @dbsid,'item',@dbid output,@databasename

if @err<>0 goto lberr


--获取要取得脚本的对象id

exec @err=sp_oamethod @dbid,'getobjectbyname',@tbid output,@objectname

if @err<>0 goto lberr


--取得脚本

exec @err=sp_oamethod @tbid,'script',@re output

if @err<>0 goto lberr


--print @re

return(@re)


lberr:

exec sp_oageterrorinfo NULL, @src out, @desc out

declare @errb varbinary(4)

set @errb=cast(@err as varbinary(4))

exec master..xp_varbintohexstr @errb,@re out

set @re='错误号: '+@re

+char(13)+'错误源: '+@src

+char(13)+'错误描述: '+@desc

return(@re)

end

go


2、 用法如下
用法如下,

print dbo.fgetscript('服务器名','用户名','密码','数据库名','表名或其它对象名')

3、 如果要获取库里所有对象的脚本,如如下方式

declare @name varchar(250)

declare #aa cursor for

select name from sysobjects where xtype not in('S','PK','D','X','L')

open #aa

fetch next from #aa into @name

while @@fetch_status=0

begin

print dbo.fgetscript('onlytiancai','sa','sa','database',@name)

fetch next from #aa into @name

end

close #aa

deallocate #aa

4、 声明,此函数是csdn邹建邹老大提供的
三、 分隔字符串
如果有一个用逗号分割开的字符串,比如说"a,b,c,d,1,2,3,4",如何用t-sql获取这个字符串有几个元素,获取第几个元素的值是多少呢?因为t-sql里没有split函数,也没有数组的概念,所以只能自己写几个函数了。
1、 获取元素个数的函数

create function getstrarrlength (@str varchar(8000))

returns int

as

begin

declare @int_return int

declare @start int

declare @next int

declare @location int

select @str =','+ @str +','

select @str=replace(@str,',,',',')

select @start =1

select @next =1

select @location = charindex(',',@str,@start)

while (@location <>0)

begin

select @start = @location +1

select @location = charindex(',',@str,@start)

select @next =@next +1

end

select @int_return = @next-2

return @int_return

end

2、 获取指定索引的值的函数

create function getstrofindex (@str varchar(8000),@index int =0)

returns varchar(8000)

as

begin

declare @str_return varchar(8000)

declare @start int

declare @next int

declare @location int

select @start =1

select @next =1 --如果习惯从0开始则select @next =0

select @location = charindex(',',@str,@start)

while (@location <>0 and @index > @next )

begin

select @start = @location +1

select @location = charindex(',',@str,@start)

select @next =@next +1

end

if @location =0 select @location =len(@str)+1 --如果是因为没有逗号退出,则认为逗号在字符串后

select @str_return = substring(@str,@start,@location -@start) --@start肯定是逗号之后的位置或者就是初始值1

if (@index <> @next ) select @str_return = '' --如果二者不相等,则是因为逗号太少,或者@index小于@next的初始值1。

return @str_return

end

3、 测试

SELECT [dbo].[getstrarrlength]('1,2,3,4,a,b,c,d')

SELECT [dbo].[getstrofindex]('1,2,3,4,a,b,c,d',5)

四、 一条语句执行跨越若干个数据库
我要在一条语句里操作不同的服务器上的不同的数据库里的不同的表,怎么办呢?
第一种方法:

select * from OPENDATASOURCE('SQLOLEDB','Data Source=远程ip;User ID=sa;Password=密码').库名.dbo.表名

第二种方法:
先使用联结服务器:

EXEC sp_addlinkedserver '别名','','MSDASQL',NULL,NULL,'DRIVER={SQL Server};SERVER=远程名;UID=用户;PWD=密码;'

exec sp_addlinkedsrvlogin @rmtsrvname='别名',@useself='false',@locallogin='sa',@rmtuser='sa',@rmtpassword='密码'

GO

然后你就可以如下:

select * from 别名.库名.dbo.表名

insert 库名.dbo.表名 select * from 别名.库名.dbo.表名

select * into 库名.dbo.新表名 from 别名.库名.dbo.表名

go

五、 怎样获取一个表中所有的字段信息
蛙蛙推荐:怎样获取一个表中所有字段的信息
先创建一个视图

Create view fielddesc

as

select o.name as table_name,c.name as field_name,t.name as type,c.length as


length,c.isnullable as isnullable,convert(varchar(30),p.value) as desp

from syscolumns c

join systypes t on c.xtype = t.xusertype

join sysobjects o on o.id=c.id

left join sysproperties p on p.smallid=c.colid and p.id=o.id

where o.xtype='U'


查询时:

Select * from fielddesc where table_name = '你的表名'
还有个更强的语句,是邹建写的,也写出来吧

SELECT

(case when a.colorder=1 then d.name else '' end) N'表名',

a.colorder N'字段序号',

a.name N'字段名',

(case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end) N'标识',

(case when (SELECT count(*)

FROM sysobjects

WHERE (name in

(SELECT name

FROM sysindexes

WHERE (id = a.id) AND (indid in

(SELECT indid

FROM sysindexkeys

WHERE (id = a.id) AND (colid in

(SELECT colid

FROM syscolumns

WHERE (id = a.id) AND (name = a.name))))))) AND

(xtype = 'PK'))>0 then '√' else '' end) N'主键',

b.name N'类型',

a.length N'占用字节数',

COLUMNPROPERTY(a.id,a.name,'PRECISION') as N'长度',

isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0) as N'小数位数',

(case when a.isnullable=1 then '√'else '' end) N'允许空',

isnull(e.text,'') N'默认值',

isnull(g.[value],'') AS N'字段说明'

--into ##tx


FROM syscolumns a left join systypes b

on a.xtype=b.xusertype

inner join sysobjects d

on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'

left join syscomments e

on a.cdefault=e.id

left join sysproperties g

on a.id=g.id AND a.colid = g.smallid

order by object_name(a.id),a.colorder


六、 时间格式转换问题
因为新开发的软件需要用一些旧软件生成的一些数据,在时间格式上不统一,只能手工转换,研究了一下午写了三条语句,以前没怎么用过convert函数和case语句,还有"+"操作符在不同上下文环境也会起到不同的作用,把我搞晕了要,不过现在看来是差不多弄好了。
1、把所有"70.07.06"这样的值变成"1970-07-06"

UPDATE lvshi

SET shengri = '19' + REPLACE(shengri, '.', '-')

WHERE (zhiyezheng = '139770070153')
2、在"1970-07-06"里提取"70","07","06"

SELECT SUBSTRING(shengri, 3, 2) AS year, SUBSTRING(shengri, 6, 2) AS month,

SUBSTRING(shengri, 9, 2) AS day

FROM lvshi

WHERE (zhiyezheng = '139770070153')

3、把一个时间类型字段转换成"1970-07-06"

UPDATE lvshi

SET shenling = CONVERT(varchar(4), YEAR(shenling))

+ '-' + CASE WHEN LEN(MONTH(shenling)) = 1 THEN '0' + CONVERT(varchar(2),

month(shenling)) ELSE CONVERT(varchar(2), month(shenling))

END + '-' + CASE WHEN LEN(day(shenling)) = 1 THEN '0' + CONVERT(char(2),

day(shenling)) ELSE CONVERT(varchar(2), day(shenling)) END

WHERE (zhiyezheng = '139770070153')

七、 分区视图
分区视图是提高查询性能的一个很好的办法

--看下面的示例


--示例表

create table tempdb.dbo.t_10(

id int primary key check(id between 1 and 10),name varchar(10))


create table pubs.dbo.t_20(

id int primary key check(id between 11 and 20),name varchar(10))


create table northwind.dbo.t_30(

id int primary key check(id between 21 and 30),name varchar(10))

go


--分区视图

create view v_t

as

select * from tempdb.dbo.t_10

union all

select * from pubs.dbo.t_20

union all

select * from northwind.dbo.t_30

go


--插入数据

insert v_t select 1 ,'aa'

union all select 2 ,'bb'

union all select 11,'cc'

union all select 12,'dd'

union all select 21,'ee'

union all select 22,'ff'


--更新数据

update v_t set name=name+'_更新' where right(id,1)=1


--删除测试

delete from v_t where right(id,1)=2


--显示结果

select * from v_t

go


--删除测试

drop table northwind.dbo.t_30,pubs.dbo.t_20,tempdb.dbo.t_10

drop view v_t



/**//*--测试结果


id name

----------- ----------

1 aa_更新

11 cc_更新

21 ee_更新


(所影响的行数为 3 行)

==*/


八、 树型的实现


--参考


--树形数据查询示例

--作者: 邹建


--示例数据

create table [tb]([id] int identity(1,1),[pid] int,name varchar(20))

insert [tb] select 0,'中国'

union all select 0,'美国'

union all select 0,'加拿大'

union all select 1,'北京'

union all select 1,'上海'

union all select 1,'江苏'

union all select 6,'苏州'

union all select 7,'常熟'

union all select 6,'南京'

union all select 6,'无锡'

union all select 2,'纽约'

union all select 2,'旧金山'

go


--查询指定id的所有子

create function f_cid(

@id int

)returns @re table([id] int,[level] int)

as

begin

declare @l int

set @l=0

insert @re select @id,@l

while @@rowcount>0

begin

set @l=@l+1

insert @re select a.[id],@l

from [tb] a,@re b

where a.[pid]=b.[id] and b.[level]=@l-1

end


/**//**//**//*--如果只显示最明细的子(下面没有子),则加上这个删除

delete a from @re a

where exists(

select 1 from [tb] where [pid]=a.[id])

--*/

return

end

go


--调用(查询所有的子)

select a.*,层次=b.[level] from [tb] a,f_cid(2)b where a.[id]=b.[id]

go


--删除测试

drop table [tb]

drop function f_cid

go


九、 排序问题

CREATE TABLE [t] (

[id] [int] IDENTITY (1, 1) NOT NULL ,

[GUID] [uniqueidentifier] NULL

) ON [PRIMARY]

GO
下面这句执行5次

insert t values (newid())
查看执行结果

select * from t
1、 第一种

select * from t

order by case id when 4 then 1

when 5 then 2

when 1 then 3

when 2 then 4

when 3 then 5 end
2、 第二种

select * from t order by (id+2)%6
3、 第三种

select * from t order by charindex(cast(id as varchar),'45123')
4、 第四种

select * fr
分享到:
相关推荐
在MS-SQL开发中,掌握一些常用的技巧和命令可以极大地提高效率和代码质量。以下是一些关键知识点的详细说明: 1. **日期转换**:在SQL Server中,使用`CONVERT`函数可以将日期格式化。例如,`CONVERT(char(10),...
查询》,读者可以掌握T-SQL的高级技巧,提升SQL Server 2008数据库的管理和应用能力,从而更好地设计、优化和维护数据库系统。这本书的PDF文件包含了所有这些内容的详细讲解,对于SQL Server 2008的开发者和管理员来...
MS-SQL报表生成的通用方法主要涉及SQL查询语言的使用,以及存储过程、动态SQL语句和游标的应用。接下来,将详细阐释这些知识点。 首先,MS-SQL报表生成的起点是数据库中的基础表。在本例中,基础表Table1包含姓名、...
罗斯文数据库是一款针对MS SQL Server设计的数据库管理系统,它提供了丰富的功能,帮助用户高效地管理和操作数据。在学习罗斯文数据库的过程中,你需要掌握以下几个关键知识点: 1. **数据库概念**:首先,理解...
- **流行的SQL开发工具**:介绍了几种常用的SQL开发工具,如Microsoft SQL Server Management Studio、SQL Server Express、Toad for SQL Server等。 - **SQL在编程中的应用**:探讨了SQL在不同编程环境中的应用方式...
综上所述,全国最新区划数据-四级-省-市-县(区)-乡(镇)-MS SQL版本提供的是一个适用于开发和测试的完整数据库解决方案,它包含中国最新的行政区域划分信息,并且是为SQL Server优化设计的,可以满足多种业务场景的...
在这个系统中,SQL数据库可能采用了如MS Access或SQL Server等数据库管理系统,用于存储和管理学生档案的数据。通过VB程序,开发者可以编写SQL语句进行数据的增删改查操作,保证数据的安全性和一致性。 3. **数据库...
【SQLserver数据库管理与开发】相关的知识点主要包括以下几个方面: 1. **数据库特点**:数据库的主要特点包括数据共享、数据完整性以及数据独立性高,而数据冗余很高是传统文件系统的特征,不属于数据库的特点。 ...
系统使用数据库中间件技术,支持My SQL、MS SQL Server等多种数据库系统平台。系统涉及到复杂表单数据提交、AJAX无刷新数据提交、WEB打印等常用应用软件中涉及到的技术。 Java Web订销管理系统(java+mysql+html+运行...
交互式SQL查询操作 本资源是数据库实验第四部分,主要内容是交互式SQL查询操作。...本实验报告涵盖了数据库设计、数据库管理系统、SQL语言、数据分析等知识点,为后续数据库开发和管理奠定了基础。
MS SQL,全称为Microsoft SQL Server,是微软公司推出的一种基于SQL标准的关系数据库管理系统。本主题将聚焦于SELECT语句在MS SQL中的应用,这是一种用于从数据库中检索数据的关键命令。 一、SELECT语句基础 ...
- **SQL概述**:这部分讲解了数据库的基本概念,包括数据库的历史发展,常用数据库类型的介绍,以及如何安装和理解MS SQL Server 2000的组件。 - **数据库用户管理**和**角色管理**:涉及如何创建、管理用户账户,...
10. 数据文件后缀:SQL数据库文件的常见后缀包括.mdf(主数据文件)、.ldf(日志文件)和.ndf(辅助数据文件),.tif通常用于图像文件,不是数据库文件后缀。 11. 数据定义语言(DDL):DDL用于创建和修改数据库...
由开发系统(如 Microsoft Visual C++®、Microsoft Visual Basic® 或 Microsoft Visual J++®)使用数据库应用程序接口 (API)(如 ADO、OLE DB 以及 ODBC)创建的应用程序。 从 SQL Server 数据库提取数据...
### SQL21自学通知识点梳理 #### 一、SQL简介及历史 - **SQL定义**:SQL(Structured Query Language)...通过上述知识点的学习,读者可以系统地掌握SQL的基础知识和高级应用技巧,从而能够有效地管理和操作数据库。
以上是MS SQL2000中的一些常见问题及解决方法,这些实例涵盖了数据对比、去重、数据清理、统计汇总、日期处理等多个方面,对于数据库管理员和程序员在日常工作中都是非常实用的。在实际应用中,需要根据具体环境和...
流行的SQL 开发工具 24 SQL 在编程中的应用 27 第二天查询— — SELECT 语句的使用 30 目标 30 背景 30 一般的语法规则 30 你的第一个查询 33 总结 37 问与答 38 校练场 38 练习 39 第三天表达式条件语句与运算 40 ...
**Microsoft Jet SQL for Access 2000 基础** Microsoft Jet SQL 是Microsoft Access数据库管理系统的核心组件,它...通过不断的练习和实践,你可以熟练地运用Jet SQL进行数据查询、报表制作以及数据库应用的开发。