Access中使用SQL語句應掌握的幾點技巧

2022-03-23 13:28:25 字數 2357 閱讀 8309

本文詳細講述了access中使用sql語句應掌握的幾點技巧。

以下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與sql server中的update語句對比

sql server中更新多表的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中的字串可以用雙引號分隔,但sql server不認,所以為了遷移方便和相容, 建議用單引號作為字串分隔符。

ACCESS中使用SQL語句應注意的地方及幾點技巧

access中使用sql語句應注意的地方及幾點技巧 以下sql語句在access xp的查詢中測試通過 建表 create table tab1 id counter,name string,age integer,date datetime 技巧 自增字段用 counter 宣告.欄位名為關鍵字的...

ACCESS中使用SQL語句應注意的地方及幾點技巧

建立索引 下面的語句在tab1的date列上建立可重複索引 create index idate on tab1 date 完成後access中欄位date索引屬性顯示為 有 有重複 下面的語句在tab1的name列上建立不可重複索引 create unique index iname on tab...

ACCESS中使用SQL語句

以下sql語句在access xp的查詢中測試通過 建表 create table tab1 id counter,name string,age integer,date datetime 技巧 自增字段用 counter 宣告.欄位名為關鍵字的字段用方括號括起來,數字作為欄位名也可行.建立索引 ...