SQL 達人的工作現場攻略筆記 | 拾書所

SQL 達人的工作現場攻略筆記

$ 458 元 原價 580

一本告訴您如何正確編寫與思考SQL的書籍


本書深入探討SQL語法,諸如CASE 陳述式、視窗函數、外部連結、關聯子查詢、HAVING子句、EXISTS,如果您已經了解使用SQL指令的基本語法,應該就能順利閱讀本書。本書的第一部會以一章介紹一個這類SQL工具,希望大家透過範例學會這些工具的使用方法。請大家務必動手撰寫這些程式碼。基本上,會希望各位讀者從頭開始閱讀本書,但如果有些內容已經很熟悉,不妨直接跳至有興趣的章節閱讀。

幫助您了解SQL的真面目
。或許大家會覺得這麼說很神奇,但其實SQL就是如此神奇的程式語言。有些初學者會遇到一些很神奇的事,例如一開始覺得SQL是能輕易實現簡單目的的語言,但隨著想要深入了解,就遇到無法合理解釋的語言規格,或是想要寫稍微複雜一點的程式,就被語法絆住腳步的情況。為什麼與NULL有關的SQL動作會如此混亂?為什麼用於資料列比對的關聯子查詢語法如此困難,有必要存在嗎?為什麼SQL沒有程序語言的迴圈或變數這類工具?為什麼SQL如此難以呈現「全部的」?以本書將為了具有這類好奇心的讀者,從背景知識開始解說SQL的原理與開發這個語言的人究竟在想什麼,才把SQL打造成這副模樣。


本書特色:
.SQL經典暢銷書,資料庫開發人員必備案頭書的全新改版
.適用於各種資料庫系統。包括Oracle、SQL Server、DB2、PostgreSQL、MySQL
.可以立即使用的實用範例

 

<序>

本書自初版發行至今已經過十年,對筆者來說,本書的初版是第一次掇筆撰寫的書,也就是所謂的處女作,完全是在不知道自己的所知所聞與文章會被如何接受的狀態下所寫。幸運的是,第一版得到許多讀者的青睞而成為稍微長銷的SQL解說書,也因為有這樣的支持,才得到本次校訂再版的機會,首先,再次感謝給予本書第二次機會的讀者。

本書得以長銷的理由之一在於RDB與SQL非常長壽。雖然NoSQL的勢力抬頭,但RDB仍是許多系統的持久層的第一選擇,而且SQL不僅沒有勢微,反而因為更具直覺性操作優勢的介面,滲透專業程式設計師與工程師之外的終端使用者層。雖然如此,SQL在這十年內也隨著流行而有不少的改變,例如,必須能處理過去難以想像的大量資料,分析業務不再只由少部分的專家負責,導致SQL也應時代需求新增了許多功能。本書為了反映這些改變,也將SQL 程式設計的部分改寫成更符合現代化的內容,尤其是在撰寫初版之際,因DBMS的支援尚不完全,而未能大幅介紹的視窗函數,在這次的修訂裡,更是全面採用。

本書的概念是「中級SQL 程式設計入門」,預設的讀者群是於實務撰寫SQL 程式達半年至一年左右的讀者。書中會介紹許多SQL 的工具,例如CASE 陳述式、視窗函數、外部連結、關聯子查詢、HAVING子句、EXISTS語句,如果您已經了解使用這些工具的基本語法,應該就能順利閱讀本書。本書的第一部會於一章介紹一個這類SQL 工具,希望大家透過範例學會這些工具的使用方法。請大家務必動手撰寫這些程式碼。基本上,會希望各位讀者從頭開始閱讀本書,但如果有些內容已經很熟悉,不妨直接跳至有興趣的章節閱讀。

此外,本書也另有一個預設的讀者群,那就是想了解「何為SQL」的各級讀者。或許大家會覺得這麼說很神奇,但其實SQL 就是如此神奇的程式語言。有些初學者會遇到一些很神奇的事,例如一開始覺得SQL是能輕易實現簡單目的的語言,但隨著想要深入了解,就遇到無法合理解釋的語言規格,或是想要寫稍微複雜一點的程式,就被語法絆住腳步的情況。為什麼與NULL 有關的SQL 動作會如此混亂?為什麼用於資料列比對的關聯子查詢語法如此困難,有必要存在嗎?為什麼SQL沒有程序語言的迴圈或變數這類工具?為什麼SQL如此難以呈現「全部的」?

若只以「就是這樣」回答這些疑問,或許可繞過這些問題,但大部分的工程師或程式設計師都是以「太深入了解反而會變得太麻煩,所以跟這些工具保持適當距離就好」的想法,但其實也有人想了解這些工具的來龍去脈,所以本書將為了具有這類好奇心的讀者,從背景知識開始解說SQL 的原理與開發這個語言的人們究竟在想什麼,才把SQL打造成這副模樣。本書也將解答SQL這類疑問。當然,筆者沒有信心徹底解答所有問題,但應該能提供各位讀者一個理解語言本質的提示。

本書除了希望在增進讀者SQL 程式語言功力這點做出貢獻,也希望能讓各位讀者一窺程式語言這種文化產物的趣味性。

歡迎來到不可思議卻很有趣的SQL 世界。

Brand Slider