嵌套的意思
if語句的嵌套當if語句中的執行語句又是if語句時,則構成了if 語句嵌套的情形.其一般形式可表示如下:if(表達式) if語句; 或者為if(表達式) if語句; else if語句; 在嵌套內的if語句可能又是if-else型的,這將會出現多個if和多個else重疊的情況,這時要特別注意if和else的配對問題.例如:if(表達式1)if(表達式2)語句1;else語句2;其中的else究竟是與哪一個if配對呢?應該理解為:還是應理解為:if(表達式1) if(表達式1)if(表達式2) if(表達式2)語句1; 語句1;else else語句2; 語句2; 為了避免這種二義性,C語言規定,else 總是與它前面最近的if配對,因此對上述例子應按前一種情況理解.比較兩個數的大小關系.void main(){int a,b;printf("please input A,B:");scanf("%d%d",&a,&b);if(a!=b)if(a>b) printf("A>B\n");else printf("AB\n");else printf("A。
如何嵌套SELECT語句
嵌套SELECT語句也叫子查詢,形如: SELECT name FROM bbc WHERE region = (SELECT region FROM bbc WHERE name = 'Brazil') 一個 SELECT 語句的查詢結果可以作為另一個語句的輸入值。
上面的SQL語句作用為獲得和'Brazil'(巴西)同屬一個地區的所有國家。 子查詢不但可以出現在Where子句中,也可以出現在from子句中,作為一個臨時表使用,也可以出現在select list中,作為一個字段值來返回。
本節我們僅介紹的Where子句中的子查詢。 在Where子句中使用子查詢,有一個在實際使用中容易犯的錯在這里說明一下。
通常,就像上面的例子一樣,嵌套的語句總是和一個值進行比較。語句 (SELECT region FROM bbc WHERE name = 'Brazil') 應該僅返回一個地區,即 'Americas'。
但如果我們在表中再插入一條地區為歐洲,國家名稱為Brazil的記錄,那會發生什么情況? 這將會導致語句的運行時錯誤.因為這個SQL語句的語法是正確的,所以數據庫引擎就開始執行,但當執行到外部的語句時就出錯了。因為這時的外部語句就像好像是 SELECT name FROM bbc WHERE region = ('Americas', 'Europe'),這個語句當然報錯了。
那么有沒有辦法解決這個問題呢,當然有。有一些SQL查詢條件允許對列表值(即多個值)進行操作。
例如"IN" 操作符,可以測試某個值是否在一個列表中。 下面的語句就可以安全的執行而不出錯,不管表中有多少條包含Brazils的記錄 SELECT name FROM bbc WHERE region IN (SELECT region FROM bbc WHERE name = 'Brazil') OK, 讓我們再看看一些具體的實例, 一、給出人口多于Russia(俄國)的國家名稱 SELECT name FROM bbc WHERE population> (SELECT population FROM bbc WHERE name='Russia') 二、給出'India'(印度), 'Iran'(伊朗)所在地區的所有國家的所有信息 SELECT * FROM bbc WHERE region IN (SELECT region FROM bbc WHERE name IN ('India','Iran')) 三、給出人均GDP超過'United Kingdom'(英國)的歐洲國家. SELECT name FROM bbc WHERE region='Europe' AND gdp/population > (SELECT gdp/population FROM bbc WHERE name='United Kingdom')。