復雜的sql
Ⅰ 復雜的sql語句
不是很復雜,只有一個子查詢,最後那個from里邊有很多內連接和外連接,主要是跟業務相關的,表多點不復雜,不知道你的業務邏輯,說不清楚
主要函數,
case when,就是根據不同的case選擇一個結果
decode,跟case when差不多,DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )
nvl,判斷是否為空的,NVL( string1, replace_with) ,如果為空就用replace_with代替
group by rollup,不太容易說清楚,給你個連接自己看吧做個小例子也容易理解
http://blog.csdn.net/ghostgant/article/details/5699731
Ⅱ 過於復雜的sql語句有哪些缺陷
過於復雜的sql語句有哪些缺陷
不同的資料庫甚至相同資料庫的不同版本都可能不一樣,具體可以查詢聯機幫助,或參閱產品規格說明。總的來說SQL語句的最大長度限制都是很大的,編寫SQL語句一般不需要考慮語句的長度問題。例如ACCESS的SQL最大長度約為6,4000個、MSSQL為65,536 * 網路數據包。像這樣的長度,足夠你寫下長篇大論了。但是話要說回來,一個太長的語句其執行效率變得會低下,盡量避免編寫太長和過於復雜的SQL語句還是非常必要的。
Ⅲ 一個復雜的sql 語句
DECLARE @key NVARCHAR(MAX)
SET @key = '中'
/*
關鍵字表=KeyTable
關鍵欄位=KeyWord
內容表=MainTable
內容欄位=MainString
1.先把內容表和關鍵表相交的資料取出來,填在TempStr,相交則填資料,不相交則留空
2.在取出資料後生成一個臨時的表TempTable,進行@Key的查詢
3.在TempTable之上再進行最後的判斷查詢,如果TempStr為空時,則只在@Key兩邊加括弧,否則將在TempStr兩邊加括弧
*/
SELECT CASE WHEN
TempStr IS NULL
THEN
REPLACE(Mainstring,@key,'('+@key +')')
ELSE
REPLACE(Mainstring,TempStr,'('+TempStr+')')
END AS FinalWord
FROM
(SELECT Mainstring,
(SELECT TOP 1 Keyword
FROM KeyTable
WHERE MainTable.Mainstring LIKE KeyTable.keyword + '%'
) AS TempStr
FROM MainTable
WHERE Mainstring LIKE @key + '%'
) AS TempTable
Ⅳ 復雜的SQL 語句
select 職工號,姓名,性別,出生日期 into infor_da from 表 where 婚姻狀況='已婚' order by 出生日期 desc
exec master..xp_cmdshell 'bcp 資料庫名..infor_da out c:\ma_da.txt -c -t'
也可以這樣,直接導出結果,不用放入臨時表
exec master..xp_cmdshell 'bcp "select 職工號,姓名,性別,出生日期 into infor_da from 資料庫名..表 where 婚姻狀況=''已婚'' order by 出生日期 desc" queryout c:\ma_da.txt -c -t'
樓上的方式太不前衛了,還需要開始,運行,輸入cmd,用我的方式一勞永逸
Ⅳ SQL怎樣處理復雜的數據查詢關系
sql查詢問題比較靈活,常用是多表查詢,有如下幾種供參考:
1、笛卡爾積:select * from 表1,表2;( 列數相加,行數記錄相乘)
2:等值連接:select * from 表1 s1,表2 s2 where s1.id = s2.id;
3、外連接:在等值連接的基礎上加上主表中的未匹配數據(左外和右外)
左外:select * from 表1 s1 left join 表2 s2 on s1.id = s2.id
右外:select * from 表1 s1 right join 表2 s2 on s1.id = s2.id
全外:select * from 表1 s1 full join 表2 s2 on s1.id = s2.id
4、內連接(等值連接的一種)
select * from 表1 s1 inner join 表2 s2 on s1.id = s2.id
5、子查詢:子查詢在外部查詢的FROM子句之後使用時,一般被當作一個數據源使用
(註:id為兩張表的相同欄位,全文)
Ⅵ 求一個復雜的SQL語句
-- =============================================
-- Author: <Rocky,f_split>
-- Create date: <2010.11.4>
-- Description: <將傳入的參數以字元分割,並返回表格形式的參數所分割出來的值>
--select * from f_split('1,2,3,4,5,6',',')
-- =============================================
create function f_split(@SourceSql varchar(8000),@StrSeprate varchar(10))
returns @temp table(a varchar(100))
as
begin
declare @i int
set @SourceSql=rtrim(ltrim(@SourceSql)) --去掉字元中的空格
set @i=charindex(@StrSeprate,@SourceSql) --找分割符在字元中的位置
while @i>=1
begin
insert @temp values(left(@SourceSql,@i-1))
set @SourceSql=substring(@SourceSql,@i+1,len(@SourceSql)-@i)
set @i=charindex(@StrSeprate,@SourceSql)
end
if @SourceSql<>''
insert @temp values(@SourceSql)
return
end
GO
IF EXISTS(SELECT * FROM SYSOBJECTS WHERE NAME='test_4')
DROP TABLE test_4
GO
create table test_4
(
id varchar(20) not null,
value varchar(100) not null
)
insert into test_4 values('1008','A1|A2|A3')
insert into test_4 values('1009','B1|B2|B3|B4')
DECLARE @COUNT INT,@INDEX INT,@ID VARCHAR(20),@VALUE VARCHAR(100)
if object_id(N'[tempdb].dbo.[#TEMP_TEST_4_1]')>0
DROP TABLE #TEMP_TEST_4_1
if object_id(N'[tempdb].dbo.[#TEMP_TEST_4_2]')>0
DROP TABLE #TEMP_TEST_4_2
SELECT * INTO #TEMP_TEST_4_2 FROM test_4 WHERE 1=2
SELECT IDENTITY(INT,1,1) AS IDX ,* INTO #TEMP_TEST_4_1 FROM test_4
SELECT @COUNT=COUNT(*) FROM #TEMP_TEST_4_1
SET @INDEX=1
WHILE (@INDEX<=@COUNT)
BEGIN
SELECT @ID=ID,@VALUE=VALUE FROM #TEMP_TEST_4_1 WHERE IDX=@INDEX
INSERT INTO #TEMP_TEST_4_2 SELECT @ID,* FROM F_SPLIT(@VALUE,'|')
SET @INDEX=@INDEX+1
END
SELECT * FROM #TEMP_TEST_4_2
以上代碼經過測試,完全能滿足你的需求,請採納,謝謝!
Ⅶ 比較復雜的sql語句
如果你的是ACCESS資料庫或者MS SQL資料庫,可以使用視圖來實現,做起來很容易的。你可以試一下。
以下介紹主要方法:
INNER JOIN 運算
組合兩個表中的記錄,只要在公共欄位之中有相符的值。
語法
FROM table1 INNER JOIN table2 ON table1.field1 compopr table2.field2
INNER JOIN 運算可分為以下幾個部分:
部分 說明
table1, table2 記錄被組合的表的名稱。
field1, field2 被聯接的欄位的名稱。若它們不是由數字構成的,則這些欄位必須為相同的數據類型並包含同類數據,但它們無須具有相同的名稱。
compopr 任何的關系比較運運算元:"=," "<," ">," "<=," ">=," 或 "<>."
說明
可以在 FROM 子句中使用INNER JOIN運算。.這是最普通的聯接類型。只要在這兩個表的公共欄位之中有相符值,內部聯接將組合兩個表中的記錄。
可以使用 INNER JOIN 與部門表及員工表選擇每一個部門中的全部員工。反之,可以使用 LEFT JOIN或 RIGHT JOIN運算創建 outer join,從而選擇所有部門(即使有些並沒有員工)或所有員工(即使有些尚未分配到部門)。
若試圖聯接包含 Memo或 OLE Object數據的欄位,會導致錯誤。
可以聯接任何兩個相同類型的數值欄位。例如,可以聯接 AutoNumber和 Long欄位,因為它們類型相似。但不能聯接 Single 和 Double 類型的欄位。
下列示例顯示如何在類標識符欄位聯接類表及產品表:
SELECT CategoryName, ProctName
FROM Categories INNER JOIN Procts
ON Categories.CategoryID = Procts.CategoryID;
在上面的示例中,類標識符是已被聯接的欄位,但是它並不包含在查詢輸出中,因它並非被包含在 SELECT 語句之中。在這個示例中,若要包含聯接欄位,將欄位名包含在 SELECT 語句中, Categories.CategoryID.
也可以使用下列語法,在一個 JOIN 語句中鏈接多個 ON 子句:
SELECT fields
FROM table1 INNER JOIN table2
ON table1.field1 compopr table2.field1 AND
ON table1.field2 compopr table2.field2) OR
ON table1.field3 compopr table2.field3)];
也可以使用下列語法,嵌套 JOIN 語句:
SELECT fields
FROM table1 INNER JOIN
(table2 INNER JOIN [( ]table3
[INNER JOIN [( ]tablex [INNER JOIN ...)]
ON table3.field3 compopr tablex.fieldx)]
ON table2.field2 compopr table3.field3)
ON table1.field1 compopr table2.field2;
在一個 INNER JOIN 之中,可以嵌套 LEFT JOIN 或 RIGHT JOIN,但是在 LEFT JOIN 或 RIGHT JOIN 中不能嵌套 INNER JOIN。
Ⅷ 求一個稍微復雜一些的sql語句
(select count(*) from a where 出發地='香港')-(select count(*) from a where 出發地!='香港')
Ⅸ 復雜數據報表的sql 編寫求助
本人也是做這行的,有11年了,就你的問題只想跟你說:
1、SQL語句其它沒什麼難度,首先了解左連接,右連接,全連接這三個方面的內容。
2、復雜SQL也是基於簡單SQL的基礎上,是一種簡單SQL的靈活應用已。
3、有前輩帶領的環境下,最好向前輩門多多提問,不用看書,看一天書,不如前輩一分鍾的指導
4、業務部門有報表需求時,你要求接個簡單的,或從前輩那接過來,親自完成,但代碼一定要親自寫,不懂問前輩,這比什麼進步都快。
5、我帶過很多的徒弟,一般這么要求他們,進步也很快,保證3次之後可獨立完成。
Ⅹ 復雜的sql語句怎麼寫
1、select * from 表 where year(列名) = year(getdate())-1 and month(列名)= 3 --這個比較容易理解,就不解釋了
2、select datepart(wk,dateadd(year,-1,getdate())) -- 去年的今天是去年的第幾周
select datepart(wk,dateadd(day,1-day(dateadd(year,-1,getdate())),dateadd(year,-1,getdate()))) -- 去年的本月的1號是去年的第幾周
select datepart(wk,dateadd(year,-1,getdate())) - datepart(wk,dateadd(day,1-day(dateadd(year,-1,getdate())),dateadd(year,-1,getdate()))) --上邊兩者相減就是去年的今天是去年本月的第幾周