ACCESS中使用SQL語句應注意的地方、與sql server的區別及幾點技巧(整理中)

來源:互聯網
上載者:User
以下SQL語句在ACCESS XP的查詢中測試通過
建表:
Create Table Tab1 (
ID Counter,
Name string,
Age integer,
[Date] DateTime);
技巧:
自增欄位用 Counter 聲明.
欄位名為關鍵字的欄位用方括弧[]括起來,數字作為欄位名也可行.

 

建立索引:
下面的語句在Tab1的Date列上建立可重複索引
Create Index iDate ON Tab1 ([Date]);
完成後ACCESS中欄位Date索引屬性顯示為 - 有(有重複).
下面的語句在Tab1的Name列上建立不可重複索引
Create Unique Index iName ON Tab1 (Name);
完成後ACCESS中欄位Name索引屬性顯示為 - 有(無重複).
下面的語句刪除剛才建立的兩個索引
Drop Index iDate ON Tab1;
Drop Index iName ON Tab1;

ACCESS與SQLSERVER中的UPDATE語句對比:
SQLSERVER中更新多表的UPDATE語句:
UPDATE Tab1
SET a.Name = b.Name
FROM Tab1 a,Tab2 b
WHERE a.ID = b.ID;
同樣功能的SQL語句在ACCESS中應該是
UPDATE Tab1 a,Tab2 b
SET a.Name = b.Name
WHERE a.ID = b.ID;
即:ACCESS中的UPDATE語句沒有FROM子句,所有引用的表都列在UPDATE關鍵字後.
上例中如果Tab2可以不是一個表,而是一個查詢,例:
UPDATE Tab1 a,(Select ID,Name From Tab2) b
SET a.Name = b.Name
WHERE a.ID = b.ID;

訪問多個不同的ACCESS資料庫-在SQL中使用In子句:
Select a.*,b.* From Tab1 a,Tab2 b In 'db2.mdb' Where a.ID=b.ID;
上面的SQL語句查詢出當前資料庫中Tab1和db2.mdb(當前檔案夾中)中Tab2以ID為關聯的所有記錄.
缺點-外部資料庫不能帶密碼.

在ACCESS中訪問其它ODBC資料來源
下例在ACCESS中查詢SQLSERVER中的資料
SELECT * FROM Tab1 IN [ODBC]
[ODBC;Driver=SQL Server;UID=sa;PWD=;Server=127.0.0.1;DataBase=Demo;]
外部資料源串連屬性的完整參數是:
[ODBC;DRIVER=driver;SERVER=server;DATABASE=database;UID=user;PWD=password;]
其中的DRIVER=driver可以在註冊表中的
HKEY_LOCAL_MACHINE\SOFTWARE\ODBC\ODBCINST.INI\
中找到

ACCESS支援子查詢

ACCESS支援外串連,但不包括完整外部聯結,如支援
LEFT JOIN 或 RIGHT JOIN
但不支援
FULL OUTER JOIN 或 FULL JOIN

ACCESS中的日期查詢
注意:ACCESS中的日期時間分隔字元是#而不是引號
Select * From Tab1 Where [Date]>#2002-1-1#;
在DELPHI中我這樣用
SQL.Add(Format(
'Select * From Tab1 Where [Date]>#%s#;',
[DateToStr(Date)]));

ACCESS中的字串可以用雙引號分隔,但SQLSERVER不認,所以為了遷移方便和相容,
建議用單引號作為字串分隔符號.

常在一些bbs上面看見有人在問Access轉換為 MS SQL 有什麼要注意的地方,或是編寫預存程序,現在小弟在此寫一些要注意的或者常用的文法給大家參考(部分為asp常用的函數)

-------------------

Access : Now()

MS SQL : GetDate()

-------------------

Access : mid

MS SQL : SubString( expression , start , length )
expression-要搜尋的目標,但不能使用彙總函式
start-指定字串的開始位置
length-指定擷取字串的長度

-------------------

Asp : Instr

MS SQL:CharIndex( expression1 , expression2 )
參數的位置和 Asp 的 Instr剛好相反

-------------------

Asp : Dim

MS SQL : Declare @variable DataType
舉例:Declare @VarName VarChar(50) 聲明變數@VarName為VarChar類型,長度為50

-------------------

賦值:
Declare @VarName VarChar(10)
Set @VarName = 'This is Content'

-------------------

資料類型轉換函式,如 Asp 的 Cstr,Clng

MS SQL : Cast( expression As DataType)
expression 為目標對象
DataType 為要轉換成的資料類型
舉例:
Declare @VarName VarChar(20) -- 聲明一個 @VarName 變數為VarChar類型,長度20
Set @VarName = '2' -- 給 @VarName 賦值
Cast( @VarName As Int) -- 轉換成 Int 類型資料

-------------------

字串串連符號: +

-------------------

迴圈:
While Boolean_expression
Begin
-- 要執行的語句
End

Boolean_expression 為布林運算式,只要指定的條件為真,就迴圈執行語句

-------------------

if 的用法
if (Boolean_expression)
Begin
-- 執行 True 分支....
End

if....else.... 的用法
if (Boolean_expression)
Begin
-- 執行 True 分支....
End
Else
Begin
-- 執行 False 分支
End

-------------------

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.