自學SQL數據庫,說難也不難,主要做好以下幾點:
首先,您要選擇合適的數據庫環境目前流行的數據庫環境,主要包括MySQL、Oracle、SQLServer、PostgreSQL、SQLite等。這幾個都屬于經典的傳統關系型數據庫,對ANSI-SQL的支持都不錯。個人建議最好選擇開源數據庫系統。
Oracle、SQLServer都屬于商業數據庫,死貴死貴的,MySQL自從被Oracle收購后,其前景堪憂,很可能跟Java的下場一樣,SQLite太小型,對上SQL的支持很有限。本人建議最好選擇PostgreSQL。
我不是亂說的,PostgreSQL號稱“全世界最強大的開源數據庫”,這名號絕對不是蓋的,真材實料。雖然國內MySQL的流行程序要高于PostgreSQL,但要看未來。美國的尿性我們都知道,連Android都要搞事情,MySQL以后我們能不能用都是問題。
最重要的,PostgreSQL不但功能強大不弱于大型商業數據庫、而且完全開源不需要任何商業授權,她屬于全世界,而不是美帝,大膽的學、大膽的用,沒有任何后顧之憂。要學就學最有前途的。
其次,您要擁有或構建一個完整的應用場景俗話說,學以致用,如果您的學習沒有任何場景,那就是無的放矢,學起來不但累而且沒有成就感。干巴巴的語法雖然看上去很簡單,但您不清楚學來干什么,還會有深入學習的興趣么?就算您硬著頭皮死啃,沒有成就感您能堅持多久?
所以,您必須有一個完整的應用場景,您學習的目的,就是圍繞這個應用場景展開。當然,應用場景不是天生就有的,如果您為了工作,可能場景已經被事先設置好了;如果您只是為了學習,就需要創建一個應用場景。當然不能隨便創建場景,您要以自己很熟悉的領域作為應用場景。比如學校的學籍管理、公司的人事管理等等。
有了應用場景,您就可以圍繞應用場景展開數據庫設計、表結構設計、關聯設計、存儲過程設計等等。各種應用能夠實現可以衡量的結果,您學起來就來了興趣。完成應用場景需求的過程中,各種SQL語法您很自然就用到和掌握了。
如果您是程序開發人員,最好與您的開發環境融合起來,通過編程實現程序前端、數據庫作為后臺,各種應用效果就更直觀,學起來興趣就越來越濃。說不準學習的過程還能做出來一個不錯的系統,何嘗不是意外的收獲啊。
最后,您要有長久學習提升的思想準備并持續展開SQL和數據庫有很多實用技巧,您學的越多、學的越久,就會有越多的問題和困惑。有些問題解決起來得心應手、而有些問題卻總讓您頭疼。頭疼不是您水平低,很可能是因為您平時沒有話費足夠的時間研究SQL和數據庫。
自學往往沒有足夠的時間系統學習,這沒辦法,但您可以做好筆記,把各種處理的經典方案SQL腳本留存起來,以后使用的時候,可以隨時查閱。但如果您任何處理都要不停的查找解決方案,那您的學習就太失敗了。
我們總會碰到各種奇葩需求,之所以奇葩,主要是我們沒處理該類需求的經驗、或者我們的知識存在各種斷層,要讓自己有足夠的底氣,您只有考多積累,日積月累多思考多試驗,崩總想著自己是高手能搞定一切,該查資料就查,查了之后做好筆記記錄,爭取下次就會處理了,時間長了,無形中您就成了高手了。