共計 36564 個字符,預計需要花費 92 分鐘才能閱讀完成。
這篇文章主要講解了“常用的 SQL 查詢語句大全”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著丸趣 TV 小編的思路慢慢深入,一起來研究和學習“常用的 SQL 查詢語句大全”吧!
一、基礎
1、說明:創建數據庫
CREATE DATABASE database-name
2、說明:刪除數據庫
drop database dbname
3、說明:備份 sql server
— 創建 備份數據的 device
USE master
EXEC sp_addumpdevice disk , testBack , c:\mssql7backup\MyNwind_1.dat
— 開始 備份
BACKUP DATABASE pubs TO testBack
4、說明:創建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根據已有的表創建新表:
A:create table tab_new like tab_old (使用舊表創建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
5、說明:刪除新表
drop table tabname
6、說明:增加一個列
Alter table tabname add column col type
注:列增加后將不能刪除。DB2 中列加上后數據類型也不能改變,唯一能改變的是增加 varchar 類型的長度。
7、說明:添加主鍵:Alter table tabname add primary key(col)
說明:刪除主鍵:Alter table tabname drop primary key(col)
8、說明:創建索引:create [unique] index idxname on tabname(col….)
刪除索引:drop index idxname
注:索引是不可更改的,想更改必須刪除重新建。
9、說明:創建視圖:create view viewname as select statement
刪除視圖:drop view viewname
10、說明:幾個簡單的基本的 sql 語句
選擇:select * from table1 where 范圍
插入:insert into table1(field1,field2) values(value1,value2)
刪除:delete from table1 where 范圍
更新:update table1 set field1=value1 where 范圍
查找:select * from table1 where field1 like’%value1%’—like 的語法很精妙,查資料!
排序:select * from table1 order by field1,field2 [desc]
總數:select count as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
11、說明:幾個高級查詢運算詞
A:UNION 運算符
UNION 運算符通過組合其他兩個結果表(例如 TABLE1 和 TABLE2)并消去表中任何重復行而派生出一個結果表。當 ALL 隨 UNION 一起使用時(即 UNION ALL),不消除重復行。兩種情況下,派生表的每一行不是來自 TABLE1 就是來自 TABLE2。
B:EXCEPT 運算符
EXCEPT 運算符通過包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重復行而派生出一個結果表。當 ALL 隨 EXCEPT 一起使用時 (EXCEPT ALL),不消除重復行。
C:INTERSECT 運算符
INTERSECT 運算符通過只包括 TABLE1 和 TABLE2 中都有的行并消除所有重復行而派生出一個結果表。當 ALL 隨 INTERSECT 一起使用時 (INTERSECT ALL),不消除重復行。
注:使用運算詞的幾個查詢結果行必須是一致的。
12、說明:使用外連接
A、left(outer)join:
左外連接(左連接):結果集幾包括連接表的匹配行,也包括左連接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right(outer)join:
右外連接 (右連接):結果集既包括連接表的匹配連接行,也包括右連接表的所有行。
C:full/cross(outer)join:
全外連接:不僅包括符號連接表的匹配行,還包括兩個連接表中的所有記錄。
12、分組:Group by:
一張表,一旦分組完成后,查詢后只能得到組相關的信息。
組相關的信息:(統計信息)count,sum,max,min,avg 分組的標準)
在 SQLServer 中分組時:不能以 text,ntext,image 類型的字段作為分組依據
在 selecte 統計函數中的字段,不能和普通的字段放在一起;
13、對數據庫進行操作:
分離數據庫:sp_detach_db; 附加數據庫:sp_attach_db 后接表明,附加需要完整的路徑名
14. 如何修改數據庫的名稱:
sp_renamedb old_name , new_name
二、提升
1、說明:復制表(只復制結構, 源表名:a 新表名:b) (Access 可用)
法一:select * into b from a where 1 1(僅用于 SQlServer)
法二:select top 0 * into b from a
2、說明:拷貝表 (拷貝數據, 源表名:a 目標表名:b) (Access 可用)
insert into b(a, b, c) select d,e,f from b;
3、說明:跨數據庫之間表的拷貝(具體數據使用絕對路徑) (Access 可用)
insert into b(a, b, c) select d,e,f from b in‘具體數據庫’where 條件
例子:..from b in Server.MapPath(.) \data.mdb where..
4、說明:子查詢 (表名 1:a 表名 2:b)
select a,b,c from a where a IN (select d from b) 或者: select a,b,c from a where a IN (1,2,3)
5、說明:顯示文章、提交人和最后回復時間
select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b
6、說明:外連接查詢(表名 1:a 表名 2:b)
select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
7、說明:在線視圖查詢(表名 1:a)
select * from (SELECT a,b,c FROM a) T where t.a
8、說明:between 的用法,between 限制查詢數據范圍時包括了邊界值,not between 不包括
select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 數值 1 and 數值 2
9、說明:in 的使用方法
select * from table1 where a [not] in (‘值 1’,’值 2’,’值 4’,’值 6’)
10、說明:兩張關聯表,刪除主表中已經在副表中沒有的信息
delete from table1 where not exists (select * from table2 where table1.field1=table2.field1)
11、說明:四表聯查問題:
select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where …..
12、說明:日程安排提前五分鐘提醒
SQL: select * from 日程安排 where datediff(minute ,f 開始時間,getdate()) 5
13、說明:一條 sql 語句搞定數據庫分頁
select top 10 b.* from (select top 20 主鍵字段, 排序字段 from 表名 order by 排序字段 desc) a, 表名 b where b. 主鍵字段 = a. 主鍵字段 order by a. 排序字段
具體實現:
關于數據庫分頁:
declare @start int,@end int
@sql nvarchar(600)
set @sql=’select top’+str(@end-@start+1)+’+from T where rid not in(select top’+str(@str-1)+’Rid from T where Rid -1)’
exec sp_executesql @sql
注意:在 top 后不能直接跟一個變量,所以在實際應用中只有這樣的進行特殊的處理。Rid 為一個標識列,如果 top 后還有具體的字段,這樣做是非常有好處的。因為這樣可以避免 top 的字段如果是邏輯索引的,查詢的結果后實際表中的不一致(邏輯索引中的數據有可能和數據表中的不一致,而查詢時如果處在索引則首先查詢索引)
14、說明:前 10 條記錄
select top 10 * form table1 where 范圍
15、說明:選擇在每一組 b 值相同的數據中對應的 a 最大的記錄的所有信息(類似這樣的用法可以用于論壇每月排行榜, 每月熱銷產品分析, 按科目成績排名, 等等.)
select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b)
16、說明:包括所有在 TableA 中但不在 TableB 和 TableC 中的行并消除所有重復行而派生出一個結果表
(select a from tableA) except (select a from tableB) except (select a from tableC)
17、說明:隨機取出 10 條數據
select top 10 * from tablename order by newid()
18、說明:隨機選擇記錄
select newid()
19、說明:刪除重復記錄
1),delete from tablename where id not in (select max(id) from tablename group by col1,col2,…)
2),select distinct * into temp from tablename
delete from tablename
insert into tablename select * from temp
評價:這種操作牽連大量的數據的移動,這種做法不適合大容量但數據操作
3), 例如:在一個外部表中導入數據,由于某些原因第一次只導入了一部分,但很難判斷具體位置,這樣只有在下一次全部導入,這樣也就產生好多重復的字段,怎樣刪除重復字段
alter table tablename
– 添加一個自增列
add column_b int identity(1,1)
delete from tablename where column_b not in(
select max(column_b) from tablename group by column1,column2,…)
alter table tablename drop column column_b
20、說明:列出數據庫里所有的表名
select name from sysobjects where type= U // U 代表用戶
21、說明:列出表里的所有的列名
select name from syscolumns where id=object_id(TableName)
22、說明:列示 type、vender、pcs 字段,以 type 字段排列,case 可以方便地實現多重選擇,類似 select 中的 case。
select type,sum(case vender when A then pcs else 0 end),sum(case vender when C then pcs else 0 end),sum(case vender when B then pcs else 0 end) FROM tablename group by type
顯示結果:
type vender pcs
電腦 A 1
電腦 A 1
光盤 B 2
光盤 A 2
手機 B 3
手機 C 3
23、說明:初始化表 table1
TRUNCATE TABLE table1
24、說明:選擇從 10 到 15 的記錄
select top 5 * from (select top 15 * from table order by id asc) table_別名 order by id desc
三、技巧
1、1=1,1= 2 的使用,在 SQL 語句組合時用的較多
“where 1=1”是表示選擇全部 “where 1=2”全部不選,
如:
if @strWhere !=
begin
set @strSQL = select count(*) as Total from [+ @tblName +] where + @strWhere
end
else
begin
set @strSQL = select count(*) as Total from [+ @tblName +]
end
我們可以直接寫成
錯誤!未找到目錄項。
set @strSQL = select count(*) as Total from [+ @tblName +] where 1=1 安定 + @strWhere 2、收縮數據庫
– 重建索引
DBCC REINDEX
DBCC INDEXDEFRAG
– 收縮數據和日志
DBCC SHRINKDB
DBCC SHRINKFILE
3、壓縮數據庫
dbcc shrinkdatabase(dbname)
4、轉移數據庫給新用戶以已存在用戶權限
exec sp_change_users_login update_one , newname , oldname
go
5、檢查備份集
RESTORE VERIFYONLY from disk= E:\dvbbs.bak
6、修復數據庫
ALTER DATABASE [dvbbs] SET SINGLE_USER
GO
DBCC CHECKDB(dvbbs ,repair_allow_data_loss) WITH TABLOCK
GO
ALTER DATABASE [dvbbs] SET MULTI_USER
GO
7、日志清除
SET NOCOUNT ON
DECLARE @LogicalFileName sysname,
@MaxMinutes INT,
@NewSize INT
USE tablename — 要操作的數據庫名
SELECT @LogicalFileName = tablename_log , — 日志文件名
@MaxMinutes = 10, — Limit on time allowed to wrap log.
@NewSize = 1 — 你想設定的日志文件的大小(M)
Setup / initialize
DECLARE @OriginalSize int
SELECT @OriginalSize = size
FROM sysfiles
WHERE name = @LogicalFileName
SELECT Original Size of + db_name() + LOG is +
CONVERT(VARCHAR(30),@OriginalSize) + 8K pages or +
CONVERT(VARCHAR(30),(@OriginalSize*8/1024)) + MB
FROM sysfiles
WHERE name = @LogicalFileName
CREATE TABLE DummyTrans
(DummyColumn char (8000) not null)
DECLARE @Counter INT,
@StartTime DATETIME,
@TruncLog VARCHAR(255)
SELECT @StartTime = GETDATE(),
@TruncLog = BACKUP LOG + db_name() + WITH TRUNCATE_ONLY
DBCC SHRINKFILE (@LogicalFileName, @NewSize)
EXEC (@TruncLog)
— Wrap the log if necessary.
WHILE @MaxMinutes DATEDIFF (mi, @StartTime, GETDATE()) — time has not expired
AND @OriginalSize = (SELECT size FROM sysfiles WHERE name = @LogicalFileName)
AND (@OriginalSize * 8 /1024) @NewSize
BEGIN — Outer loop.
SELECT @Counter = 0
WHILE ((@Counter @OriginalSize / 16) AND (@Counter 50000))
BEGIN — update
INSERT DummyTrans VALUES (Fill Log) DELETE DummyTrans
SELECT @Counter = @Counter + 1
END
EXEC (@TruncLog)
END
SELECT Final Size of + db_name() + LOG is +
CONVERT(VARCHAR(30),size) + 8K pages or +
CONVERT(VARCHAR(30),(size*8/1024)) + MB
FROM sysfiles
WHERE name = @LogicalFileName
DROP TABLE DummyTrans
SET NOCOUNT OFF
8、說明:更改某個表
exec sp_changeobjectowner tablename , dbo
9、存儲更改全部表
CREATE PROCEDURE dbo.User_ChangeObjectOwnerBatch
@OldOwner as NVARCHAR(128),
@NewOwner as NVARCHAR(128)
AS
DECLARE @Name as NVARCHAR(128)
DECLARE @Owner as NVARCHAR(128)
DECLARE @OwnerName as NVARCHAR(128)
DECLARE curObject CURSOR FOR
select Name = name,
Owner = user_name(uid)
from sysobjects
where user_name(uid)=@OldOwner
order by name
OPEN curObject
FETCH NEXT FROM curObject INTO @Name, @Owner
WHILE(@@FETCH_STATUS=0)
BEGIN
if @Owner=@OldOwner
begin
set @OwnerName = @OldOwner + . + rtrim(@Name)
exec sp_changeobjectowner @OwnerName, @NewOwner
end
— select @name,@NewOwner,@OldOwner
FETCH NEXT FROM curObject INTO @Name, @Owner
END
close curObject
deallocate curObject
GO
10、SQL SERVER 中直接循環寫入數據
declare @i int
set @i=1
while @i 30
begin
insert into test (userid) values(@i)
set @i=@i+1
end
案例:
有如下表,要求就裱中所有沒有及格的成績,在每次增長 0.1 的基礎上,使他們剛好及格:
Name score
Zhangshan 80
Lishi 59
Wangwu 50
Songquan 69
while((select min(score) from tb_table) 60)
begin
update tb_table set score =score*1.01
where score 60
if (select min(score) from tb_table) 60
break
else
continue
end
數據開發 - 經典
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
案例
例如 1:一張表有一萬多條記錄,表的第一個字段 RecID 是自增長字段,寫一個 SQL 語句,找出表的第 31 到第 40 個記錄。
select top 10 recid from A where recid not in(select top 30 recid from A)
分析:如果這樣寫會產生某些問題,如果 recid 在表中存在邏輯索引。
select top 10 recid from A where……是從索引中查找,而后面的 select top 30 recid from A 則在數據表中查找,這樣由于索引中的順序有可能和數據表中的不一致,這樣就導致查詢到的不是本來的欲得到的數據。
解決方案
1, 用 order by select top 30 recid from A order by ricid 如果該字段不是自增長,就會出現問題
2, 在那個子查詢中也加條件:select top 30 recid from A where recid -1
例 2:查詢表中的最后以條記錄,并不知道這個表共有多少數據, 以及表結構。
set @s = select top 1 * from T where pid not in (select top + str(@count-1) + pid from T)
print @s exec sp_executesql @s
9:獲取當前數據庫中的所有用戶表
select Name from sysobjects where xtype= u and status =0
10:獲取某一個表的所有字段
select name from syscolumns where id=object_id(表名)
select name from syscolumns where id in (select id from sysobjects where type = u and name = 表名)
兩種方式的效果相同
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 = 表名
15:不同服務器數據庫之間的數據操作
– 創建鏈接服務器
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
– 連接遠程 / 局域網數據(openrowset/openquery/opendatasource)
–1、openrowset
– 查詢示例
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
–openquery 用法需要創建一個連接
– 首先創建一個連接創建鏈接服務器
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
–3、opendatasource/openrowset
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 本地表
SQL Server 基本函數
SQL Server 基本函數
1. 字符串函數 長度與分析用
1,datalength(Char_expr) 返回字符串包含字符數, 但不包含后面的空格
2,substring(expression,start,length) 取子串,字符串的下標是從“1”,start 為起始位置,length 為字符串長度,實際應用中以 len(expression) 取得其長度
3,right(char_expr,int_expr) 返回字符串右邊第 int_expr 個字符,還用 left 于之相反
4,isnull(check_expression , replacement_value) 如果 check_expression 為空,則返回 replacement_value 的值,不為空,就返回 check_expression 字符操作類
5,Sp_addtype 自定義數據類型
例如:EXEC sp_addtype birthday, datetime, NULL
6,set nocount {on|off}
使返回的結果中不包含有關受 Transact-SQL 語句影響的行數的信息。如果存儲過程中包含的一些語句并不返回許多實際的數據,則該設置由于大量減少了網絡流量,因此可顯著提高性能。SET NOCOUNT 設置是在執行或運行時設置,而不是在分析時設置。
SET NOCOUNT 為 ON 時,不返回計數(表示受 Transact-SQL 語句影響的行數)。
SET NOCOUNT 為 OFF 時,返回計數
常識
在 SQL 查詢中:from 后最多可以跟多少張表或視圖:256
在 SQL 語句中出現 Order by, 查詢時,先排序,后取
在 SQL 中,一個字段的最大容量是 8000,而對于 nvarchar(4000), 由于 nvarchar 是 Unicode 碼。
SQLServer2000 同步復制技術實現步驟
一、預備工作
1. 發布服務器, 訂閱服務器都創建一個同名的 windows 用戶, 并設置相同的密碼, 做為發布快照文件夾的有效訪問用戶
– 管理工具
– 計算機管理
– 用戶和組
– 右鍵用戶
– 新建用戶
– 建立一個隸屬于 administrator 組的登陸 windows 的用戶(SynUser)
2. 在發布服務器上, 新建一個共享目錄, 做為發布的快照文件的存放目錄, 操作:
我的電腦 –D:\ 新建一個目錄, 名為: PUB
– 右鍵這個新建的目錄
– 屬性 – 共享
– 選擇 共享該文件夾
– 通過 權限 按紐來設置具體的用戶權限, 保證第一步中創建的用戶(SynUser) 具有對該文件夾的所有權限
– 確定
3. 設置 SQL 代理(SQLSERVERAGENT) 服務的啟動用戶 (發布 / 訂閱服務器均做此設置)
開始 – 程序 – 管理工具 – 服務
– 右鍵 SQLSERVERAGENT
– 屬性 – 登陸 – 選擇 此賬戶
– 輸入或者選擇第一步中創建的 windows 登錄用戶名(SynUser)
— 密碼 中輸入該用戶的密碼
4. 設置 SQL Server 身份驗證模式, 解決連接時的權限問題(發布 / 訂閱服務器均做此設置)
企業管理器
– 右鍵 SQL 實例 – 屬性
– 安全性 – 身份驗證
– 選擇 SQL Server 和 Windows
– 確定
5. 在發布服務器和訂閱服務器上互相注冊
企業管理器
– 右鍵 SQL Server 組
– 新建 SQL Server 注冊 …
– 下一步 – 可用的服務器中, 輸入你要注冊的遠程服務器名 – 添加
– 下一步 – 連接使用, 選擇第二個 SQL Server 身份驗證
– 下一步 – 輸入用戶名和密碼(SynUser)
– 下一步 – 選擇 SQL Server 組, 也可以創建一個新組
– 下一步 – 完成
6. 對于只能用 IP, 不能用計算機名的, 為其注冊服務器別名(此步在實施中沒用到)
(在連接端配置, 比如, 在訂閱服務器上配置的話, 服務器名稱中輸入的是發布服務器的 IP)
開始 – 程序 –Microsoft SQL Server– 客戶端網絡實用工具
– 別名 – 添加
– 網絡庫選擇 tcp/ip – 服務器別名輸入 SQL 服務器名
– 連接參數 – 服務器名稱中輸入 SQL 服務器 ip 地址
– 如果你修改了 SQL 的端口, 取消選擇 動態決定端口 , 并輸入對應的端口號
二、正式配置
1、配置發布服務器
打開企業管理器,在發布服務器(B、C、D)上執行以下步驟:
(1) 從 [工具] 下拉菜單的 [復制] 子菜單中選擇 [配置發布、訂閱服務器和分發] 出現配置發布和分發向導
(2) [下一步] 選擇分發服務器 可以選擇把發布服務器自己作為分發服務器或者其他 sql 的服務器(選擇自己)
(3) [下一步] 設置快照文件夾
采用默認 \\servername\Pub
(4) [下一步] 自定義配置
可以選擇: 是, 讓我設置分發數據庫屬性啟用發布服務器或設置發布設置
否, 使用下列默認設置(推薦)
(5) [下一步] 設置分發數據庫名稱和位置 采用默認值
(6) [下一步] 啟用發布服務器 選擇作為發布的服務器
(7) [下一步] 選擇需要發布的數據庫和發布類型
(8) [下一步] 選擇注冊訂閱服務器
(9) [下一步] 完成配置
2、創建出版物
發布服務器 B、C、D 上
(1) 從[工具]菜單的 [復制] 子菜單中選擇 [創建和管理發布] 命令
(2) 選擇要創建出版物的數據庫,然后單擊 [創建發布]
(3) 在[創建發布向導]的提示對話框中單擊 [下一步] 系統就會彈出一個對話框。對話框上的內容是復制的三個類型。我們現在選第一個也就是默認的快照發布 (其他兩個大家可以去看看幫助)
(4) 單擊 [下一步] 系統要求指定可以訂閱該發布的數據庫服務器類型,
SQLSERVER 允許在不同的數據庫如 orACLE 或 ACCESS 之間進行數據復制。
但是在這里我們選擇運行 SQL SERVER 2000 的數據庫服務器
(5) 單擊 [下一步] 系統就彈出一個定義文章的對話框也就是選擇要出版的表
注意: 如果前面選擇了事務發布 則再這一步中只能選擇帶有主鍵的表
(6) 選擇發布名稱和描述
(7) 自定義發布屬性 向導提供的選擇:
是 我將自定義數據篩選, 啟用匿名訂閱和或其他自定義屬性
否 根據指定方式創建發布(建議采用自定義的方式)
(8)[下一步] 選擇篩選發布的方式
(9)[下一步] 可以選擇是否允許匿名訂閱
1) 如果選擇署名訂閱, 則需要在發布服務器上添加訂閱服務器
方法: [工具]- [復制]- [配置發布、訂閱服務器和分發的屬性]- [訂閱服務器] 中添加
否則在訂閱服務器上請求訂閱時會出現的提示: 改發布不允許匿名訂閱
如果仍然需要匿名訂閱則用以下解決辦法
[企業管理器]- [復制]- [發布內容]- [屬性]- [訂閱選項] 選擇允許匿名請求訂閱
2) 如果選擇匿名訂閱, 則配置訂閱服務器時不會出現以上提示
(10)[下一步] 設置快照 代理程序調度
(11)[下一步] 完成配置
當完成出版物的創建后創建出版物的數據庫也就變成了一個共享數據庫
有數據
srv1. 庫名..author 有字段:id,name,phone,
srv2. 庫名..author 有字段:id,name,telphone,adress
要求:
srv1. 庫名..author 增加記錄則 srv1. 庫名..author 記錄增加
srv1. 庫名..author 的 phone 字段更新,則 srv1. 庫名..author 對應字段 telphone 更新
–*/
– 大致的處理步驟
–1. 在 srv1 上創建連接服務器, 以便在 srv1 中操作 srv2, 實現同步
exec sp_addlinkedserver srv2 , , SQLOLEDB , srv2 的 sql 實例名或 ip
exec sp_addlinkedsrvlogin srv2 , false ,null, 用戶名 , 密碼
go
–2. 在 srv1 和 srv2 這兩臺電腦中, 啟動 msdtc(分布式事務處理服務), 并且設置為自動啟動
。我的電腦 – 控制面板 – 管理工具 – 服務 – 右鍵 Distributed Transaction Coordinator– 屬性 – 啟動 – 并將啟動類型設置為自動啟動
go
– 然后創建一個作業定時調用上面的同步處理存儲過程就行了
企業管理器
– 管理
–SQL Server 代理
– 右鍵作業
– 新建作業
— 常規 項中輸入作業名稱
— 步驟 項
– 新建
— 步驟名 中輸入步驟名
— 類型 中選擇 Transact-SQL 腳本(TSQL)
— 數據庫 選擇執行命令的數據庫
— 命令 中輸入要執行的語句: exec p_process
– 確定
— 調度 項
– 新建調度
— 名稱 中輸入調度名稱
— 調度類型 中選擇你的作業執行安排
– 如果選擇 反復出現
– 點 更改 來設置你的時間安排
然后將 SQL Agent 服務啟動, 并設置為自動啟動, 否則你的作業不會被執行
設置方法:
我的電腦 – 控制面板 – 管理工具 – 服務 – 右鍵 SQLSERVERAGENT– 屬性 – 啟動類型 – 選擇 自動啟動 – 確定.
–3. 實現同步處理的方法 2, 定時同步
– 在 srv1 中創建如下的同步處理存儲過程
create proc p_process
as
– 更新修改過的數據
update b set name=i.name,telphone=i.telphone
from srv2. 庫名.dbo.author b,author i
where b.id=i.id and
(b.name i.name or b.telphone i.telphone)
– 插入新增的數據
insert srv2. 庫名.dbo.author(id,name,telphone)
select id,name,telphone from author i
where not exists(
select * from srv2. 庫名.dbo.author where id=i.id)
– 刪除已經刪除的數據(如果需要的話)
delete b
from srv2. 庫名.dbo.author b
where not exists(
select * from author where id=b.id)
go
SQL 查詢語句關鍵字方法
distinct 關鍵字
顯示沒有重復記錄的商品名稱,商品價格和商品類別列表。
select distinct ware_name,price from t_ware;
使用計算列
查詢所有商品價格提高 20% 后的價格。
select ware_id,ware_name,price*1.2 from t_ware;
列的別名
a) 不使用 as
select ware_id,ware_name,price*1.2 as price_raise from t_ware;
b) 使用 as
select ware_id,ware_name,price*1.2 price_raise from t_ware;
使用邏輯表達式
a) not
顯示商品價格不大于 100 的商品
select ware_id,ware_name,price,category_id from t_ware where not price
b) and
顯示商品價格大于 100 且商品類別編號為 5 的商品
select ware_id,ware_name,price,category_id from t_ware where not price
c) or
顯示商品類別編號為 5 或 6 或 7 的商品
select ware_id,ware_name,price,category_id from t_ware where category_id=5 or category_id=6 or category_id=7;
使用 between 關鍵字
顯示商品價格在 200 元至 1000 元之間的商品(留心一下,是半開區間還是封閉區間?)
select ware_id,ware_name,price,category_id from t_ware where price between 200 and 1000;
使用 in 關鍵字
顯示商品類別為 5,6,7 且價格不小于 200 元的商品
select ware_id,ware_name,price,category_id from t_ware where category_id in (5,6,7) and price =200;
使用 like 子句進行模糊查詢
a) %(百分號)表示 0 到 n 個任意字符
select ware_id,ware_name,price,category_id from t_ware where ware_name like % 純棉 %
b) _(下劃線)表示單個的任意字符
select ware_id,ware_name,price,category_id from t_ware where ware_name like % 長袖_恤 %
轉義字符 escape 的使用
select ware_id,ware_name,price,category_id from t_ware where ware_name like %\%% escape \
使用 order by 給數據排序
select * from t_ware_category where parent_id=0 order by seq;
select * from t_ware_category where parent_id=0 order by seq asc;
select * from t_ware_category where parent_id=0 order by seq desc;
rownum
a) 查詢前 20 條商品記錄
select ware_id,ware_name,price from t_ware where rownum
b) 查詢第 11 條至第 20 條記錄
select ware_id,ware_name,price from t_ware where rownum =10 and ware_id not in (select ware_id from t_ware where rownum =10);
常用統計函數
a) sum() 返回一個數字列或計算列的總和
select sum(price) from t_ware;
b) avg()對一個數字列或計算列求平均值
c) min()返回一個數字列或一個數字表達式的最小值
d) max()返回一個數字列或一個數字表達式的最大值
e) count()返回滿面足 select 語句中指定的條件的記錄值
多表查詢和笛卡兒乘積
查詢商品編號,商品名稱,商品價格和商品類別名稱
select t_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_name from t_ware,t_ware_category where t_ware.category_id=t_ware_category.category_id;
使用 join
a) 左連接
select t_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_name from t_ware left join t_ware_category on t_ware.category_id=t_ware_category.category_id;
select w.ware_id,w.ware_name,w.price,wc.category_name from t_ware w left join t_ware_category wc on w.category_id=wc.category_id;
b) 右連接
select t_ware.ware_id,t_ware.ware_name,t_ware.price,t_ware_category.category_name from t_ware left join t_ware_category on t_ware.category_id=t_ware_category.category_id;
使用 union
select ware_id,ware_name from t_ware where ware_name like %T 恤 % union select ware_id,ware_name from t_ware where ware_name like % 手提包 %
使用 group by
a) 統計每個二級類別下有多少商品,以及商品總價值
select w.category_id,wc.category_name,count(w.ware_id),sum(w.price) from t_ware w left join t_ware_category wc on w.category_id=wc.category_id group by w.category_id,wc.category_name;
b) 統計每個一級類別下有多少商品,以及商品總價值
select wc2.category_id,wc2.category_name,sum(w.price) from t_ware w left join t_ware_category wc on w.category_id=wc.category_id left join t_ware_category wc2 on wc.parent_id=wc2.category_id group by wc2.category_id,wc2.category_name;
使用 having 對結果進行篩選
select w.category_id,wc.category_name,count(w.ware_id),sum(w.price) from t_ware w left join t_ware_category wc on w.category_id=wc.category_id group by w.category_id,wc.category_name having sum(w.price) 1000;
SQL 查詢語句精華使用簡要
一、簡單查詢
簡單的 Transact-SQL 查詢只包括選擇列表、FROM 子句和 WHERE 子句。它們分別說明所查詢列、查詢的
表或視圖、以及搜索條件等。
例如,下面的語句查詢 testtable 表中姓名為“張三”的 nickname 字段和 email 字段。
SELECT nickname,email
FROM testtable
WHERE name= 張三
(一) 選擇列表
選擇列表 (select_list) 指出所查詢列,它可以是一組列名列表、星號、表達式、變量 (包括局部變
量和全局變量)等構成。
1、選擇所有列
例如,下面語句顯示 testtable 表中所有列的數據:
SELECT *
FROM testtable
2、選擇部分列并指定它們的顯示次序
查詢結果集合中數據的排列順序與選擇列表中所指定的列名排列順序相同。
例如:
SELECT nickname,email
FROM testtable
3、更改列標題
在選擇列表中,可重新指定列標題。定義格式為:
列標題 = 列名
列名 列標題
如果指定的列標題不是標準的標識符格式時,應使用引號定界符,例如,下列語句使用漢字顯示列
標題:
SELECT 昵稱 =nickname, 電子郵件 =email
FROM testtable
4、刪除重復行
SELECT 語句中使用 ALL 或 DISTINCT 選項來顯示表中符合條件的所有行或刪除其中重復的數據行,默認為 ALL。使用 DISTINCT 選項時,對于所有重復的數據行在 SELECT 返回的結果集合中只保留一行。
5、限制返回的行數
使用 TOP n [PERCENT]選項限制返回的數據行數,TOP n 說明返回 n 行,而 TOP n PERCENT 時,說明 n 是
表示一百分數,指定返回的行數等于總行數的百分之幾。
例如:
SELECT TOP 2 *
FROM testtable
SELECT TOP 20 PERCENT *
FROM testtable
(二)FROM 子句
FROM 子句指定 SELECT 語句查詢及與查詢相關的表或視圖。在 FROM 子句中最多可指定 256 個表或視圖,
它們之間用逗號分隔。
在 FROM 子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應使用對象名限定這些列
所屬的表或視圖。例如在 usertable 和 citytable 表中同時存在 cityid 列,在查詢兩個表中的 cityid 時應
使用下面語句格式加以限定:
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在 FROM 子句中可用以下兩種格式為表或視圖指定別名:
表名 as 別名
表名 別名
(二) FROM 子句
FROM 子句指定 SELECT 語句查詢及與查詢相關的表或視圖。在 FROM 子句中最多可指定 256 個表或視圖,
它們之間用逗號分隔。
在 FROM 子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應使用對象名限定這些列
所屬的表或視圖。例如在 usertable 和 citytable 表中同時存在 cityid 列,在查詢兩個表中的 cityid 時應
使用下面語句格式加以限定:
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在 FROM 子句中可用以下兩種格式為表或視圖指定別名:
表名 as 別名
表名 別名
例如上面語句可用表的別名格式表示為:
SELECT username,b.cityid
FROM usertable a, citytable b
WHERE a.cityid=b.cityid
SELECT 不僅能從表或視圖中檢索數據,它還能夠從其它查詢語句所返回的結果集合中查詢數據。
例如:
SELECT a.au_fname+a.au_lname
FROM authors a,titleauthor ta
(SELECT title_id,title
FROM titles
WHERE ytd_sales 10000
) AS t
WHERE a.au_id=ta.au_id
AND ta.title_id=t.title_id
此例中,將 SELECT 返回的結果集合給予一別名 t,然后再從中檢索數據。
(三) 使用 WHERE 子句設置查詢條件
WHERE 子句設置查詢條件,過濾掉不需要的數據行。例如下面語句查詢年齡大于 20 的數據:
SELECT *
FROM usertable
WHERE age 20
WHERE 子句可包括各種條件運算符:
比較運算符 (大小比較):、=、=、、=、、!、!
范圍運算符 (表達式值是否在指定的范圍):BETWEEN…AND…
NOT BETWEEN…AND…
列表運算符 (判斷表達式是否為列表中的指定項):IN (項 1, 項 2……)
NOT IN (項 1, 項 2……)
模式匹配符 (判斷值是否與指定的字符通配格式相符):LIKE、NOT LIKE
空值判斷符 (判斷表達式是否為空):IS NULL、NOT IS NULL
邏輯運算符 (用于多條件的邏輯連接):NOT、AND、OR
1、范圍運算符例:age BETWEEN 10 AND 30 相當于 age =10 AND age =30
2、列表運算符例:country IN (Germany , China)
3、模式匹配符例:常用于模糊查找,它判斷列值是否與指定的字符串格式相匹配。可用于 char、
varchar、text、ntext、datetime 和 smalldatetime 等類型查詢。
可使用以下通配字符:
百分號 %:可匹配任意類型和長度的字符,如果是中文,請使用兩個百分號即 %%。
下劃線_:匹配單個任意字符,它常用來限制表達式的字符長度。
方括號 []:指定一個字符、字符串或范圍,要求所匹配對象為它們中的任一個。
[^]:其取值也[] 相同,但它要求所匹配對象為指定字符以外的任一個字符。
例如:
限制以 Publishing 結尾,使用 LIKE %Publishing
限制以 A 開頭:LIKE [A]%
限制以 A 開頭外:LIKE [^A]%
4、空值判斷符例 WHERE age IS NULL
5、邏輯運算符:優先級為 NOT、AND、OR
(四)查詢結果排序
使用 ORDER BY 子句對查詢返回的結果按一列或多列排序。ORDER BY 子句的語法格式為:
ORDER BY {column_name [ASC|DESC]} [,…n]
其中 ASC 表示升序,為默認值,DESC 為降序。ORDER BY 不能按 ntext、text 和 image 數據類型進行排
序。
例如:
SELECT *
FROM usertable
ORDER BY age desc,userid ASC
另外,可以根據表達式進行排序。
二、聯合查詢
UNION 運算符可以將兩個或兩個以上上 SELECT 語句的查詢結果集合合并成一個結果集合顯示,即執行聯
合查詢。UNION 的語法格式為:
select_statement
UNION [ALL] selectstatement
[UNION [ALL] selectstatement][…n]
其中 selectstatement 為待聯合的 SELECT 查詢語句。
ALL 選項表示將所有行合并到結果集合中。不指定該項時,被聯合查詢結果集合中的重復行將只保留一
行。
聯合查詢時,查詢結果的列標題為第一個查詢語句的列標題。因此,要定義列標題必須在第一個查詢語
句中定義。要對聯合查詢結果排序時,也必須使用第一查詢語句中的列名、列標題或者列序號。
在使用 UNION 運算符時,應保證每個聯合查詢語句的選擇列表中有相同數量的表達式,并且每個查詢選
擇表達式應具有相同的數據類型,或是可以自動將它們轉換為相同的數據類型。在自動轉換時,對于數值類型,系統將低精度的數據類型轉換為高精度的數據類型。
在包括多個查詢的 UNION 語句中,其執行順序是自左至右,使用括號可以改變這一執行順序。例如:
查詢 1 UNION (查詢 2 UNION 查詢 3)
三、連接查詢
通過連接運算符可以實現多個表查詢。連接是關系數據庫模型的主要特點,也是它區別于其它類型
數據庫管理系統的一個標志。
在關系數據庫管理系統中,表建立時各數據之間的關系不必確定,常把一個實體的所有信息存放在
一個表中。當檢索數據時,通過連接操作查詢出存放在多個表中的不同實體的信息。連接操作給用戶帶
來很大的靈活性,他們可以在任何時候增加新的數據類型。為不同實體創建新的表,爾后通過連接進行
查詢。
連接可以在 SELECT 語句的 FROM 子句或 WHERE 子句中建立,似是而非在 FROM 子句中指出連接時有助于
將連接操作與 WHERE 子句中的搜索條件區分開來。所以,在 Transact-SQL 中推薦使用這種方法。
SQL-92 標準所定義的 FROM 子句的連接語法格式為:
FROM join_table join_type join_table
[ON (join_condition)]
其中 join_table 指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一
個表操作的連接又稱做自連接。
join_type 指出連接類型,可分為三種:內連接、外連接和交叉連接。內連接 (INNER JOIN) 使用比
較運算符進行表間某 (些) 列數據的比較操作,并列出這些表中與連接條件相匹配的數據行。根據所使用
的比較方式不同,內連接又分為等值連接、自然連接和不等連接三種。
外連接分為左外連接 (LEFT OUTER JOIN 或 LEFT JOIN)、右外連接(RIGHT OUTER JOIN 或 RIGHT JOIN)
和全外連接 (FULL OUTER JOIN 或 FULL JOIN) 三種。與內連接不同的是,外連接不只列出與連接條件相匹配的行,而是列出左表 (左外連接時)、右表(右外連接時) 或兩個表 (全外連接時) 中所有符合搜索條件的
數據行。
交叉連接 (CROSS JOIN) 沒有 WHERE 子句,它返回連接表中所有數據行的笛卡爾積,其結果集合中的
數據行數等于第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
連接操作中的 ON (join_condition) 子句指出連接條件,它由被連接表中的列和比較運算符、邏輯
運算符等構成。
無論哪種連接都不能對 text、ntext 和 image 數據類型列進行直接連接,但可以對這三種列進行間接
連接。例如:
SELECT p1.pub_id,p2.pub_id,p1.pr_info
FROM pub_info AS p1 INNER JOIN pub_info AS p2
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)
(一)內連接
內連接查詢操作列出與連接條件匹配的數據行,它使用比較運算符比較被連接列的列值。內連接分
三種:
1、等值連接:在連接條件中使用等于號 (=) 運算符比較被連接列的列值,其查詢結果中列出被連接
表中的所有列,包括其中的重復列。
2、不等連接:在連接條件使用除等于運算符以外的其它比較運算符比較被連接的列的列值。這些
運算符包括、=、=、、!、! 和。
3、自然連接:在連接條件中使用等于 (=) 運算符比較被連接列的列值,但它使用選擇列表指出查詢
結果集合中所包括的列,并刪除連接表中的重復列。
例,下面使用等值連接列出 authors 和 publishers 表中位于同一城市的作者和出版社:
SELECT *
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
又如使用自然連接,在選擇列表中刪除 authors 和 publishers 表中重復列 (city 和 state):
SELECT a.*,p.pub_id,p.pub_name,p.country
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
(二) 外連接
內連接時,返回查詢結果集合中的僅是符合查詢條件 (WHERE 搜索條件或 HAVING 條件) 和連接條件
的行。而采用外連接時,它返回到查詢結果集合中的不僅包含符合連接條件的行,而且還包括左表 (左外
連接時)、右表 (右外連接時) 或兩個邊接表 (全外連接) 中的所有數據行。
如下面使用左外連接將論壇內容和作者信息連接起來:
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b
ON a.username=b.username
下面使用全外連接將 city 表中的所有作者以及 user 表中的所有作者,以及他們所在的城市:
SELECT a.*,b.*
FROM city as a FULL OUTER JOIN user as b
ON a.username=b.username
(三)交叉連接
交叉連接不帶 WHERE 子句,它返回被連接的兩個表所有數據行的笛卡爾積,返回到結果集合中的數
據行數等于第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
例,titles 表中有 6 類圖書,而 publishers 表中有 8 家出版社,則下列交叉連接檢索到的記錄數將等
于 6 *8=48 行。
SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY type
SQL 查詢語句精華大全
一、簡單查詢
簡單的 Transact-SQL 查詢只包括選擇列表、FROM 子句和 WHERE 子句。它們分別說明所查詢列、查詢的
表或視圖、以及搜索條件等。
例如,下面的語句查詢 testtable 表中姓名為“張三”的 nickname 字段和 email 字段。
SELECT nickname,email
FROM testtable
WHERE name= 張三
(一) 選擇列表
選擇列表 (select_list) 指出所查詢列,它可以是一組列名列表、星號、表達式、變量 (包括局部變
量和全局變量)等構成。
1、選擇所有列
例如,下面語句顯示 testtable 表中所有列的數據:
SELECT *
FROM testtable
2、選擇部分列并指定它們的顯示次序
查詢結果集合中數據的排列順序與選擇列表中所指定的列名排列順序相同。
例如:
SELECT nickname,email
FROM testtable
3、更改列標題
在選擇列表中,可重新指定列標題。定義格式為:
列標題 = 列名
列名 列標題
如果指定的列標題不是標準的標識符格式時,應使用引號定界符,例如,下列語句使用漢字顯示列
標題:
SELECT 昵稱 =nickname, 電子郵件 =email
FROM testtable
4、刪除重復行
SELECT 語句中使用 ALL 或 DISTINCT 選項來顯示表中符合條件的所有行或刪除其中重復的數據行,默認
為 ALL。使用 DISTINCT 選項時,對于所有重復的數據行在 SELECT 返回的結果集合中只保留一行。
5、限制返回的行數
使用 TOP n [PERCENT]選項限制返回的數據行數,TOP n 說明返回 n 行,而 TOP n PERCENT 時,說明 n 是
表示一百分數,指定返回的行數等于總行數的百分之幾。
例如:
SELECT TOP 2 *
FROM testtable
SELECT TOP 20 PERCENT *
FROM testtable
(二) FROM 子句
FROM 子句指定 SELECT 語句查詢及與查詢相關的表或視圖。在 FROM 子句中最多可指定 256 個表或視圖,
它們之間用逗號分隔。
在 FROM 子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應使用對象名限定這些列
所屬的表或視圖。例如在 usertable 和 citytable 表中同時存在 cityid 列,在查詢兩個表中的 cityid 時應
使用下面語句格式加以限定:
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在 FROM 子句中可用以下兩種格式為表或視圖指定別名:
表名 as 別名
表名 別名
例如上面語句可用表的別名格式表示為:
SELECT username,b.cityid
FROM usertable a,citytable b
WHERE a.cityid=b.cityid
SELECT 不僅能從表或視圖中檢索數據,它還能夠從其它查詢語句所返回的結果集合中查詢數據。
例如:
SELECT a.au_fname+a.au_lname
FROM authors a,titleauthor ta
(SELECT title_id,title
FROM titles
WHERE ytd_sales 10000
) AS t
WHERE a.au_id=ta.au_id
AND ta.title_id=t.title_id
此例中,將 SELECT 返回的結果集合給予一別名 t,然后再從中檢索數據。
(三) 使用 WHERE 子句設置查詢條件
WHERE 子句設置查詢條件,過濾掉不需要的數據行。例如下面語句查詢年齡大于 20 的數據:
SELECT *
FROM usertable
WHERE age 20
WHERE 子句可包括各種條件運算符:
比較運算符 (大小比較):、=、=、、=、、!、!
范圍運算符 (表達式值是否在指定的范圍):BETWEEN…AND…
NOT BETWEEN…AND…
列表運算符 (判斷表達式是否為列表中的指定項):IN (項 1, 項 2……)
NOT IN (項 1, 項 2……)
模式匹配符 (判斷值是否與指定的字符通配格式相符):LIKE、NOT LIKE
空值判斷符 (判斷表達式是否為空):IS NULL、NOT IS NULL
邏輯運算符 (用于多條件的邏輯連接):NOT、AND、OR
1、范圍運算符例:age BETWEEN 10 AND 30 相當于 age =10 AND age =30
2、列表運算符例:country IN (Germany , China)
3、模式匹配符例:常用于模糊查找,它判斷列值是否與指定的字符串格式相匹配。可用于 char、
varchar、text、ntext、datetime 和 smalldatetime 等類型查詢。
可使用以下通配字符:
百分號 %:可匹配任意類型和長度的字符,如果是中文,請使用兩個百分號即 %%。
下劃線_:匹配單個任意字符,它常用來限制表達式的字符長度。
方括號 []:指定一個字符、字符串或范圍,要求所匹配對象為它們中的任一個。
[^]:其取值也[] 相同,但它要求所匹配對象為指定字符以外的任一個字符。
例如:
限制以 Publishing 結尾,使用 LIKE %Publishing
限制以 A 開頭:LIKE [A]%
限制以 A 開頭外:LIKE [^A]%
4、空值判斷符例 WHERE age IS NULL
5、邏輯運算符:優先級為 NOT、AND、OR
(四)查詢結果排序
使用 ORDER BY 子句對查詢返回的結果按一列或多列排序。ORDER BY 子句的語法格式為:
ORDER BY {column_name [ASC|DESC]} [,…n]
其中 ASC 表示升序,為默認值,DESC 為降序。ORDER BY 不能按 ntext、text 和 image 數據類型進行排
序。
例如:
SELECT *
FROM usertable
ORDER BY age desc,userid ASC
另外,可以根據表達式進行排序。
二、聯合查詢
UNION 運算符可以將兩個或兩個以上上 SELECT 語句的查詢結果集合合并成一個結果集合顯示,即執行聯
合查詢。UNION 的語法格式為:
select_statement
UNION [ALL] selectstatement
[UNION [ALL] selectstatement][…n]
其中 selectstatement 為待聯合的 SELECT 查詢語句。
ALL 選項表示將所有行合并到結果集合中。不指定該項時,被聯合查詢結果集合中的重復行將只保留一
行。
聯合查詢時,查詢結果的列標題為第一個查詢語句的列標題。因此,要定義列標題必須在第一個查詢語
句中定義。要對聯合查詢結果排序時,也必須使用第一查詢語句中的列名、列標題或者列序號。
在使用 UNION 運算符時,應保證每個聯合查詢語句的選擇列表中有相同數量的表達式,并且每個查詢選
擇表達式應具有相同的數據類型,或是可以自動將它們轉換為相同的數據類型。在自動轉換時,對于數值類
型,系統將低精度的數據類型轉換為高精度的數據類型。
在包括多個查詢的 UNION 語句中,其執行順序是自左至右,使用括號可以改變這一執行順序。例如:
查詢 1 UNION (查詢 2 UNION 查詢 3)
三、連接查詢
通過連接運算符可以實現多個表查詢。連接是關系數據庫模型的主要特點,也是它區別于其它類型
數據庫管理系統的一個標志。
在關系數據庫管理系統中,表建立時各數據之間的關系不必確定,常把一個實體的所有信息存放在
一個表中。當檢索數據時,通過連接操作查詢出存放在多個表中的不同實體的信息。連接操作給用戶帶
來很大的靈活性,他們可以在任何時候增加新的數據類型。為不同實體創建新的表,爾后通過連接進行
查詢。
連接可以在 SELECT 語句的 FROM 子句或 WHERE 子句中建立,似是而非在 FROM 子句中指出連接時有助于
將連接操作與 WHERE 子句中的搜索條件區分開來。所以,在 Transact-SQL 中推薦使用這種方法。
SQL-92 標準所定義的 FROM 子句的連接語法格式為:
FROM join_table join_type join_table
[ON (join_condition)]
其中 join_table 指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一
個表操作的連接又稱做自連接。
join_type 指出連接類型,可分為三種:內連接、外連接和交叉連接。內連接 (INNER JOIN) 使用比
較運算符進行表間某 (些) 列數據的比較操作,并列出這些表中與連接條件相匹配的數據行。根據所使用
的比較方式不同,內連接又分為等值連接、自然連接和不等連接三種。
外連接分為左外連接 (LEFT OUTER JOIN 或 LEFT JOIN)、右外連接(RIGHT OUTER JOIN 或 RIGHT JOIN)
和全外連接 (FULL OUTER JOIN 或 FULL JOIN) 三種。與內連接不同的是,外連接不只列出與連接條件相匹
配的行,而是列出左表 (左外連接時)、右表(右外連接時) 或兩個表 (全外連接時) 中所有符合搜索條件的
數據行。
交叉連接 (CROSS JOIN) 沒有 WHERE 子句,它返回連接表中所有數據行的笛卡爾積,其結果集合中的
數據行數等于第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
連接操作中的 ON (join_condition) 子句指出連接條件,它由被連接表中的列和比較運算符、邏輯
運算符等構成。
無論哪種連接都不能對 text、ntext 和 image 數據類型列進行直接連接,但可以對這三種列進行間接
連接。例如:
SELECT p1.pub_id,p2.pub_id,p1.pr_info
FROM pub_info AS p1 INNER JOIN pub_info AS p2
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)
(一)內連接
內連接查詢操作列出與連接條件匹配的數據行,它使用比較運算符比較被連接列的列值。內連接分
三種:
1、等值連接:在連接條件中使用等于號 (=) 運算符比較被連接列的列值,其查詢結果中列出被連接
表中的所有列,包括其中的重復列。
2、不等連接:在連接條件使用除等于運算符以外的其它比較運算符比較被連接的列的列值。這些
運算符包括、=、=、、!、! 和。
3、自然連接:在連接條件中使用等于 (=) 運算符比較被連接列的列值,但它使用選擇列表指出查詢
結果集合中所包括的列,并刪除連接表中的重復列。
例,下面使用等值連接列出 authors 和 publishers 表中位于同一城市的作者和出版社:
SELECT *
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
又如使用自然連接,在選擇列表中刪除 authors 和 publishers 表中重復列 (city 和 state):
SELECT a.*,p.pub_id,p.pub_name,p.country
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
(二) 外連接
內連接時,返回查詢結果集合中的僅是符合查詢條件 (WHERE 搜索條件或 HAVING 條件) 和連接條件
的行。而采用外連接時,它返回到查詢結果集合中的不僅包含符合連接條件的行,而且還包括左表 (左外
連接時)、右表 (右外連接時) 或兩個邊接表 (全外連接) 中的所有數據行。
如下面使用左外連接將論壇內容和作者信息連接起來:
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b
ON a.username=b.username
下面使用全外連接將 city 表中的所有作者以及 user 表中的所有作者,以及他們所在的城市:
SELECT a.*,b.*
FROM city as a FULL OUTER JOIN user as b
ON a.username=b.username
(三)交叉連接
交叉連接不帶 WHERE 子句,它返回被連接的兩個表所有數據行的笛卡爾積,返回到結果集合中的數
據行數等于第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
例,titles 表中有 6 類圖書,而 publishers 表中有 8 家出版社,則下列交叉連接檢索到的記錄數將等
于 6 *8=48 行。
SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY typeSQL 核心語句 (非常實用的幾個技巧) 插入數據
向表中添加一個新記錄,你要使用 SQL INSERT 語句。這里有一個如何使用這種語句的例子:
INSERT mytable (mycolumn) VALUES (‘some data’)
這個語句把字符串’some data’插入表 mytable 的 mycolumn 字段中。將要被插入數據的字段的名字在第一個括號中指定,實際的數據在第二個括號中給出。
INSERT 語句的完整句法如下:
INSERT [INTO] {table_name|view_name} [(column_list)] {DEFAULT VALUES |
Values_list | select_statement}
如果一個表有多個字段,通過把字段名和字段值用逗號隔開,你可以向所有的字段中插入數據。假設表 mytable 有三個字段 first_column,second_column, 和 third_column。下面的 INSERT 語句添加了一條三個字段都有值的完整記錄:
INSERT mytable (first_column,second_column,third_column)
VALUES (‘some data’,’some more data’,’yet more data’)
注意
你可以使用 INSERT 語句向文本型字段中插入數據。但是,如果你需要輸入很長的字符串,你應該使用 WRITETEXT 語句。這部分內容對本書來說太高級了,因此不加討論。要了解更多的信息,請參考 Microsoft SQL Sever 的文檔。
如果你在 INSERT 語句中只指定兩個字段和數據會怎么樣呢?換句話說,你向一個表中插入一條新記錄,但有一個字段沒有提供數據。在這種情況下,有下面的四種可能:
如果該字段有一個缺省值,該值會被使用。例如,假設你插入新記錄時沒有給字段 third_column 提供數據,而這個字段有一個缺省值’some value’。在這種情況下,當新記錄建立時會插入值’some value’。
如果該字段可以接受空值,而且沒有缺省值,則會被插入空值。
如果該字段不能接受空值,而且沒有缺省值,就會出現錯誤。你會收到錯誤信息:
The column in table mytable may not be null.
最后,如果該字段是一個標識字段,那么它會自動產生一個新值。當你向一個有標識字段的表中插入新記錄時,只要忽略該字段,標識字段會給自己賦一個新值。
注意
向一個有標識字段的表中插入新記錄后,你可以用 SQL 變量 @@identity 來訪問新記錄
的標識字段的值。考慮如下的 SQL 語句:
INSERT mytable (first_column) VALUES(‘some value’)
INSERT anothertable(another_first,another_second)
VALUES(@@identity,’some value’)
如果表 mytable 有一個標識字段,該字段的值會被插入表 anothertable 的 another_first 字段。這是因為變量 @@identity 總是保存最后一次插入標識字段的值。
字段 another_first 應該與字段 first_column 有相同的數據類型。但是,字段 another_first 不能是應該標識字段。Another_first 字段用來保存字段 first_column 的值。
刪除記錄
要從表中刪除一個或多個記錄,需要使用 SQL DELETE 語句。你可以給 DELETE 語句提供 WHERE 子句。WHERE 子句用來選擇要刪除的記錄。例如,下面的這個 DELETE 語句只刪除字段 first_column 的值等于’Delete Me’的記錄:
DELETE mytable WHERE first_column=’Deltet Me’
DELETE 語句的完整句法如下:
DELETE [FROM] {table_name|view_name} [WHERE clause]
在 SQL SELECT 語句中可以使用的任何條件都可以在 DELECT 語句的 WHERE 子句中使用。例如,下面的這個 DELETE 語句只刪除那些 first_column 字段的值為’goodbye’或 second_column 字段的值為’so long’的記錄:
DELETE mytable WHERE first_column=’goodby’OR second_column=’so long’
如果你不給 DELETE 語句提供 WHERE 子句,表中的所有記錄都將被刪除。你不應該有這種想法。如果你想刪除應該表中的所有記錄,應使用第十章所講的 TRUNCATE TABLE 語句。
注意
為什么要用 TRUNCATE TABLE 語句代替 DELETE 語句?當你使用 TRUNCATE TABLE 語句時,記錄的刪除是不作記錄的。也就是說,這意味著 TRUNCATE TABLE 要比 DELETE 快得多。
更新記錄
要修改表中已經存在的一條或多條記錄,應使用 SQL UPDATE 語句。同 DELETE 語句一樣,UPDATE 語句可以使用 WHERE 子句來選擇更新特定的記錄。請看這個例子:
UPDATE mytable SET first_column=’Updated!’WHERE second_column=’Update Me!’
這個 UPDATE 語句更新所有 second_column 字段的值為’Update Me!’的記錄。對所有被選中的記錄,字段 first_column 的值被置為’Updated!’。
下面是 UPDATE 語句的完整句法:
UPDATE {table_name|view_name} SET [{table_name|view_name}]
{column_list|variable_list|variable_and_column_list}
[,{column_list2|variable_list2|variable_and_column_list2}…
[,{column_listN|variable_listN|variable_and_column_listN}]][WHERE clause]
注意
你可以對文本型字段使用 UPDATE 語句。但是,如果你需要更新很長的字符串,應使用 UPDATETEXT 語句。這部分內容對本書來說太高級了,因此不加討論。要了解更多的信息,請參考 Microsoft SQL Sever 的文檔。
如果你不提供 WHERE 子句,表中的所有記錄都將被更新。有時這是有用的。例如,如果你想把表 titles 中的所有書的價格加倍,你可以使用如下的 UPDATE 語句:
你也可以同時更新多個字段。例如,下面的 UPDATE 語句同時更新 first_column,second_column, 和 third_column 這三個字段:
UPDATE mytable SET first_column=’Updated!’
Second_column=’Updated!’
Third_column=’Updated!’
WHERE first_column=’Update Me1’
技巧
SQL 忽略語句中多余的空格。你可以把 SQL 語句寫成任何你最容易讀的格式。
用 SELECT 創建記錄和表
你也許已經注意到,INSERT 語句與 DELETE 語句和 UPDATE 語句有一點不同,它一次只操作一個記錄。然而,有一個方法可以使 INSERT 語句一次添加多個記錄。要作到這一點,你需要把 INSERT 語句與 SELECT 語句結合起來,象這樣:
INSERT mytable (first_column,second_column)
SELECT another_first,another_second
FROM anothertable
WHERE another_first=’Copy Me!’
這個語句從 anothertable 拷貝記錄到 mytable. 只有表 anothertable 中字段 another_first 的值為’Copy Me!’的記錄才被拷貝。
當為一個表中的記錄建立備份時,這種形式的 INSERT 語句是非常有用的。在刪除一個表中的記錄之前,你可以先用這種方法把它們拷貝到另一個表中。
如果你需要拷貝整個表,你可以使用 SELECT INTO 語句。例如,下面的語句創建了一個名為 newtable 的新表,該表包含表 mytable 的所有數據:
SELECT * INTO newtable FROM mytable
你也可以指定只有特定的字段被用來創建這個新表。要做到這一點,只需在字段列表中指定你想要拷貝的字段。另外,你可以使用 WHERE 子句來限制拷貝到新表中的記錄。下面的例子只拷貝字段 second_columnd 的值等于’Copy Me!’的記錄的 first_column 字段。
SELECT first_column INTO newtable
FROM mytable
WHERE second_column=’Copy Me!’
使用 SQL 修改已經建立的表是很困難的。例如,如果你向一個表中添加了一個字段,沒有容易的辦法來去除它。另外,如果你不小心把一個字段的數據類型給錯了,你將沒有辦法改變它。但是,使用本節中講述的 SQL 語句,你可以繞過這兩個問題。
例如,假設你想從一個表中刪除一個字段。使用 SELECT INTO 語句,你可以創建該表的一個拷貝,但不包含要刪除的字段。這使你既刪除了該字段,又保留了不想刪除的數據。
如果你想改變一個字段的數據類型,你可以創建一個包含正確數據類型字段的新表。創建好該表后,你就可以結合使用 UPDATE 語句和 SELECT 語句,把原來表中的所有數據拷貝到新表中。通過這種方法,你既可以修改表的結構,又能保存原有的數據。
jsp 連接數據庫:
%@ page language= java import= java.util.*, java.sql.* pageEncoding= GB18030 %
%
String username = request.getParameter(username
String password = request.getParameter(password
String password2 = request.getParameter(password2
Class.forName(com.mysql.jdbc.Driver
Connection conn = DriverManager.getConnection(jdbc:mysql://localhost/bishe , root , admin
String sqlQuery = select count(*) from user where username = ?
PreparedStatement psQuery = conn.prepareStatement(sqlQuery);
psQuery.setString(1, username);
ResultSet rs = psQuery.executeQuery();
rs.next();
int count = rs.getInt(1);
if(count 0) {
response.sendRedirect(registerFail.jsp
psQuery.close();
conn.close();
return;
}
String sql = insert into user values (null, ?, ?)
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, username);
ps.setString(2, password);
ps.executeUpdate();
ps.close();
conn.close();
response.sendRedirect(registerSuccess.jsp
%
javaBean 數據庫連接:
Class.forName(com.mysql.jdbc.Driver
Connection conn = DriverManager.getConnection(jdbc:mysql://localhost/spring , root , bjsxt
String sql = insert into user values (null, ?, ?)
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, u.getUsername());
ps.setString(2, u.getPassword());
ps.executeUpdate();
ps.close();
conn.close();
hibernate 數據操作
Configuration cfg = new Configuration().configure();
factory = cfg.buildSessionFactory().openSession();
Session session = HibernateUtil.getSession();
// 開啟事務
session.beginTransaction();
// 保存數據
session.save(p);
// 事務提交
session.getTransaction().commit();
// 關閉 session
HibernateUtil.closeSession(session);
select(選擇) 字段 from (表名) where(篩選條件)
group by(字段名,按什么分組) having (條件, 在每組中篩選)
order by (排序)
—————- 局部變量 ————–
聲明:
declare @name varchar(30)– 聲明一個存放學生名稱的變量,最多存放 30 個字符
declare @age int
————— 全局變量 —————–
輸出:
print 服務器的名稱:+@@servername
select @@servername as 是服務器的名稱
print 當前錯誤號:+@@error(錯誤的: 將 varchar 值 當前錯誤號:轉換為數據類型為 int 的列時發生語法錯誤。)
print 當前錯誤號: +convert(varchar(5),@@error)(正確)
—————if-else 語句 —————-
declare @myavg float
select @myavg=AVG(writtenExam) from stuMarks
print 本班平均分 +convert(varchar(5),@myavg)
if(@myavg 70) —(begin-end 相當于 java 中的{})
begin
print 本班筆試成績優秀,前三名的成績為:
select top 3 * from stuMarks order by writtenExam desc
end
else
begin
print 本班筆試成績較差, 后三名的成績為:
select top 3 * from stuMarks order by writtenExam [asc]
end
—————-while 循環語句 ————-
declare @n int
while(1=1)– 條件永遠成立
begin
select @n=count(*) from stuMarks where writtenExam 60 – 統計不及格的人數
if(@n 0)
update stuMarks set writtenExam=writtenExam+2 – 每人加 2 分
else
break – 退出循環
end
print 加分后的成績如下:
select * from stuMarks
—————–case 多分支語句 ————-
select * from stuMarks – 原始數據
print ABCDE 五級顯示成績如下:
select stuNo, 成績 =case
when writtenExam 60 then E
when writtenExam between 60 and 69 then D
when writtenExam between 70 and 79 then C
when writtenExam between 80 and 89 then B
else A
end
from stuMarks
—————–go 批處理語句 ——————
use Master
go
create table stuInfo
(
id int not null,
name varchar(20)
)
go
—————–in 和 not in 子查詢 ——————–
in 查詢:
select stuName from stuInfo
where stuNo in (select stuNo from stuMarks where writtenExam=60)
not in 查詢:
select stuName from stuInfo
where stuNo not in (select stuNo from stuMarks)
go
——————exists 和 not exists 子查詢 ————
exists 子查詢:
1、if exists(select * from sysdatabases where name= stuDB)
drop database stuDB
go
2、if exists(select * from stuMarks where writtenExam 80)
begin
print 本班有人筆試成績高于 80 分,每人只加 2 分,加分后的成績如下:
update stuMarks set writtenExam=writtenExam+2
select * from stuMarks
end
else
begin
print 本班無人筆試成績高于 80 分,每人可以加 5 分,加分后的成績如下:
update stuMarks set writtenExam=writtenExam+5
select * from stuMarks
end
go
not exists 子查詢:
if not exists(select * from stuMarks where writtenExam 60 and labExam 60)
begin
print 本班無人通過考試,試題偏難,每人加 3 分,加分后的成績如下:
update stuMarks set writtenExam=writtenExam+3,labExam=labExam+3
select * from stuMarks
end
else
begin
print 本班考試成績一般,每人只加 1 分,加分后的成績如下:
update stuMarks set writtenExam=writtenExam+1,labExam=labExam+1
select * from stuMarks
end
感謝各位的閱讀,以上就是“常用的 SQL 查詢語句大全”的內容了,經過本文的學習后,相信大家對常用的 SQL 查詢語句大全這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是丸趣 TV,丸趣 TV 小編將為大家推送更多相關知識點的文章,歡迎關注!