您好,很高興為您解答。
襄城網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站等網(wǎng)站項目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)于2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運(yùn)維經(jīng)驗,來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
1、下載安裝軟件:請認(rèn)準(zhǔn)百正規(guī)軟件下載
2、安裝navicat for mysql(注意一下插件的自定義選擇)
3、連接數(shù)據(jù)庫:
打開navicat for mysql之后找到,文件----新建連接
4、連接參數(shù)填寫
在出現(xiàn)的連接設(shè)置里面,有很多選項都是針對需要連接的數(shù)據(jù)庫的賬號信息
連接名:可以任意填寫,方便以后識別區(qū)分即可
主機(jī)名或IP: 填寫服務(wù)器的主機(jī)名(必須要能解析的)或者服務(wù)器IP地址,如果是本機(jī)可 以填寫localhost 或 127.0.0.1
端口:默認(rèn)是3306 如果修改了其他端口,需要對應(yīng)
密碼:就是用戶名root密碼或者其他mysql用戶的密碼
5、設(shè)置好連接數(shù)據(jù)庫的參數(shù)之后,點擊下方的“連接”出現(xiàn)“連接成功”即設(shè)置成功
6、數(shù)據(jù)庫管理:連接上數(shù)據(jù)庫之后,在左側(cè)會顯示當(dāng)前mysql所有的數(shù)據(jù)庫。點擊對應(yīng)的數(shù)據(jù)庫,能查看當(dāng)前數(shù)據(jù)庫下面的表
7、添加刪除數(shù)據(jù)庫:如果需要添加刪除數(shù)據(jù)庫的話,很簡單選擇需要操作的數(shù)據(jù)庫,鼠標(biāo)右鍵選擇操作即可
8、添加刪除表:同樣對于數(shù)據(jù)庫下方的表,如果要新建的話點擊選擇 表---新建
對于新建的表,名和類型都可以手動輸入指定選擇。設(shè)置好之后,點擊保存輸入表名即可完成操作
9、點擊添加好的表,或數(shù)據(jù)庫的表。雙擊之后右側(cè)會列出當(dāng)前表的詳細(xì)列項目和屬性
如何使用命令行
雖然是圖形化管理工具,但是對于很多操作其實還是需要SQL命令會更加方便。進(jìn)入sql命令行界面,點擊“工具”--“命令列界面”
隨后在右下方空白區(qū)域進(jìn)入了SQL命令行界面,操作方法和普通進(jìn)入mysql命令行界面一樣使用命令。如果需要清除當(dāng)前屏幕內(nèi)容,可以點擊“清除”即可
其他功能
對于之前數(shù)據(jù)庫已經(jīng)導(dǎo)出的sql文件,或者寫好的sql命令語句??梢酝ㄟ^選擇需要導(dǎo)入的數(shù)據(jù)庫,或表 右鍵選項“運(yùn)行sql文件”
本文主要介紹 SQL 標(biāo)準(zhǔn)中定義的各種連接的意義和區(qū)別,例如,交叉連接( CROSS JOIN )、內(nèi)連接( INNER JOIN )、外連接( OUTER JOIN )、自然連接( NATURAL JOIN )等,并結(jié)合例子講解這些連接在 MySQL 中的語法和表現(xiàn)。
從網(wǎng)上的資料看, JOIN 更多翻譯為連接,本文中凡是出現(xiàn)中文“連接”的地方都是指 JOIN 。
本文中用到的所有例子涉及兩張表—— customers 用戶表和 orders 訂單表,其中訂單表中的 cust_id 字段表示用戶的唯一 ID,也就是用戶表的主鍵 cust_id 。兩張表的數(shù)據(jù)如下:
注:兩張表都經(jīng)過了簡化,實際業(yè)務(wù)中這兩張表肯定還包括其他字段。
英文維基百科 JOIN 詞條 對連接的定義如下:
翻譯過來就是,“連接可以根據(jù)一張(自連接)或多張表中的共同值將這些表的列數(shù)據(jù)合并為一個新的結(jié)果集,標(biāo)準(zhǔn) SQL 定義了五種連接:內(nèi)連接、左外連接、右外連接、全外連接和交叉連接?!?/p>
也就是說,連接是 SQL 標(biāo)準(zhǔn)中定義的一種組合多張表的方式,當(dāng)然一張表自身也可以和自身組合,稱為自連接。連接后得到的結(jié)果集的每一列其實都來自用于連接的多張表,不同的連接類型只是區(qū)分了這些列具體從哪張表里來,列里填充的是什么數(shù)據(jù)。
其實英文維基百科的 JOIN 詞條已經(jīng)把各種連接的類型解釋地非常清楚了,非常值得去看一下。
我們來看一下 SQL 標(biāo)準(zhǔn)中定義的各種連接類型,理解各種連接最好的方法就是把需要連接的表想象成集合,并畫出可以反映集合的交與并的情況的圖——韋恩圖,例如下圖就畫出了 SQL 中定義的幾種主要連接。
請先仔細(xì)查看一下圖中的內(nèi)容,你可以從中歸納出幾種連接類型呢?
雖然圖中畫了 7 種集合的交并情況,但是總結(jié)起來,主要是兩種連接類型在起作用——內(nèi)連接( INNER JOIN )和外連接( OUTER JOIN ),其中外連接又分為了左外連接( LEFT OUTER JOIN )、右外連接( RIGHT OUTER JOIN )和全外連接( FULL OUTER JOIN )。
下面先簡單介紹一下 SQL 標(biāo)準(zhǔn)中各種連接的定義,然后在「MySQL 中的連接」一節(jié)再用例子來演示 MySQL 中支持的各種連接。
連接既然是用來合并多張表的,那么要定義一個連接就必須指定需要連接的表,并指定可選的連接條件。例如,一個典型的 SQL 連接語句如下:
我們用表 A 和表 B 指代需要連接的兩張表,經(jīng)過 內(nèi)連接 后得到的結(jié)果集 僅 包含所有滿足 連接條件 的數(shù)據(jù);而經(jīng)過 外連接 后得到的數(shù)據(jù)集 不僅 包含滿足 連接條件 的數(shù)據(jù),還包含其他數(shù)據(jù),具體的差別是:
在上面「SQL 標(biāo)準(zhǔn)定義的主要連接」一圖中并沒有列出交叉連接,交叉連接會對連接的兩張表做笛卡爾積,也就是連接后的數(shù)據(jù)集中的行是由第一張表中的每一行與第二張表中的每一行配對而成的,而不管它們 邏輯上 是否可以搭配在一起。假設(shè)交叉連接的兩張表分別有 m 和 n 行數(shù)據(jù),那么交叉連接后的數(shù)據(jù)集就包含 m 乘以 n 行數(shù)據(jù)。
連接根據(jù)連接的條件不同,又可以區(qū)分為等值連接和非等值連接,「SQL 標(biāo)準(zhǔn)定義的主要連接」圖中畫出的連接的連接條件都是比較兩個字段是否相等,它們都是等值連接。
自然連接是等值連接的一種特殊形式,自然連接會自動選取需要連接的兩張表中字段名相同的 所有 列做相等比較,而不需要再指定連接條件了。
注:以下內(nèi)容全部基于 MySQL 5.7 版本,所有例子只保證在 MySQL 5.7 上是可以正確執(zhí)行的。
MySQL 中支持的連接類型和關(guān)鍵字如下:
上面的表示方法摘自 MySQL 5.7 版本 官方文檔 ,其中 | 表示兩者皆可出現(xiàn), [] 表示的是可選的, {} 表示的是必選的,例如 NATURAL LEFT JOIN 和 NATURAL JOIN 都是合法的。
可以看到,除了全外連接( FULL OUTER JOIN )以外, MySQL 基本支持了 SQL 標(biāo)準(zhǔn)中定義的各種連接。在 MySQL 中全外連接可以通過 UNION 合并的方式做到,當(dāng)然前提是你知道自己為什么需要這么做,具體參見: Full Out Join in MySQL 。
MySQL 語法中還支持一個并不在 SQL 標(biāo)準(zhǔn)中的 STRAIGHT_JOIN ,它在 表現(xiàn)上 和內(nèi)連接或者交叉連接并無區(qū)別,只是一種給 MySQL 優(yōu)化器的一個提示, STRAIGHT_JOIN 提示 MySQL 按照語句中表的順序加載表,只有在你明確清楚 MySQL 服務(wù)器對你的 JOIN 語句做了負(fù)優(yōu)化的時候才可能用到它。
還有一點需要說明的是,根據(jù) 官方文檔 ,在 MySQL 中, JOIN 、 CROSS JOIN 和 INNER JOIN 實現(xiàn)的功能是一致的,它們在語法上是等價的。從語義上來說, CROSS JOIN 特指無條件的連接(沒有指定 ON 條件的 JOIN 或者沒有指定 WHERE 連接條件的多表 SELECT ), INNER JOIN 特指有條件的連接(指定了 ON 條件的 JOIN 或者指定了 WHERE 連接條件的多表 SELECT )。當(dāng)然,如果你非要寫 ... CROSS JOIN ... ON ... 這樣的語法,也是可以執(zhí)行的,雖然寫著交叉連接,實際上執(zhí)行的是內(nèi)連接。
下面我們就用例子來看一看 MySQL 中支持的幾種連接的例子。
注:下面的例子都沒有指定 ORDER BY 子句,返回結(jié)果的順序可能會因為數(shù)據(jù)插入順序的不同而略有不同。
MySQL 的交叉連接或內(nèi)連接有兩種寫法,一種是使用 JOIN 并用 ON 或者 USING 子句指定連接條件的寫法,一種是普通的 SELECT 多表,并且用 WHERE 子句指定連接的鍵的寫法。
下面的例子是一個交叉連接:
上面的寫法等價于:
當(dāng)然,第二種寫法中如果將 CROSS JOIN 替換成 JOIN 或者 INNER JOIN 也是可以正確執(zhí)行的。上面兩條語句的執(zhí)行結(jié)果如下:
可以看到共返回了 30 行結(jié)果,是兩張表的笛卡爾積。
一個內(nèi)連接的例子如下:
上面的寫法等價于:
在連接條件比較的字段相同的情況下,還可以改用 USING 關(guān)鍵字,上面的寫法等價于:
上面三條語句的返回結(jié)果如下:
可以看到只返回了符合連接條件 customers.cust_id = orders.cust_id 的 6 行結(jié)果,結(jié)果的含義是所有有訂單的用戶和他們的訂單。
左外連接和右外連接的例子如下,其中的 OUTER 關(guān)鍵字可以省略:
其中右外連接的返回與內(nèi)連接的返回是一致的(思考一下為什么),左外連接的返回結(jié)果如下:
可以看到一共返回了 8 行數(shù)據(jù),其中最后兩行數(shù)據(jù)對應(yīng)的 order_id 的值為 NULL ,結(jié)果的含義是所有用戶的訂單,不管這些用戶是否已經(jīng)有訂單存在了。
根據(jù)前面介紹的自然連接的定義,自然連接會自動用參與連接的兩張表中 字段名相同 的列做等值比較,由于例子中的 customers 和 orders 表只有一列名稱相同,我們可以用自然連接的語法寫一個與上面的內(nèi)連接的例子表現(xiàn)行為一樣的語句如下:
可以看到,使用自然連接就不能再用 ON 子句指定連接條件了,因為這完全是多余的。
當(dāng)然,自然連接同樣支持左外連接和右外連接。
下面用一個 customers 表自連接的例子再來說明一下自然連接,語句如下:
因為是自連接,因此必須使用 AS 指定別名,否則 MySQL 無法區(qū)分“兩個” customers 表,運(yùn)行的結(jié)果如下:
可以看到結(jié)果集和 customers 表完全一致,大家可以思考一下為什么結(jié)果是這樣的。
文章之前也提到了,MySQL 還支持一種 SQL 標(biāo)準(zhǔn)中沒有定義的“方言”, STRAIGHT_JOIN , STRAIGHT_JOIN 支持帶 ON 子句的內(nèi)連接和不帶 ON 子句的交叉連接,我們來看一個 STRAIGHT_JOIN 版本的內(nèi)連接的例子:
返回結(jié)果與前面內(nèi)連接的例子是一致的,如下:
STRAIGHT_JOIN 的表現(xiàn)和 JOIN 是完全一致的,它只是一種給 MySQL 優(yōu)化器的提示,使得 MySQL 始終按照語句中表的順序讀取表(上面的例子中,MySQL 在執(zhí)行時一定會先讀取 customers 表,再讀取 orders 表),而不會做改變讀取表的順序的優(yōu)化。關(guān)于 MySQL 優(yōu)化器的話題這里不做展開,需要說明的是除非你非常清楚你在做什么,否則不推薦直接使用 STRAIGHT_JOIN 。
你能理解上面的語句是在檢索什么數(shù)據(jù)嗎?
本文主要介紹了 SQL 標(biāo)準(zhǔn)里定義的各種連接的概念,以及 MySQL 中的實現(xiàn),并通過各種例子來介紹了這些連接的區(qū)別。這些連接不一定都能在實際開發(fā)中用到,但是做到心中有知識也還是很有必要的。
那么,現(xiàn)在再回憶一下,什么是內(nèi)連接、外連接、自連接、等值連接和自然連接?他們的區(qū)別是什么?
最后,給大家留一個思考題,為什么 MySQL 中沒有左外連接或者右外連接版本的 STRAIGHT_JOIN ?
1、首先進(jìn)入的是安裝引導(dǎo)界面
2、然后進(jìn)入的是類型選擇界面,這里有3個類型:Typical(典型)、Complete(完全)、Custom(自定義)。這里建議 選擇“自定義”(Custom)安裝,這樣可以自定義選擇MySQL的安裝目錄,然后點“Next”下一步,出現(xiàn)自定義安裝界面,為了數(shù)據(jù)安全起見,不建議將MySQL安裝系統(tǒng)盤C目錄。
3、準(zhǔn)備安裝
4、安裝完成之后會出現(xiàn)MySQL配置的引導(dǎo)界面
5、這里有個引導(dǎo)配置MySQL的選項(Luanch the MySQL Instance Configuration Wizard),建議勾選立即配置你的MySQL6、這里是配置MySQL的 MySQL配置的類型,可以選擇兩種配置類型:Detailed Configuration(詳細(xì)配置)和Standard Configuration(標(biāo)準(zhǔn)配置)。
Standard Configuration(標(biāo)準(zhǔn)配置)選項適合想要快速啟動MySQL而不必考慮服務(wù)器配置的新用戶。詳細(xì)配置選項適合想要更加細(xì)粒度控制服務(wù)器配置的高級用戶。
如果你是MySQL的新手,需要配置為單用戶開發(fā)機(jī)的服務(wù)器,Standard Configuration(標(biāo)準(zhǔn)配置)應(yīng)當(dāng)適合你的需求。選擇Standard Configuration(標(biāo)準(zhǔn)配置)選項,則 MySQL Configuration Wizard(配置向?qū)В┳詣釉O(shè)置所有配置選項,但不包括服務(wù)選項和安全選項。
Standard Configuration(標(biāo)準(zhǔn)配置)設(shè)置選項可能與安裝MySQL的系統(tǒng)不兼容。如果系統(tǒng)上已經(jīng)安裝了MySQL和你想要配置的安裝,建議選擇詳細(xì)配置。
這里本人選擇的是Detailed Configuration ,想更好的完成個性化定制。
7、這里是配置MySQL的 MySQL服務(wù)器類型,可以選擇3種服務(wù)器類型,選擇哪種服務(wù)器將影響到MySQL Configuration Wizard(配置向?qū)В?nèi)存、硬盤和過程或使用的決策。
Developer Machine(開發(fā)機(jī)器):該選項代表典型個人用桌面工作站。假定機(jī)器上運(yùn)行著多個桌面應(yīng)用程序。將MySQL服務(wù)器配置成使用最少的系統(tǒng)資源。
Server Machine(服務(wù)器):該選項代表服務(wù)器,MySQL服務(wù)器可以同其它應(yīng)用程序一起運(yùn)行,例如FTP、email和web服務(wù)器。MySQL服務(wù)器配置成使用適當(dāng)比例的系統(tǒng)資源。
Dedicated MySQL Server Machine(專用MySQL服務(wù)器):該選項代表只運(yùn)行MySQL服務(wù)的服務(wù)器。假定運(yùn)行沒有運(yùn)行其它應(yīng)用程序。MySQL服務(wù)器配置成使用所有可用系統(tǒng)資源。
這里本人選擇的是Developer Machine ,主要是為了平時開發(fā)所需。
8、這里是配置MySQL的 數(shù)據(jù)庫使用情況,你可以指出創(chuàng)建MySQL表時使用的表處理器。通過該選項,你可以選擇是否使用InnoDB儲存引擎,以及InnoDB占用多大比例的服務(wù)器資源。
Multifunctional Database(多功能數(shù)據(jù)庫):選擇該選項,則同時使用InnoDB和MyISAM儲存引擎,并在兩個引擎之間平均分配資源。建議經(jīng)常使用兩個儲存引擎的用戶選擇該選項。
Transactional Database Only(只是事務(wù)處理數(shù)據(jù)庫):該選項同時使用InnoDB和MyISAM 儲存引擎,但是將大多數(shù)服務(wù)器資源指派給InnoDB儲存引擎。建議主要使用InnoDB只偶爾使用MyISAM的用戶選擇該選項。
Non-Transactional Database Only(只是非事務(wù)處理數(shù)據(jù)庫):該選項完全禁用InnoDB儲存引擎,將所有服務(wù)器資源指派給MyISAM儲存引擎。建議不使用InnoDB的用戶選擇該選項。
本人選擇的是Multifunctional Database .
9、這里是配置MySQL的 InnoDB表空間,有些用戶可能想要將InnoDB表空間文件放到不同的位置,而不放到MySQL服務(wù)器數(shù)據(jù)目錄。如果你的系統(tǒng)有較大的空間或較高性能的儲存設(shè)備(例如RAID儲存系統(tǒng)),則最好將表空間文件單獨(dú)放到一個位置。要想更改InnoDB表空間文件的默認(rèn)位置,從驅(qū)動器下拉列表選擇一個新的驅(qū)動器,并從路徑下拉列表選擇新的路徑。要想創(chuàng)建路徑,點擊 ...按鈕。如果你要更改已有服務(wù)器的配置,更改路徑前你必須點擊Modify按鈕。此時啟動服務(wù)器之前,你必須將已有表空間文件移到新位置。本人選擇的默認(rèn)配置。
10、這里是配置MySQL的并發(fā)連接,限制所創(chuàng)建的與MySQL服務(wù)器之間的并行連接數(shù)量很重要,以便防止服務(wù)器耗盡資源??梢赃x擇服務(wù)器的使用方法,并根據(jù)情況限制并行連接的數(shù)量。還可以手動設(shè)置并行連接的限制。
Decision Support(決策支持)(DSS)/OLAP:如果服務(wù)器不需要大量的并行連接可以選擇該選項。假定最大連接數(shù)目設(shè)置為100,平均并行連接數(shù)為20。
Online Transaction Processing(聯(lián)機(jī)事務(wù)處理)(OLTP):如果你的服務(wù)器需要大量的并行連接則選擇該選項。最大連接數(shù)設(shè)置為500。
Manual Setting(人工設(shè)置):選擇該選項可以手動設(shè)置服務(wù)器并行連接的最大數(shù)目。從前面的下拉框中選擇并行連接的數(shù)目,如果你期望的數(shù)目不在列表中,則在下拉框中輸入最大連接數(shù)。
這里根據(jù)個人所需,本人選擇的是Manual Setting.
11、這里是配置MySQL的網(wǎng)絡(luò)選項,可以啟用或禁用TCP/IP網(wǎng)絡(luò),并配置用來連接MySQL服務(wù)器的端口號。默認(rèn)情況啟用TCP/IP網(wǎng)絡(luò)。要想禁用TCP/IP網(wǎng)絡(luò),取消選擇Enable TCP/IP Networking選項旁邊的檢查框。默認(rèn)使用3306端口。要想更訪問MySQL使用的端口,從下拉框選擇一個新端口號或直接向下拉框輸入新的端口號。如果你選擇的端口號已經(jīng)被占用,將提示確認(rèn)選擇的端口號,如果其他機(jī)器需要訪問該數(shù)據(jù)庫,建議勾選 Add firewall exception for this port(添加到防火墻例外)。
12、這里是配置MySQL的字符集,MySQL服務(wù)器支持多種字符集,可以設(shè)置適用于所有表、列和數(shù)據(jù)庫的默認(rèn)服務(wù)器字符集。可以通過Character Set(字符集對話框)來更改 MySQL服務(wù)器的默認(rèn)字符集。
Standard Character Set(標(biāo)準(zhǔn)字符集):如果想要使用Latin1做為默認(rèn)服務(wù)器字符集,則選擇該選項。Latin1用于英語和許多西歐語言。
Best Support For Multilingualism(支持多種語言):如果想要使用UTF8做為默認(rèn)服務(wù)器字符集,則選擇該選項。UTF8可以 將不同語言的字符儲存為單一的字符集。
Manual Selected Default Character Set/Collation(人工選擇的默認(rèn)字符集/校對規(guī)則):如果想要手動選擇服務(wù)器的默認(rèn)字符集,請選擇該項。從下拉列表中選擇期望的字符集。
13、這里是配置MySQL的服務(wù)選項,可以將MySQL服務(wù)器安裝成服務(wù)。安裝成服務(wù),系統(tǒng)啟動時可以自動啟動MySQL服務(wù)器,甚至出現(xiàn)服務(wù)故障時可以隨Windows自動啟動。
默認(rèn)情況,MySQL Configuration Wizard(配置向?qū)ВySQL服務(wù)器安裝為服務(wù),服務(wù)名為MySQL。如果你不想安裝服務(wù),取消Install As Windows Service選項旁邊的選擇框??梢詮南吕蜻x擇新的服務(wù)名或在下拉框輸入新的服務(wù)名來更改服務(wù)名。要想將MySQL服務(wù)器安裝為服務(wù),但是不自動啟動,不選中Launch the MySQL Server Automatically選項旁邊的檢查框。
14、這里是配置MySQL的安全選項,強(qiáng)烈建議為你的MySQL服務(wù)器設(shè)置一個root密碼,默認(rèn)情況MySQL Configuration Wizard(配置向?qū)В┮竽阍O(shè)置一個root密碼。如果你不想設(shè)置root密碼,不選中Modify Security Settings(修改安全設(shè)定值)選項旁邊的選擇框。要想設(shè)置root密碼,在New root password(輸入新密碼)和Confirm(確認(rèn))兩個框內(nèi)輸入期望的密碼。如果重新配置已有的服務(wù)器,你還需要Current root password(當(dāng)前root密碼)框內(nèi)輸入已有的root密碼。要想防止通過網(wǎng)絡(luò)以root登錄,選中Root may only connect from localhost(只允許從本機(jī)登陸連接root)選項旁邊的框。這樣可以提高root賬戶的安全。要想創(chuàng)建一個匿名用戶賬戶,選中Create An Anonymous Account(創(chuàng)建匿名賬戶)選項旁邊的框。創(chuàng)建匿名賬戶會降低服務(wù)器的安全,并造成登錄和許可困難。因此不建議。
15、確認(rèn),點擊Excute完成安裝
一、 簡單查詢
簡單的Transact-SQL查詢只包括選擇列表、FROM子句和WHERE子句。它們分別說明所查詢列、查詢的表或視圖、以及搜索條件等。
例如,下面的語句查詢testtable表中姓名為"張三"的nickname字段和email字段。
SELECT nickname,email
FROM testtable
WHERE name='張三'
(一) 選擇列表
選擇列表(select_list)指出所查詢列,它可以是一組列名列表、星號、表達(dá)式、變量(包括局部變量和全局變量)等構(gòu)成。
1、選擇所有列
例如,下面語句顯示testtable表中所有列的數(shù)據(jù):
SELECT *
FROM testtable
2、選擇部分列并指定它們的顯示次序
查詢結(jié)果集合中數(shù)據(jù)的排列順序與選擇列表中所指定的列名排列順序相同。
例如:
SELECT nickname,email
FROM testtable
3、更改列標(biāo)題
在選擇列表中,可重新指定列標(biāo)題。定義格式為:
列標(biāo)題=列名
列名 列標(biāo)題
如果指定的列標(biāo)題不是標(biāo)準(zhǔn)的標(biāo)識符格式時,應(yīng)使用引號定界符,例如,下列語句使用漢字顯示列標(biāo)題:
SELECT 昵稱=nickname,電子郵件=email
FROM testtable
4、刪除重復(fù)行
SELECT語句中使用ALL或DISTINCT選項來顯示表中符合條件的所有行或刪除其中重復(fù)的數(shù)據(jù)行,默認(rèn)為ALL。使用DISTINCT選項時,對于所有重復(fù)的數(shù)據(jù)行在SELECT返回的結(jié)果集合中只保留一行。
5、限制返回的行數(shù)
使用TOP n [PERCENT]選項限制返回的數(shù)據(jù)行數(shù),TOP n說明返回n行,而TOP n PERCENT時,說明n是表示一百分?jǐn)?shù),指定返回的行數(shù)等于總行數(shù)的百分之幾。
例如:
SELECT TOP 2 *
FROM testtable
SELECT TOP 20 PERCENT *
FROM testtable
(二)FROM子句
FROM子句指定SELECT語句查詢及與查詢相關(guān)的表或視圖。在FROM子句中最多可指定256個表或視圖,它們之間用逗號分隔。
在FROM子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應(yīng)使用對象名限定這些列所屬的表或視圖。例如在usertable和citytable表中同時存在cityid列,在查詢兩個表中的cityid時應(yīng)使用下面語句格式加以限定:
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在FROM子句中可用以下兩種格式為表或視圖指定別名:
表名 as 別名
表名 別名
(二) FROM子句
FROM子句指定SELECT語句查詢及與查詢相關(guān)的表或視圖。在FROM子句中最多可指定256個表或視圖,它們之間用逗號分隔。
在FROM子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應(yīng)使用對象名限定這些列所屬的表或視圖。例如在usertable和citytable表中同時存在cityid列,在查詢兩個表中的cityid時應(yīng)使用下面語句格式加以限定:
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不僅能從表或視圖中檢索數(shù)據(jù),它還能夠從其它查詢語句所返回的結(jié)果集合中查詢數(shù)據(jù)。
例如:
SELECT a.au_fname+a.au_lname
FROM authors a,titleauthor ta
(SELECT title_id,title
FROM titles
WHERE ytd_sales10000
) AS t
WHERE a.au_id=ta.au_id
AND ta.title_id=t.title_id
此例中,將SELECT返回的結(jié)果集合給予一別名t,然后再從中檢索數(shù)據(jù)。
(三) 使用WHERE子句設(shè)置查詢條件
WHERE子句設(shè)置查詢條件,過濾掉不需要的數(shù)據(jù)行。例如下面語句查詢年齡大于20的數(shù)據(jù):
SELECT *
FROM usertable
WHERE age20
WHERE子句可包括各種條件運(yùn)算符:
比較運(yùn)算符(大小比較):、=、=、、=、、!、!
范圍運(yùn)算符(表達(dá)式值是否在指定的范圍):BETWEEN...AND...
NOT BETWEEN...AND...
列表運(yùn)算符(判斷表達(dá)式是否為列表中的指定項):IN (項1,項2......)
NOT IN (項1,項2......)
模式匹配符(判斷值是否與指定的字符通配格式相符):LIKE、NOT LIKE
空值判斷符(判斷表達(dá)式是否為空):IS NULL、NOT IS NULL
邏輯運(yùn)算符(用于多條件的邏輯連接):NOT、AND、OR
1、范圍運(yùn)算符例:age BETWEEN 10 AND 30相當(dāng)于age=10 AND age=30
2、列表運(yùn)算符例:country IN ('Germany','China')
3、模式匹配符例:常用于模糊查找,它判斷列值是否與指定的字符串格式相匹配??捎糜赾har、varchar、text、ntext、datetime和smalldatetime等類型查詢。
可使用以下通配字符:
百分號%:可匹配任意類型和長度的字符,如果是中文,請使用兩個百分號即%%。
下劃線_:匹配單個任意字符,它常用來限制表達(dá)式的字符長度。
方括號[]:指定一個字符、字符串或范圍,要求所匹配對象為它們中的任一個。[^]:其取值也[] 相同,但它要求所匹配對象為指定字符以外的任一個字符。
例如:
限制以Publishing結(jié)尾,使用LIKE '%Publishing'
限制以A開頭:LIKE '[A]%'
限制以A開頭外:LIKE '[^A]%'
4、空值判斷符例WHERE age IS NULL
5、邏輯運(yùn)算符:優(yōu)先級為NOT、AND、OR
(四)查詢結(jié)果排序
使用ORDER BY子句對查詢返回的結(jié)果按一列或多列排序。ORDER BY子句的語法格式為:
ORDER BY {column_name [ASC|DESC]} [,...n]
其中ASC表示升序,為默認(rèn)值,DESC為降序。ORDER BY不能按ntext、text和image數(shù)據(jù)類型進(jìn)行排
序。
例如:
SELECT *
FROM usertable
ORDER BY age desc,userid ASC
另外,可以根據(jù)表達(dá)式進(jìn)行排序。
二、 聯(lián)合查詢
UNION運(yùn)算符可以將兩個或兩個以上上SELECT語句的查詢結(jié)果集合合并成一個結(jié)果集合顯示,即執(zhí)行聯(lián)合查詢。UNION的語法格式為:
select_statement
UNION [ALL] selectstatement
[UNION [ALL] selectstatement][...n]
其中selectstatement為待聯(lián)合的SELECT查詢語句。
ALL選項表示將所有行合并到結(jié)果集合中。不指定該項時,被聯(lián)合查詢結(jié)果集合中的重復(fù)行將只保留一行。
聯(lián)合查詢時,查詢結(jié)果的列標(biāo)題為第一個查詢語句的列標(biāo)題。因此,要定義列標(biāo)題必須在第一個查詢語句中定義。要對聯(lián)合查詢結(jié)果排序時,也必須使用第一查詢語句中的列名、列標(biāo)題或者列序號。
在使用UNION 運(yùn)算符時,應(yīng)保證每個聯(lián)合查詢語句的選擇列表中有相同數(shù)量的表達(dá)式,并且每個查詢選擇表達(dá)式應(yīng)具有相同的數(shù)據(jù)類型,或是可以自動將它們轉(zhuǎn)換為相同的數(shù)據(jù)類型。在自動轉(zhuǎn)換時,對于數(shù)值類型,系統(tǒng)將低精度的數(shù)據(jù)類型轉(zhuǎn)換為高精度的數(shù)據(jù)類型。
在包括多個查詢的UNION語句中,其執(zhí)行順序是自左至右,使用括號可以改變這一執(zhí)行順序。例如:
查詢1 UNION (查詢2 UNION 查詢3)
三、連接查詢
通過連接運(yùn)算符可以實現(xiàn)多個表查詢。連接是關(guān)系數(shù)據(jù)庫模型的主要特點,也是它區(qū)別于其它類型數(shù)據(jù)庫管理系統(tǒng)的一個標(biāo)志。
在關(guān)系數(shù)據(jù)庫管理系統(tǒng)中,表建立時各數(shù)據(jù)之間的關(guān)系不必確定,常把一個實體的所有信息存放在一個表中。當(dāng)檢索數(shù)據(jù)時,通過連接操作查詢出存放在多個表中的不同實體的信息。連接操作給用戶帶來很大的靈活性,他們可以在任何時候增加新的數(shù)據(jù)類型。為不同實體創(chuàng)建新的表,爾后通過連接進(jìn)行查詢。
連接可以在SELECT 語句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出連接時有助于將連接操作與WHERE子句中的搜索條件區(qū)分開來。所以,在Transact-SQL中推薦使用這種方法。
SQL-92標(biāo)準(zhǔn)所定義的FROM子句的連接語法格式為:
FROM join_table join_type join_table
[ON (join_condition)]
其中join_table指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一個表操作的連接又稱做自連接。
join_type 指出連接類型,可分為三種:內(nèi)連接、外連接和交叉連接。內(nèi)連接(INNER JOIN)使用比較運(yùn)算符進(jìn)行表間某(些)列數(shù)據(jù)的比較操作,并列出這些表中與連接條件相匹配的數(shù)據(jù)行。根據(jù)所使用的比較方式不同,內(nèi)連接又分為等值連接、自然連接和不等連接三種。外連接分為左外連接(LEFT OUTER JOIN或LEFT JOIN)、右外連接(RIGHT OUTER JOIN或RIGHT JOIN)和全外連接(FULL OUTER JOIN或FULL JOIN)三種。與內(nèi)連接不同的是,外連接不只列出與連接條件相匹配的行,而是列出左表(左外連接時)、右表(右外連接時)或兩個表(全外連接時)中所有符合搜索條件的數(shù)據(jù)行。
交叉連接(CROSS JOIN)沒有WHERE 子句,它返回連接表中所有數(shù)據(jù)行的笛卡爾積,其結(jié)果集合中的數(shù)據(jù)行數(shù)等于第一個表中符合查詢條件的數(shù)據(jù)行數(shù)乘以第二個表中符合查詢條件的數(shù)據(jù)行數(shù)。
連接操作中的ON (join_condition) 子句指出連接條件,它由被連接表中的列和比較運(yùn)算符、邏輯運(yùn)算符等構(gòu)成。
無論哪種連接都不能對text、ntext和image數(shù)據(jù)類型列進(jìn)行直接連接,但可以對這三種列進(jìn)行間接連接。例如:
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)
(一)內(nèi)連接
內(nèi)連接查詢操作列出與連接條件匹配的數(shù)據(jù)行,它使用比較運(yùn)算符比較被連接列的列值。內(nèi)連接分三種:
1、等值連接:在連接條件中使用等于號(=)運(yùn)算符比較被連接列的列值,其查詢結(jié)果中列出被連接表中的所有列,包括其中的重復(fù)列。
2、不等連接: 在連接條件使用除等于運(yùn)算符以外的其它比較運(yùn)算符比較被連接的列的列值。這些運(yùn)算符包括、=、=、、!、!和。
3、自然連接:在連接條件中使用等于(=)運(yùn)算符比較被連接列的列值,但它使用選擇列表指出查詢結(jié)果集合中所包括的列,并刪除連接表中的重復(fù)列。
例,下面使用等值連接列出authors和publishers表中位于同一城市的作者和出版社:
SELECT *
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
又如使用自然連接,在選擇列表中刪除authors 和publishers 表中重復(fù)列(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
(二)外連接
內(nèi)連接時,返回查詢結(jié)果集合中的僅是符合查詢條件( WHERE 搜索條件或 HAVING 條件)和連接條件的行。而采用外連接時,它返回到查詢結(jié)果集合中的不僅包含符合連接條件的行,而且還包括左表(左外連接時)、右表(右外連接時)或兩個邊接表(全外連接)中的所有數(shù)據(jù)行。如下面使用左外連接將論壇內(nèi)容和作者信息連接起來:
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 子句,它返回被連接的兩個表所有數(shù)據(jù)行的笛卡爾積,返回到結(jié)果集合中的數(shù)據(jù)行數(shù)等于第一個表中符合查詢條件的數(shù)據(jù)行數(shù)乘以第二個表中符合查詢條件的數(shù)據(jù)行數(shù)。例,titles表中有6類圖書,而publishers表中有8家出版社,則下列交叉連接檢索到的記錄數(shù)將等于6*8=48行。
SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY type
看看進(jìn)程里有沒有mysqld.exe,如果有那說明是在運(yùn)行的。如果沒有的話,在命令行下,用mysqld命令可以啟動mysql。如果要連接mysql,使用mysql 命令就可以。前提是沒有設(shè)置密碼,這會以本地管理員身份登錄。如果指定用戶密碼登錄用mysql -u[username] -p[password],中括號中的為用戶和密碼。這個只有你自己知道。
我修改了一下,你可以試試看,我估計差不多就是這樣了,我這里沒有mysql環(huán)境,沒法測試
select b.product,count(distinct b.user_id) 購買人數(shù) /*一個人可能購買多次,這里只算一次*/
from orders a,orders b
where a.pay_method="free trial" and a.date_format(o1.end_date,"%Y%m%d") between 20080825 and 20080831 and a.user_id=b.user_id and a.product_id=b.product_id and b.pay_status="paid"
and b.date_format(o1.end_date,"%Y%m%d")a.date_format(o1.end_date,"%Y%m%d") /*b表表示購買,a表表示測試,這里的判斷是b的購買時間大于測試時間*/
group by b.product