一、SQL速成
我們提供的服務(wù)有:成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、大廠ssl等。為數(shù)千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的大廠網(wǎng)站制作公司
以下是一些重要的SQL快速參考,有關(guān)SQL的語法和在標準SQL上增加的特性,請查詢MySQL手冊。
1.創(chuàng)建表
表是數(shù)據(jù)庫的最基本元素之一,表與表之間可以相互獨立,也可以相互關(guān)聯(lián)。創(chuàng)建表的基本語法如下:
create table table_name
(column_name datatype {identity |null|not null},
…)
其中參數(shù)table_name和column_name必須滿足用戶數(shù)據(jù)庫中的識別器(identifier)的要求,參數(shù)datatype是一個標準的SQL類型或由用戶數(shù)據(jù)庫提供的類型。用戶要使用non-null從句為各字段輸入數(shù)據(jù)。
create table還有一些其他選項,如創(chuàng)建臨時表和使用select子句從其他的表中讀取某些字段組成新表等。還有,在創(chuàng)建表是可用PRIMARY KEY、KEY、INDEX等標識符設(shè)定某些字段為主鍵或索引等。
書寫上要注意:
在一對圓括號里的列出完整的字段清單。
字段名間用逗號隔開。
字段名間的逗號后要加一個空格。
最后一個字段名后不用逗號。
所有的SQL陳述都以分號";"結(jié)束。
例:
mysql CREATE TABLE test (blob_col BLOB, index(blob_col(10)));
2.創(chuàng)建索引
索引用于對數(shù)據(jù)庫的查詢。一般數(shù)據(jù)庫建有多種索引方案,每種方案都精于某一特定的查詢類。索引可以加速對數(shù)據(jù)庫的查詢過程。創(chuàng)建索引的基本語法如下:
create index index_name
on table_name (col_name[(length)],... )
例:
mysql CREATE INDEX part_of_name ON customer (name(10));
3.改變表結(jié)構(gòu)
在數(shù)據(jù)庫的使用過程中,有時需要改變它的表結(jié)構(gòu),包括改變字段名,甚至改變不同數(shù)據(jù)庫字段間的關(guān)系??梢詫崿F(xiàn)上述改變的命令是alter,其基本語法如下:
alter table table_name alter_spec [, alter_spec ...]
例:
mysql ALTER TABLE t1 CHANGE a b INTEGER;
4.刪除數(shù)據(jù)對象
很多數(shù)據(jù)庫是動態(tài)使用的,有時可能需要刪除某個表或索引。大多數(shù)數(shù)據(jù)庫對象可以下面的命令刪除:
drop object_name
mysql DROP TABLE tb1;
5.執(zhí)行查詢
查詢是使用最多的SQL命令。查詢數(shù)據(jù)庫需要憑借結(jié)構(gòu)、索引和字段類型等因素。大多數(shù)數(shù)據(jù)庫含有一個優(yōu)化器(optimizer),把用戶的查詢語句轉(zhuǎn)換成可選的形式,以提高查詢效率。
值得注意的是MySQL不支持SQL92標準的嵌套的where子句,即它只支持一個where子句。其基本語法如下:
SELECT [STRAIGHT_JOIN] [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [HIGH_PRIORITY] [DISTINCT | DISTINCTROW | ALL]
select_expression,... [INTO {OUTFILE | DUMPFILE} 'file_name' export_options] [FROM table_references [WHERE where_definition] [GROUP BY col_name,...] [HAVING where_definition] [ORDER BY {unsigned_integer | col_name | formula} [ASC | DESC] ,...] [LIMIT [offset,] rows] [PROCEDURE procedure_name] ]
其中where從句是定義選擇標準的地方,where_definition可以有不同的格式,但都遵循下面的形式:
字段名操作表達式
字段名操作字段名
在第一種形式下,標準把字段的值與表達式進行比較;在第二種形式下,把兩個字段的值進行比較。根據(jù)所比較的數(shù)據(jù)類型,search_condition中的操作可能選以下幾種:
= 檢查是否相等
!= 檢查是否不等
(或=) 檢查左邊值是否大于(或大于等于)右邊值
(或=) 檢查左邊值是否小于(或小于等于)右邊值 [not] between 檢查左邊值是否在某個范圍內(nèi) [not] in 檢查左邊是否某個特定集的成員 [not] like 檢查左邊是否為右邊的子串
is [not] null 檢查左邊是否為空值
在這里,可以用通配符_代表任何一個字符,%代表任何字符串。使用關(guān)鍵字、和可以生成復(fù)雜的詞,它們運行檢查時使用布爾表達式的多重標準集。
例:
mysql select t1.name, t2.salary from employee AS t1, info AS t2 where t1.name = t2.name;
mysql select college, region, seed from tournament
ORDER BY region, seed;
mysql select col_name from tbl_name WHERE col_name 0;
先給出我的核心觀點:
學(xué)習(xí),無論你是學(xué)什么,也無論你有沒有基礎(chǔ)。思考永遠是第一位的,有些知識你沒接觸過不要緊,用不著害怕,也沒必要害怕。重要的是一秒鐘也不要停止思考,問題要想透徹,正所謂磨刀不誤砍柴工。尤其是作為工程師,要有打破砂鍋問到底的精神,否則你怎么學(xué)都沒用。
首先,學(xué)習(xí)基本的SQL語法。完成這個后,你就可以編寫SQL語句了。這一步推薦:W3Schools的 SQL 教程。
其次,學(xué)習(xí)數(shù)據(jù)庫的主要功能和使用方法,比如用戶相關(guān)或者權(quán)限相關(guān)等等。
我推薦兩本書:
一、《MySQL必知必會》 這本書講的非常全,從基本概念,到查詢到插入新建表,用戶的管理,都有具體的例子,非常適合沒有任何基礎(chǔ)的同學(xué)來學(xué)習(xí)Mysql,總之這本書學(xué)習(xí)的方法就是:1、十分鐘了解下數(shù)據(jù)庫的基本概念 2、找到練手的數(shù)據(jù)庫 3、對照著上面的內(nèi)容去敲。本書里也有大量的內(nèi)容是講sql的,可以結(jié)合w3c的sql教程一起,有取舍地看。
二、《數(shù)據(jù)庫系統(tǒng)概念》這本書是dba必看的。看完這些并且實踐+思考之后,可以算入門了。接下來對于希望深入學(xué)習(xí)的童鞋我推薦幾本書(很多大神都這么推薦),《高性能MySQL(第3版)》、 《MySQL技術(shù)內(nèi)幕(第4版)》,《MySQL技術(shù)內(nèi)幕 InnoDB存儲引擎》,《深入理解MySQL》還有Mysql的官網(wǎng)。讀完這些東西,再加些豐富的經(jīng)驗,理論上來講就具備DBA的水平了。十分推薦閱讀Planet MySQL上匯總的博客,特別是Percona's MySQL InnoDB performance and scalability blog但是,正如我開頭所言的。
面對問題的時候一定要積極思考!比如:我問你,面對一個并發(fā)量比較高的場景,如何配置mysql的連接數(shù)?你可能會回答:“哦,就是調(diào)高max_connection的數(shù)值吧。”那,你有沒有思考過調(diào)到多少是最合適的呢?為什么這樣設(shè)置就最合適呢?也許你會回答:“恩我知道,可以看系統(tǒng)之前的max_used_connection的數(shù)值,然后來設(shè)置。也可以調(diào)高back_log的值?!蹦悄阌袥]有思考過,max_connection連接數(shù)太高會有什么不好的影響呢?back_log設(shè)置的太高有什么不好的地方呢?max_connect的上限其實是取決于mysql能獲得的文件描述符的數(shù)量,也就是說你就算設(shè)置成10000,最后也是沒用的,系統(tǒng)會根據(jù)機器的情況自動調(diào)低。也許你會回答:“恩我知道,設(shè)置太高,會有系統(tǒng)開銷...”那你有沒有思考過,這些開銷具體是什么呢?是什么工作導(dǎo)致了需要這些內(nèi)存開銷?也許你還會回答,在連接創(chuàng)建的時候,會立刻為它分配連接緩沖區(qū)以及查詢緩沖區(qū),這些都會吃內(nèi)存。那你有沒有思考過,占據(jù)的資源具體是多少呢?取決于哪些因素呢?好了,我們先結(jié)束這個問題?;氐街醯膯栴}上來,其實我說了這么多,就是表達要如何自學(xué)mysql。所以的所以,你必須不斷思考,才能在工作中面對具體場景的時候,非常淡定地推斷:“哦,一定是這里出了問題。應(yīng)該怎么怎么做?!泵鎸栴},拿出打破砂鍋問到底的精神,先思考一番,給出自己的假設(shè),不要著急地去找度娘,谷歌。思考過后,帶著你的推斷或者答案,大膽地去搜索吧!去看看別人的見解,去看看官方的描述!這才是一個工程師應(yīng)有的態(tài)度。最后我想給出一些有價值的學(xué)習(xí)資料。可以省去一些時間。-電子書:我認為多看書還是有好處的。有些書值得反復(fù)看許多遍,有時候只看一遍無法深刻理解吸收,思考也不夠充分
如果你沒有 MySQL 的基礎(chǔ),建議可以看看以下書籍:
《MySQL 必知必會》:主要講 SQL 的寫法
《深入淺出 MySQL》:比較全面的講解了 MySQL 的基礎(chǔ)知識,也涉及了一些優(yōu)化。
如果已經(jīng)對 MySQL 比較熟悉了,可以看下面的書籍:
《高性能 MySQL》:里面講了很多 MySQL 優(yōu)化技巧。
《MySQL 技術(shù)內(nèi)幕》:講解了很多 MySQL 原理,強力推薦給想深入學(xué)習(xí) MySQL 的同學(xué)。
《MySQL 內(nèi)核:InnoDB 存儲引擎》:想深入研究 MySQL 內(nèi)核及原理的可以看看。
《MySQL 運維內(nèi)參》:對 MySQL 源碼感興趣,可以入手。
《MySQL Internals Manual》
《MySQL 5.7 Reference Manual》
這要看你對數(shù)據(jù)庫原理的掌握程度。如果一點知識都沒有,你可以從關(guān)系數(shù)據(jù)庫原理學(xué)起,無論什么關(guān)系數(shù)據(jù)庫,其原理都是相通的。你可以到這個教程網(wǎng)站上看數(shù)據(jù)庫的教程,用這個網(wǎng)站帶你入門的話很適合,他簡單明了的講了一些最常見的數(shù)據(jù)庫的增刪改查的方法。等你掌握了最常見的數(shù)據(jù)庫操作后,建議你把關(guān)系數(shù)據(jù)庫原理與設(shè)計這類的書認真的學(xué)習(xí)一下。你會得到很大程度的進步。希望我的回答對你有用!祝你成功!