SQLServer语句 汇总
时间:2022-03-13 22:54
drop database databaseName
go
Create DATABASE databasename
EXEC sp_addumpdevice ‘disk‘, ‘testBack‘, ‘c:\mssql7backup\MyNwind_1.dat‘
BACKUP DATABASE pubs TO testBack
go
select * into 目的数据库名.dbo.目的表名 from 原表名(使用旧表创建新表)
2、create table tab_new as select col1,col2… from tab_old definition only
minvalue 1 -- 最小值
maxvalue 999999999999999999999999999 -- 最大值
start with 1 -- 开始值
increment by 1 -- 每次加几
cache 20;
alter table tablename add column_b int identity(1,1)
DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
sql="select * from 数据表 where 字段名 like ‘%字段值%‘ order by 字段名 [desc]"
sql="select top 10 * from 数据表 where 字段名=字段值 order by 字段名 [desc]"
sql="select top 10 * from 数据表 order by 字段名 [desc]"
sql="select * from 数据表 where 字段名 in (‘值1‘,‘值2‘,‘值3‘)"
sql="select * from 数据表 where 字段名 between 值1 and 值2"
注:like中"%"匹配0个或多个字符;like中"_"匹配一个字符
sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式"
sql="delete from 数据表" (将数据表所有记录删除)
sql="insert into 目标数据表 select * from 源数据表"
(把源数据表的记录添加到目标数据表)
COUNT(*;字段名) 对数据行数的统计或对某一栏有值的数据行数统计
MAX(字段名) 取得一个表格栏最大的值
MIN(字段名) 取得一个表格栏最小的值
SUM(字段名) 把数据栏的值相加
引用以上函数的方法:
sql="select sum(字段名) as 别名 from 数据表 where 条件表达式"
set rs=conn.excute(sql)
用 rs("别名") 获取统计的值,其它函数运用同上。
where xtype = ‘u‘ and id in(select id from syscolumns where name = ‘s3‘)
select top 0 * into b from a
insert into aa(Customer_ID, ID_Type, ID_Number)
select Customer_ID, ID_Type, ID_Number from TCustomer;
set identity_insert aa OFF
drop table#临时表名
print ‘自增列‘
else
print ‘不是自增列‘
SELECT* FROM sys.columns WHERE object_id=OBJECT_ID(‘表名‘)
AND is_identity=1
whereid=object_id(‘表名‘) and name=‘索引名‘)
print ‘存在‘ else print ‘不存在
not between不包括边界值
where not exists ( select * from table2 where table1.field1=table2.field1)
DBCC REINDEX
DBCC INDEXDEFRAG
收缩数据和日志:
DBCC SHRINKDB
DBCC SHRINKFILE
go
GO
DBCC CHECKDB(‘dvbbs‘,repair_allow_data_loss) WITH TABLOCK
GO
Alter DATABASE [dvbbs] SET MULTI_USER
GO
组相关的信息:(统计信息) count,sum,max,min,avg 分组的标准)
在SQLServer中分组时:不能以text,ntext,image类型的字段作为分组依据
在selecte统计函数中的字段,不能和普通的字段放在一起;
select pwdencrypt(‘原始密码‘)
select pwdcompare(‘原始密码‘,‘加密后密码‘) = 1--相同;否则不相同
select pwdencrypt(‘原始密码‘)
select pwdcompare(‘原始密码‘,‘加密后密码‘) = 1--相同;否则不相同
=(select checksum_agg(binary_checksum(*)) from B)
print ‘相等‘
else print ‘不相等‘
WHERE program_name IN(‘SQL profiler‘,N‘SQL 事件探查器‘)
EXEC sp_msforeach_worker ‘?‘
exec sp_addlinkedserver ‘ITSV ‘, ‘ ‘, ‘SQLOLEDB ‘, ‘远程服务器名或ip地址 ‘
exec sp_addlinkedsrvlogin ‘ITSV ‘, ‘false ‘,null, ‘用户名 ‘, ‘密码 ‘
--查询示例
select * from ITSV.数据库名.dbo.表名
--导入示例
select * into 表 from ITSV.数据库名.dbo.表名
--以后不再使用时删除链接服务器
exec sp_dropserver ‘ITSV ‘, ‘droplogins ‘
--查询示例
select * from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)
--生成本地表
select * into 表 from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)
--把本地表导入远程表
insert openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)
select *from 本地表
--更新本地表
update b set b.列A=a.列A
from openrowset( ‘SQLOLEDB ‘, ‘sql服务器名 ‘; ‘用户名 ‘; ‘密码 ‘,数据库名.dbo.表名)as a inner join 本地表 b on a.column1=b.column1
--首先创建一个连接创建链接服务器
exec sp_addlinkedserver ‘ITSV ‘, ‘ ‘, ‘SQLOLEDB ‘, ‘远程服务器名或ip地址 ‘
--查询
select * FROM openquery(ITSV, ‘SELECT * FROM 数据库.dbo.表名 ‘)
--把本地表导入远程表
insert openquery(ITSV, ‘SELECT * FROM 数据库.dbo.表名 ‘) select * from 本地表
--更新本地表
update b set b.列B=a.列B
FROM openquery(ITSV, ‘SELECT * FROM 数据库.dbo.表名 ‘) as a
inner join 本地表 b on a.列A=b.列A
SELECT * FROM opendatasource( ‘SQLOLEDB ‘, ‘Data Source=ip/ServerName;User ID=登陆名;Password=密码 ‘ ).test.dbo.roy_ta
--把本地表导入远程表
insert opendatasource( ‘SQLOLEDB ‘, ‘Data Source=ip/ServerName;User ID=登陆名;Password=密码 ‘).数据库.dbo.表名 select * from 本地表
SQLServer语句 汇总,布布扣,bubuko.com