㈠ ACCESS sql語句有哪些(常用)
常用資料庫語句:
查詢語句--->
select
*
from
table
修改語句--->
update
table
刪除語句--->
delete
something
增加語句--->
insert
something
所有資料庫中...無非都是這些常用語句!
㈡ Access資料庫,請寫成SQL查詢語句
是得查詢出來的
㈢ access的sql查詢語句怎麼寫
Access SQL查詢語句是兼容的,有兩種方式可以使用SQL語句:
方式一:在「查詢」的試圖里,可以使用Access的向導模式,也可以直接使用SQL語言模式,如下圖:
打開任何一個查詢,在標簽處選擇SQL視圖
㈣ ACCESS 追加查詢 SQL語句
追加語句:
InsertInto目的表名(目的表名.欄位1,目的表名.欄位2)Values('值1','值2');
上面是標準的語法。跟T_SQL操作查詢是一樣的。所以他也能嵌套擴展,比如我要表對表追加查詢:
InsertInto目的表名(目的表名.欄位1,目的表名.欄位2)Select來源表.欄位1,來源表.欄位2from來源表
你也可以給他有選擇性的篩選:
InsertInto目的表名(目的表名.欄位1,目的表名.欄位2)Select來源表.欄位1,來源表.欄位2from來源表where條件加在這
你也可以嵌套連接查詢,舉個例子,我要向A表追加B表數據,當A表有重復某個欄位就不重復追加,沒有就追加,通過這種方法避免重復追加:
InsertIntoA(A.欄位1,A.欄位2)SelectB.欄位1,B.欄位2fromBLeftjoinAonB.欄位1=A.欄位1where((A.欄位1)isnull)
㈤ access的sql語句有哪些
建表:
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=SQLServer;UID=sa;PWD=;Server=127.0.0.1;DataBase=Demo;]
外部數據源連接屬性的完整參數是:
[ODBC;DRIVER=driver;SERVER=server;DATABASE=database;UID=user;PWD=pass(word);]
其中的DRIVER=driver可以在注冊表中的
HKEY_LOCAL_MACHINESOFTWAREODBCODBCINST.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不認,所以為了遷移方便和兼容,
建議用單引號作為字元串分隔符.
查詢時生成序號
SELECT (SELECT Count([xlh].[aa]) AS AutoNum FROM xlh WHERE (((xlh.aa)<=xlh_Alias.aa));) AS 序號, xlh.aa
FROM xlh AS xlh_Alias INNER JOIN xlh ON xlh_Alias.aa=xlh.aa
ORDER BY xlh.aa;
多表sql查詢
SELECT test.aa AS 第一個欄位, test1.bb AS 第二個欄位, test1.cc
FROM test, test1
WHERE test.aa=test1.aa;
多表sql查詢1
SELECT a.aa, b.bb, b.cc, b.cc*100 AS 合計
FROM test AS a, test1 AS b
WHERE a.aa=b.aa;
多表sql查詢排序
SELECT a.aa, b.bb, b.cc AS 第三個欄位
FROM test AS a, test1 AS b
WHERE a.aa=b.aa
ORDER BY b.cc;
查詢例子
SELECT a.dhhm
FROM xl11a AS a, xl919 AS b
WHERE a.dhhm=b.dhhm and aa<>"1";
日期時間分隔符是#而不是引號
Select * From Tab1 Where [Date]>#2002-1-1#;
兩個表關聯修改多個欄位
UPDATE chhl AS a, jbsj AS b SET a.fzr = b.fzr, a.gh = b.gh
WHERE a.dhhm=b.dhhm;
update chhl set (fzr,gh)=
(SELECT b.fzr, b.gh
FROM chhl AS a, jbsj AS b
WHERE a.dhhm=b.dhhm);
如果Tab2可以不是一個表,而是一個查詢
UPDATE Tab1 a,(Select ID,Name From Tab2) b
SET a.Name = b.Name
WHERE a.ID = b.ID;
UPDATE Tab1 a,Tab2 b
SET a.Name = b.Name
WHERE a.ID = b.ID;
訪問多個不同的ACCESS資料庫-在SQL中使用In子句,外部資料庫不能帶密碼
Select a.*,b.* FromTab1 a,Tab2 b In 'db2.mdb' Where a.ID=b.ID;
將一個表的某個欄位置空
UPDATE chhl AS a SET a.fzr = null, a.gh = null;
刪除兩個表中欄位一樣的記錄
delete from xl11 where dhhm in(SELECT a.dhhm
FROM xl11 AS a, xl919 AS b
WHERE a.dhhm=b.dhhm;);
完成後ACCESS中欄位Name索引屬性顯示為--有(無重復)
Create Unique Index iName ON Tab1 (Name);
下面的語句刪除剛才建立的兩個索引
Drop Index iDate ONTab1;
Drop Index iName ON Tab1;
㈥ access SQL語句查詢
給你個笨辦法,在SQL查詢分析器中測試通過
select * from a where a3 <= (select a3 from a where a4=1) or a1 <> (select a1 from a where a4=1)
㈦ 查詢ACCESS SQL語句
查詢1:查詢除了供應商A和供應商B以外,所有物料所有供應商最新采購價格記錄:
selecta.*from原始表asa,
(select物料,供應商,max(采購時間)as最新采購時間from原始表where供應商notin('A','B')groupby物料,供應商)asb
wherea.物料=b.物料anda.供應商=b.供應商anda.采購時間=b.最新采購時間
結果:
㈧ 求幾條access的sql查詢語句
select * from (select * from data1 where (CT like '*肝*') OR (B超 like '*肝*') OR (MR like '*肝*')) where (CT not like '*脂肪肝*') AND (B超 not like '*脂肪肝*') AND (MR not like '*脂肪肝*')