1. sql怎麼輸入單引號和頓號。我想要的是紅色的
我估計鍵盤上單引號、反單引號這些常用的符號你應該沒問題
注意要使用半形,不能用全形
另外你說的顏色,是SQL編輯器自動著色的,你無法輸入想要的顏色,除非你自己開發一個
不知道你用的什麼資料庫,什麼編輯工具,只能提供這些了
祝好運,望採納
2. 關於導出excel的,為什麼SQL語句不能換行
一、如果原來分行的文字行數很少,可以直接在原來文件中用Backspace或Del鍵消除分行,再復制、粘貼到excel中。
二、如果原來分行的文字行數很多,可以直接在原來文件中用「查找、替換」命令消除分行控制符「^p」,再把復制、粘貼內容。具體做法:
1.打開「查找並替換…」命令。
2.在「查找」項內輸入「^p」(注意要半形字元!),在「替換為」項中輸入希望分隔文字的字元(如頓號、逗號)或不填(如果希望合並原來分行的文字,且不需要分隔),點擊「全部替換」。原來分行的文字將消除分行。
3. 再把內容復制、粘貼到excel中。
3. 更新SQL語句 把某一列內容中的頓號替換成逗號
updateexamsetstudent_name=REPLACE(student_name,';',',')
需要注意;和,都有區分全形半形,注意輸入的時候切換全半形。另外,上面的SQL語句適用於MS SQL,其他資料庫系統,要找類似的函數替換。
4. 知道為什麼SQL查詢語句不能使用*嗎 考驗你們的小細節
作為運行效率來說的話, 有2種情況。
第一種情況, 是返回了太多沒有用處的列,導致網路傳輸的數據過多。
* 要返回所有的列的信息。
如果你表的列很多, 又存在很多 二進制的數據類型的話。
例如有某個 安保系統, 有個 進出門的日誌表。 這個門需要 2個人, 各刷一次卡,才能進入。
這個表包含下面的列:
自增流水、門口代碼、日期時間、第一次刷卡的卡片代碼,第二次刷卡的卡片代碼,第一次刷卡的照片,第二次刷卡的照片,......其他列
現在發現可能有安全問題, 說昨天有東西丟了。
那麼首先就是先
SELECT
日期時間、門口代碼,第一次刷卡的卡片代碼,第二次刷卡的卡片代碼
FROM
表
WHERE
門口代碼 = '那個丟東西房間的門'
AND 日期時間 > 昨天0點
先看看都哪些人刷卡了, 然後再去有重點地去查看那些 可能有問題的 刷卡記錄的 照片信息。
否則你直接
SELECT
*
FROM
表
WHERE
門口代碼 = '那個丟東西房間的門'
AND 日期時間 > 昨天0點
一次就會有太多的數據, 從伺服器 傳遞到你的客戶端。 而這些數據, 又可能是你用不上的。
第二種情況, 是如果檢索的列都包含在索引裡面了, 那麼查詢效率要快很多。
還是上面那個例子。
假如存在有這樣的索引 (門口代碼, 日期時間)
SELECT
日期時間、門口代碼
FROM
表
WHERE
門口代碼 = '那個丟東西房間的門'
AND 日期時間 > 昨天0點
這個查詢, 連表都不需要查詢了, 直接查詢完索引, 就能返回了。
在 SQL Server 中, 可以通過 Include 來包含一個額外的數據到索引上面。
例如:
CREATE NONCLUSTERED INDEX idx_TestDoc
ON 表 (門口代碼, 日期時間)
Include(第一次刷卡的卡片代碼,第二次刷卡的卡片代碼) ;
上面的索引創建完畢的話
SELECT
日期時間、門口代碼,第一次刷卡的卡片代碼,第二次刷卡的卡片代碼
FROM
表
WHERE
門口代碼 = '那個丟東西房間的門'
AND 日期時間 > 昨天0點
也不需要訪問表了, 直接查詢索引, 就能返回了。
這個情況,用 select * 嘛, 是不行的。就要先去訪問好索引, 然後通過索引裡面的 信息, 去表裡面定位到具體的行數據, 最後再檢索出來。
5. 為sql一欄位值中每個特定字元前的最後一個數字加1怎麼處理
這個需要用到plsql(過程、語句塊)編程:
1.
按照頓號拆分
2.
取倒數第一個字元+1,如果>10則賦值為0
3.
循環完成後使用頓號連接起來,更新到該行,ok。
6. sql語句後面是否有標點符號
oracle資料庫語法
切換用戶命令conn什麼的不需要符號
普通sql命令(比如select update delete insert)末尾都需要加分號;
sql server資料庫
普通sql命令(比如select update delete insert)末尾不需要添加符號
7. sql語句查詢什麼時候用逗號什麼時候用句號
as用法:
是給現有的欄位名另指定一個別名的意思,比如:
select username as 用戶名,password as 密碼 from users
補充:比如其中的一個好處是:當欄位名是英文或拼音縮寫時,採用漢字替代之後可以給閱讀帶來方便
sql中as的用法和一些經典的sql語句
1、delete table1 from (select * from table2) as t2 where table1.id=t2.id
2、truncate table table1 (不在事務日誌中做記錄,比delete table快,但不能激活觸發器)
3、update table1 set column=column+1 where id=(select id from table2)
4、update table1 set column=column+1 from table1,table2 where table1.id=table2.id
5、select top n [Percent] * from table1 '輸出百分比記錄
6、select id,column1 * column2 as column from table1 '可算明白as的用法了
7、select * from table1 where column1 like 'SQL#_G_O' escape '#' '單匹配
8、select table1.id from table1 where not exists (select table2.id from table2 where table1.id=table2.id) '這個應該比not in快一些
9、select table1.id from table1,table2 where table1.id<>table2.id '看復合查詢機制
10、select table1.id from table1,table2,(select id from table3) as t3 where table1.id=table2.id and table2.id=t3.id '有些類似[1]了......
11、select * from table1 where column1 like '[A]%' or like '[^B]%'
12、select @column1=column1 from table1;select @column1 as column1 '存儲到自定義變數
8. SQL語言的問題
SQL語言快速入門之一
SQL是英文Structured Query Language的縮寫,意思為結構化查詢語言。SQL語言的主要功能就是同各種資料庫建立聯系,進行溝通。按照ANSI(美國國家標准協會)的規定,SQL被作為關系型資料庫管理系統的標准語言。SQL語句可以用來執行各種各樣的操作,例如更新資料庫中的數據,從資料庫中提取數據等。目前,絕大多數流行的關系型資料庫管理系統,如Oracle, Sybase, Microsoft SQL Server, ACCESS等都採用了SQL語言標准。雖然很多資料庫都對SQL語句進行了再開發和擴展,但是包括Select, Insert, Update, Delete, Create, 以及Drop在內的標準的SQL命令仍然可以被用來完成幾乎所有的資料庫操作。下面,我們就來詳細介紹一下SQL語言的基本知識。
資料庫表格
一個典型的關系型資料庫通常由一個或多個被稱作表格的對象組成。資料庫中的所有數據或信息都被保存在這些資料庫表格中。資料庫中的每一個表格都具有自己唯一的表格名稱,都是由行和列組成,其中每一列包括了該列名稱,數據類型,以及列的其它屬性等信息,而行則具體包含某一列的記錄或數據。以下,是一個名為天氣的資料庫表格的實例。
城市 最高氣溫 最低氣溫
北京 10 5
上海 15 8
天津 8 2
重慶 20 13
該表格中「城市」, 「最高氣溫」和「最低氣溫」就是三個不同的列,而表格中的每一行則包含了具體的表格數據。
數據查詢
在眾多的SQL命令中,select語句應該算是使用最頻繁的。Select語句主要被用來對資料庫進行查詢並返回符合用戶查詢標準的結果數據。Select語句的語法格式如下:
select column1 [, column2,etc] from tablename
[where condition];
([] 表示可選項)
select語句中位於select關鍵詞之後的列名用來決定那些列將作為查詢結果返回。用戶可以按照自己的需要選擇任意列,還可以使用通配符「*」來設定返回表格中的所有列。
select語句中位於from關鍵詞之後的表格名稱用來決定將要進行查詢操作的目標表格。
Select語句中的where可選從句用來規定哪些數據值或哪些行將被作為查詢結果返回或顯示。
在where條件從句中可以使用以下一些運算符來設定查詢標准:
= 等於
> 大於
< 小於
>= 大於等於
<= 小於等於
<> 不等於
除了上面所提到的運算符外,LIKE運算符在where條件從句中也非常重要。LIKE運算符的功能非常強大,通過使用LIKE運算符可以設定只選擇與用戶規定格式相同的記錄。此外,我們還可以使用通配符「%」用來代替任何字元串。舉例如下:
select firstname, lastname, city
from employee
where firstname LIKE 『E%』;
(注意,字元串必須被包含在單括弧內)
上述SQL語句將會查詢所有名稱以E開頭的姓名。或者,通過如下語句:
select * from employee
where firstname = 『May』;
查詢所有名稱為May的行。
SQL語言快速入門之二
創建表格
SQL語言中的create table語句被用來建立新的資料庫表格。Create table語句的使用格式如下:
create table tablename
(column1 data type,
column2 data type,
column3 data type);
如果用戶希望在建立新表格時規定列的限制條件,可以使用可選的條件選項:
create table tablename
(column1 data type [constraint],
column2 data type [constraint],
column3 data type [constraint]);
舉例如下:
create table employee
(firstname varchar(15),
lastname varchar(20),
age number(3),
address varchar(30),
city varchar(20));
簡單來說,創建新表格時,在關鍵詞create table後面加入所要建立的表格的名稱,然後在括弧內順次設定各列的名稱,數據類型,以及可選的限制條件等。注意,所有的SQL語句在結尾處都要使用「;」符號。
使用SQL語句創建的資料庫表格和表格中列的名稱必須以字母開頭,後面可以使用字母,數字或下劃線,名稱的長度不能超過30個字元。注意,用戶在選擇表格名稱時不要使用SQL語言中的保留關鍵詞,如select, create, insert等,作為表格或列的名稱。
數據類型用來設定某一個具體列中數據的類型。例如,在姓名列中只能採用varchar或char的數據類型,而不能使用number的數據類型。
SQL語言中較為常用的數據類型為:
char(size):固定長度字元串,其中括弧中的size用來設定字元串的最大長度。Char類型的最大長度為255位元組。
varchar(size):可變長度字元串,最大長度由size設定。
number(size):數字類型,其中數字的最大位數由size設定。
Date:日期類型。
number(size,d):數字類型,size決定該數字總的最大位數,而d則用於設定該數字在小數點後的位數。
最後,在創建新表格時需要注意的一點就是表格中列的限制條件。所謂限制條件就是當向特定列輸入數據時所必須遵守的規則。例如,unique這一限制條件要求某一列中不能存在兩個值相同的記錄,所有記錄的值都必須是唯一的。除unique之外,較為常用的列的限制條件還包括not null和primary key等。Not null用來規定表格中某一列的值不能為空。Primary key則為表格中的所有記錄規定了唯一的標識符。
向表格中插入數據SQL語言使用insert語句向資料庫表格中插入或添加新的數據行。Insert語句的使用格式如下:
insert into tablename
(first_column,...last_column)
values (first_value,...last_value);
例如:
insert into employee
(firstname, lastname, age, address, city)
values (『Li』, 『Ming』, 45, 『No.77 Changan Road』, 『Beijing」);
簡單來說,當向資料庫表格中添加新記錄時,在關鍵詞insert into後面輸入所要添加的表格名稱,然後在括弧中列出將要添加新值的列的名稱。最後,在關鍵詞values的後面按照前面輸入的列的順序對應的輸入所有要添加的記錄值。
更新記錄
SQL語言使用update語句更新或修改滿足規定條件的現有記錄。Update語句的格式為:
update tablename
set columnname = newvalue [, nextcolumn = newvalue2...]
where columnname OPERATOR value [and|or column OPERATOR value];
例如:
update employee
set age = age+1
where first_name= 『Mary』and last_name= 『Williams』;
使用update語句時,關鍵一點就是要設定好用於進行判斷的where條件從句。
刪除記錄
SQL語言使用delete語句刪除資料庫表格中的行或記錄。Delete語句的格式為:
delete from tablename
where columnname OPERATOR value [and|or column OPERATOR value];
例如:
delete from employee
where lastname = May;
簡單來說,當需要刪除某一行或某個記錄時,在delete from關鍵詞之後輸入表格名稱,然後在where從句中設定刪除記錄的判斷條件。注意,如果用戶在使用delete語句時不設定where從句,則表格中的所有記錄將全部被刪除。
刪除資料庫表格
在SQL語言中使用drop table命令刪除某個表格以及該表格中的所有記錄。Drop table命令的使用格式為:
drop table tablename;
例如:
drop table employee;
如果用戶希望將某個資料庫表格完全刪除,只需要在drop table命令後輸入希望刪除的表格名稱即可。Drop table命令的作用與刪除表格中的所有記錄不同。刪除表格中的全部記錄之後,該表格仍然存在,而且表格中列的信息不會改變。而使用drop table命令則會將整個資料庫表格的所有信息全部刪除。
以上,我們對SQL語言主要的命令和語句進行了較為詳細的介紹。應該說SQL語句的語法結構和風格還是相當簡單和直觀的,只要用戶結合實踐多加練習,一定會在短期內迅速掌握。
SQL語言快速入門之三
我們日常使用SQL語言的工作過程中,使用最多的還是從已經建立好的資料庫中查詢信息。下面,我們就來詳細介紹一下如何使用SQL語言實現各種資料庫查詢操作。
SELECT…FROM
為方便講解,我們在資料庫中創建名為Store_Information的如下數據表。
Store_Information
Store_Name
Sales
Date
Los Angeles
$1500
Jan-10-2000
San Diego
$250
Jan-11-2000
Los Angeles
$300
Jan-12-2000
Boston
$700
Jan-12-2000
SQL語言中用於資料庫查詢的最簡單的命令就是SELECT…FROM,語法格式為:
SELECT "column_name" FROM "table_name"
例如,如果我們希望查詢Store_Information數據表中所有的商店名稱時,可以使用如下命令:
SELECT store_name FROM Store_Information
查詢結果顯示為:
Store_Name
Los Angeles
San Diego
Los Angeles
Boston
如果用戶希望一次查詢多個欄位,可以將所要查詢的欄位名稱依次加入SELECT關鍵字之後,中間用「,」隔開即可。
DISTINCT
SELECT關鍵字支持用戶查詢數據表中指定欄位的所有數據,但是這樣有時就會不可避免的出現重復信息。如果用戶希望只查詢那些具有不同記錄值的信息的話,可以使用SQL語言的DISTINCT關鍵字。語法格式如下:
SELECT DISTINCT "column_name"
FROM "table_name"
例如,我們可以使用以下命令查詢Store_Information數據表具有不同記錄值的所有記錄。
SELECT DISTINCT Store_Name FROM Store_Information
查詢結果如下:
Store_Name
Los Angeles
San Diego
Boston
WHERE
除了選擇具有不同記錄值的記錄之外,有時我們可能還會需要根據某些條件對資料庫中的數據進行查詢。例如,我們可能需要查詢Store_Information數據表中銷售額超過1000美圓的商店。為此,我們可以使用SQL語言的WHERE關鍵字設定查詢條件。語法格式如下:
SELECT "column_name"
FROM "table_name"
WHERE "condition"
由此,我們可以使用如下命令查詢銷售額超過1000美圓的商店信息:
SELECT store_name FROM Store_Information WHERE Sales > 1000
查詢結果顯示為:
store_name
Los Angeles
運算函數
現在,我們已經了解到在使用SQL語言進行資料庫查詢操作時可以通過對數值的判斷設定靈活的查詢條件。為了增強對運算的支持能力,SQL提供了眾多實用的運算函數供廣大用戶使用。例如,我們可以直接在SQL命令中調用SUM或AVG這兩個分別用於計算總數和平均數的函數。語法格式如下:
SELECT "function type"("column_name")
FROM "table_name"
如果我們希望查詢Store_Information數據表中所有商店的總銷售額的話,可以使用如下命令:
SELECT SUM(Sales) FROM Store_Information
查詢結果顯示為:
SUM(Sales)
$2750
COUNT
除了SUM和AVG函數之外,COUNT函數是SQL語言中另一個較為常用的運算函數。COUNT函數可以用來計算數據表中指定欄位所包含的記錄數目。語法格式為:
SELECT COUNT("column_name")
FROM "table_name"
例如,如果我們希望查詢Store_Information數據表中的有關商店的記錄條數時,可以使用如下命令:
SELECT COUNT(store_name)
FROM Store_Information
查詢結果顯示為:
Count(store_name)
4
COUNT函數可以和DISTINCT關鍵字一起使用從而可以查詢數據表中指定欄位中所有具有不同記錄值的記錄數目。例如,如果我們希望查詢Store_Information數據表中不同商店的數目時,可以使用如下命令:
SELECT COUNT(DISTINCT store_name)
FROM Store_Information
查詢結果顯示為:
Count(DISTINCT store_name)
3
GROUP BY
下面我們來進一步看一下SQL語言中的集合函數。上文中,我們曾使用SUM函數計算所有商店的銷售總額,如果我們希望計算每一家商店各自的總銷售額時該怎麼辦呢?要實現這一目的我們需要做兩件事:首先,我們需要查詢商店名稱和銷售額兩個欄位;然後,我們使用SQL語言的GROUP BY命令將銷售額按照不同的商店進行分組,從而計算出不同商店的銷售總額。GROUP BY命令的語法格式為:
SELECT "column_name1", SUM("column_name2")
FROM "table_name"
GROUP BY "column_name1"
我們可以使用如下命令實現上述查詢目的:
SELECT store_name, SUM(Sales)
FROM Store_Information
GROUP BY store_name
查詢結果顯示為:
store_name SUM(Sales)
Los Angeles $1800
San Diego $250
Boston $700
小註:
GROUP BY關鍵字一般應用於同時查詢多個欄位並對欄位進行算術運算的SQL命令中。
HAVING
用戶在使用SQL語言的過程中可能希望解決的另一個問題就是對由sum或其它集合函數運算結果的輸出進行限制。例如,我們可能只希望看到Store_Information數據表中銷售總額超過1500美圓的商店的信息,這時我們就需要使用HAVING從句。語法格式為:
SELECT "column_name1", SUM("column_name2")
FROM "table_name"
GROUP BY "column_name1"
HAVING (arithematic function condition)
(GROUP BY從句可選)
由此,我們可以使用如下命令實現上述查詢目的:
SELECT store_name, SUM(sales)
FROM Store_Information
GROUP BY store_name
HAVING SUM(sales) > 1500
查詢結果顯示為:
store_name SUM(Sales)
Los Angeles $1800
小註:
SQL語言中設定集合函數的查詢條件時使用HAVING從句而不是WHERE從句。通常情況下,HAVING從句被放置在SQL命令的結尾處。下面,我們重點介紹一下如何在SQL命令中設定別名。SQL語言中一般使用兩種類型的別名,分別為欄位別名和數據表別名。
簡單的說,使用欄位別名可以幫助我們有效的組織查詢的輸出結果。例如,上文所列舉的多個實例中,當我們計算商店銷售總額時,顯示結果中就會出現SUM(sales)。雖然SUM(sales)並不會對我們理解查詢結果帶來不便,但是如果我們需要在查詢中使用多項復雜運算時,顯示結果就不會這么直觀了。如果這時我們使用欄位別名就會極大的提高查詢結果的可讀性。
對於數據表別名,我們可以通過將別名直接放置在FROM從句中數據表名稱的後面設定。數據表別名在我們下面將要講述的連接多個數據表進行查詢的操作中極為有用。
欄位和數據表別名的語法格式如下:
SELECT "table_alias"."column_name1" "column_alias"
FROM "table_name" "table_alias"
即別名都直接放置在各自對應名稱的後面,中間用空格分開。
以Store_Information數據表為例,我們可以在GROUP BY一節中所使用的SQL命令中設置如下欄位和數據表別名:
SELECT A1.store_name Store, SUM(Sales) "Total Sales"
FROM Store_Information A1
GROUP BY A1.store_name
查詢結果顯示為:
Store Total Sales
Los Angeles $1800
San Diego $250
Boston $700
連接多個數據表
最後,我們來看一下如果使用SQL語言連接多個數據表,實現對多個數據表的查詢。為方便講解,我們在資料庫中分別創建了兩個名為Store_Information和Region的數據表。
Store_Information
Store_Name
Sales
Date
Los Angeles
$1500
Jan-10-2000
San Diego
$250
Jan-11-2000
Los Angeles
$300
Jan-12-2000
Boston
$700
Jan-12-2000
Region
Region_Name
Store_Name
East
Boston
East
New York
West
Los Angeles
West
San Diego
下面,我們就來看一下通過數據表的連接實現按不同區域查詢銷售額。
我們注意到在名為Region的數據表中包含區域和商店兩個欄位信息,而在名為Store_Information的數據表中則包含每一家商店的銷售信息。因此,為了得到按區域劃分的銷售信息,我們需要將兩個不同數據表的信息結合在一起進行查詢。通過對上述兩個數據表的分析,我們發現每個數據表中都包含一個名為Store_Name的欄位,因此,我們可以使用如下命令實現查詢目的:
SELECT A1.region_name REGION, SUM(A2.Sales) SALES
FROM Geography A1, Store_Information A2
WHERE A1.store_name = A2.store_name
GROUP BY A1.region_name
查詢結果顯示為:
REGION SALES
East $700
West $2050
說明:
上述查詢命令的前兩行用於指定所要查詢的目標欄位,分別為Region數據表中的Region_Name欄位和Store_Information數據表中Sales欄位的記錄值總數。這里,我們設定兩個欄位的別名分別為REGION和SALES,兩個數據表的別名分別為A1和A2。如果我們只使用欄位別名而不設定數據表別名的話,上述SQL命令的第一行就變成 如下形式:
SELECT Region.Region_Name REGION, SUM(Store_Information.Sales) SALES
由此我們可以看出有效的使用數據表別名,可以極大的簡化對多個數據表進行操作的SQL命令。
上述查詢命令的第3行為WHERE從句,正是該從句設定了兩個數據表的連接條件。因為我們希望確保Region數據表中的Store_Name欄位能夠與Store_Information數據表中的同名欄位相對應,所以我們規定兩個欄位的記錄值應當相等。在連接多個數據表時,一定要准確設定數據表的連接條件,如果WHERE從句設定不正確,則可能導致查詢結果中出現眾多不相關的數據
9. 計算機二級VF里,SQL語言輸入的時候,什麼時候用逗號,什麼時候用句號怎麼區分as怎麼用啊
你好,剛翻了書,查下SQL語句除了有中文的句子,別的沒看到有用句號的。一般的都用的是逗號,而且要特別注意,這個逗號是在輸入法在英文狀態下輸入的,否則在開發工具中SQL語句你是無法調試成功的。
as用法:
是給現有的欄位名另指定一個別名的意思,比如:
select username as 用戶名,password as 密碼 from users
補充:比如其中的一個好處是:當欄位名是英文或拼音縮寫時,採用漢字替代之後可以給閱讀帶來方便
sql中as的用法和一些經典的sql語句
1、delete table1 from (select * from table2) as t2 where table1.id=t2.id
2、truncate table table1 (不在事務日誌中做記錄,比delete table快,但不能激活觸發器)
3、update table1 set column=column+1 where id=(select id from table2)
4、update table1 set column=column+1 from table1,table2 where table1.id=table2.id
5、select top n [Percent] * from table1 '輸出百分比記錄
6、select id,column1 * column2 as column from table1 '可算明白as的用法了
7、select * from table1 where column1 like 'SQL#_G_O' escape '#' '單匹配
8、select table1.id from table1 where not exists (select table2.id from table2 where table1.id=table2.id) '這個應該比not in快一些
9、select table1.id from table1,table2 where table1.id<>table2.id '看復合查詢機制
10、select table1.id from table1,table2,(select id from table3) as t3 where table1.id=table2.id and table2.id=t3.id '有些類似[1]了......
11、select * from table1 where column1 like '[A]%' or like '[^B]%'
12、select @column1=column1 from table1;select @column1 as column1 '存儲到自定義變數
13、select * from table1 where contains(column1,'char1 or char2*') '全文索引
14、select * from table1 where contains(column1,'前有 near 中有 near 後有')
15、select * from table1 where contains(column1,'formsof(inflectional,go)') '派生
16、select * from table1 where contains(description,'isabout(apple weight(.9),boy weight(.8),china weight(.7))') '權重
17、select * from table1 where freetext(column1,'char') '僅支持文字不支持表達式搜索
18、insert into table1 select column1,count(column1) from table2 group by column1 '統計
-----------------------------------------------------------------------------------------
1 說明:復製表(只復制結構,源表名:a 新表名:b)
SQL: select * into b from a where 1<>1
2 說明:拷貝表(拷貝數據,源表名:a 目標表名:b)
SQL: insert into b(a, b, c) select d,e,f from b;
3 說明:顯示文章、提交人和最後回復時間
SQL: select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b
4 說明:外連接查詢(表名1:a 表名2:b)
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
5 說明:日程安排提前五分鍾提醒
SQL: select * from 日程安排 where datediff('minute',f開始時間,getdate())>5
6 說明:兩張關聯表,刪除主表中已經在副表中沒有的信息
SQL:
delete from info where not exists ( select * from infobz where info.infid=infobz.infid )
7 說明:
從資料庫中去一年的各單位電話費統計(電話費定額和電話費清單兩個表來源)
SQL:
SELECT a.userper, a.tel, a.standfee, TO_CHAR(a.telfeedate, 'yyyy') AS telyear,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '01', a.factration)) AS JAN,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '02', a.factration)) AS FRI,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '03', a.factration)) AS MAR,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '04', a.factration)) AS APR,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '05', a.factration)) AS MAY,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '06', a.factration)) AS JUE,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '07', a.factration)) AS JUL,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '08', a.factration)) AS AGU,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '09', a.factration)) AS SEP,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '10', a.factration)) AS OCT,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '11', a.factration)) AS NOV,
SUM(decode(TO_CHAR(a.telfeedate, 'mm'), '12', a.factration)) AS DEC
FROM (SELECT a.userper, a.tel, a.standfee, b.telfeedate, b.factration
FROM TELFEESTAND a, TELFEE b
WHERE a.tel = b.telfax) a
GROUP BY a.userper, a.tel, a.standfee, TO_CHAR(a.telfeedate, 'yyyy')
8 說明:四表聯查問題:
SQL: select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where .....
9 說明:得到表中最小的未使用的ID號
SQL:
SELECT (CASE WHEN EXISTS(SELECT * FROM Handle b WHERE b.HandleID = 1) THEN MIN(HandleID) + 1 ELSE 1 END) as HandleID
FROM Handle
WHERE NOT HandleID IN (SELECT a.HandleID - 1 FROM Handle a)
10 說明:模糊查詢,單字匹配(短橫線代表待匹配內容)
select * from table where field1 like 'A_B_C'
11 說明:as的用法
select id,column1 * column2 as column from table1