亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Delphi > 正文

在Delphi中的Access技巧集

2024-07-21 02:12:25
字體:
來源:轉載
供稿:網友
1.delphi中操作access數據庫(建立.mdb文件,壓縮數據庫)
以下代碼在win2k,d6,mdac2.6下測試通過,
編譯好的程序在win98第二版無access環境下運行成功.
//在之前uses comobj,activex
//聲明連接字符串
const
sconnectionstring = 'provider=microsoft.jet.oledb.4.0;data source=%s;'
+'jet oledb:database password=%s;';

//=============================================================================
// procedure: gettemppathfilename
// author : ysai
// date : 2003-01-27
// arguments: (none)
// result : string
//=============================================================================
function gettemppathfilename():string;
//取得臨時文件名
var
spath,sfile&:array [0..254] of char;
begin
gettemppath(254,spath);
gettempfilename(spath,'~sm',0,sfile);
result:=sfile;
deletefile(pchar(result));
end;

//=============================================================================
// procedure: createaccessfile
// author : ysai
// date : 2003-01-27
// arguments: filename:string;password:string=''
// result : boolean
//=============================================================================
function createaccessfile(filename:string;password:string=''):boolean;
//建立access文件,如果文件存在則失敗
var
stempfilename:string;
vcatalog:olevariant;
begin
stempfilename:=gettemppathfilename;
try
vcatalog:=createoleobject('adox.catalog');
vcatalog.create(format(sconnectionstring,[stempfilename,password]));
result:=copyfile(pchar(stempfilename),pchar(filename),true);
deletefile(stempfilename);
except
result:=false;
end;
end;

//=============================================================================
// procedure: compactdatabase
// author : ysai
// date : 2003-01-27
// arguments: afilename,apassword:string
// result : boolean
//=============================================================================
function compactdatabase(afilename,apassword:string):boolean;
//壓縮與修復數據庫,覆蓋源文件
var
stempfilename:string;
vje:olevariant;
begin
stempfilename:=gettemppathfilename;
try
vje:=createoleobject('jro.jetengine');
vje.compactdatabase(format(sconnectionstring,[afilename,apassword]),
format(sconnectionstring,[stempfilename,apassword]));
result:=copyfile(pchar(stempfilename),pchar(afilename),false);
deletefile(stempfilename);
except
result:=false;
end;
end;
//=============================================================================
// procedure: changedatabasepassword
// author : ysai
// date : 2003-01-27
// arguments: afilename,aoldpassword,anewpassword:string
// result : boolean
//=============================================================================
function changedatabasepassword(afilename,aoldpassword,anewpassword:string):boolean;
//修改access數據庫密碼
var
stempfilename:string;
vje:olevariant;
begin
stempfilename:=gettemppathfilename;
try
vje:=createoleobject('jro.jetengine');
vje.compactdatabase(format(sconnectionstring,[afilename,aoldpassword]),
format(sconnectionstring,[stempfilename,anewpassword]));
result:=copyfile(pchar(stempfilename),pchar(afilename),false);
deletefile(stempfilename);
except
result:=false;
end;
end;

2.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與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為關聯的所有記錄.
缺點-外部數據庫不能帶密碼.
補充:看到ugvanxk在一貼中的答復,可以用
select * from [c:/aa/a.mdb;pwd=1111].table1;
access xp測試通過

在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/
中找到
異構數據庫之間導數據參見 碧血劍 的
http://www.delphibbs.com/delphibbs/dispq.asp?lid=1691966

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不認,所以為了遷移方便和兼容,
建議用單引號作為字符串分隔符.
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美午夜激情小视频| 欧美激情2020午夜免费观看| 欧美一二三视频| 在线观看日韩视频| 欧美性猛交xxxx久久久| 欧美午夜精品久久久久久久| 欧美日韩成人精品| 欧美综合一区第一页| 国产高清视频一区三区| 国产成人精品一区| 日本亚洲欧洲色α| 97视频色精品| 日韩黄色在线免费观看| 欧美日韩中文在线| 国产精品视频资源| yw.139尤物在线精品视频| 91精品国产99久久久久久| 亲爱的老师9免费观看全集电视剧| 在线视频亚洲欧美| 理论片在线不卡免费观看| 国模精品一区二区三区色天香| 国产极品jizzhd欧美| 欧美电影免费观看高清完整| 日韩精品在线视频| 国产激情久久久| 亚洲精品美女在线观看播放| 亚洲视频精品在线| 国产美女精品视频免费观看| 91老司机精品视频| 性欧美长视频免费观看不卡| 自拍亚洲一区欧美另类| 91在线无精精品一区二区| 久久99精品视频一区97| 国产精品电影一区| 热久久99这里有精品| 国产精品久久久久久网站| 欧美日本精品在线| 亚洲码在线观看| 一区二区国产精品视频| 欧美专区国产专区| 国产精品视频一区国模私拍| 精品视频偷偷看在线观看| 国产精品夜色7777狼人| 亚洲国产精品成人av| 欧美性色xo影院| 91久久久国产精品| 久热精品视频在线| 韩剧1988在线观看免费完整版| 精品亚洲国产成av人片传媒| 欧美做受高潮电影o| 成人午夜激情网| 精品网站999www| 国产精品电影久久久久电影网| 国产精品偷伦一区二区| 日韩精品极品在线观看播放免费视频| 91在线高清视频| 色综合男人天堂| 国产在线日韩在线| 欧美成人午夜激情视频| 欧美一级在线亚洲天堂| 亚洲免费高清视频| 亚洲综合在线播放| 91在线色戒在线| 国产999精品久久久| 91国偷自产一区二区三区的观看方式| 亚洲黄一区二区| 国内精品久久久久久中文字幕| 中文字幕欧美日韩| 9.1国产丝袜在线观看| 热re91久久精品国99热蜜臀| 日韩精品在线观看网站| 2019中文字幕免费视频| 亚洲一区二区三区在线视频| 国产欧美精品久久久| 色偷偷噜噜噜亚洲男人| 欧美在线视频播放| 欧美综合激情网| 国产精品亚洲自拍| 国产香蕉97碰碰久久人人| 91美女片黄在线观看游戏| 国产色婷婷国产综合在线理论片a| 97视频在线免费观看| 国产精品丝袜高跟| 成人国产精品日本在线| 久久久久久国产| 九九久久久久99精品| 亚洲二区中文字幕| 亚洲美女精品久久| 久久精品精品电影网| 色综合视频一区中文字幕| 久久躁日日躁aaaaxxxx| 日韩精品免费在线播放| 成人激情在线观看| 国产欧美一区二区| 欧美国产日韩一区二区在线观看| 日韩av电影在线网| 日韩在线视频免费观看高清中文| 欧美一级片在线播放| 亚洲大尺度美女在线| 亚洲一区亚洲二区亚洲三区| 国产97在线|亚洲| 91久久国产婷婷一区二区| 国产精品久久久久久av| 国产一区二区三区久久精品| 亚洲美女av电影| 精品视频中文字幕| 91爱爱小视频k| 国产精品视频一| 免费不卡欧美自拍视频| www国产91| 国产日韩综合一区二区性色av| 国产精品一区二区三区免费视频| 日韩av123| 伊人久久男人天堂| 久久99亚洲热视| 最近2019中文字幕mv免费看| 亚洲福利视频在线| 国产精品视频白浆免费视频| 高清欧美性猛交xxxx| 成人看片人aa| 久久国产精品亚洲| xvideos亚洲人网站| 97超碰蝌蚪网人人做人人爽| 国产精品一区二区久久久| 国产伦精品一区二区三区精品视频| 亚洲美女福利视频网站| 色偷偷偷综合中文字幕;dd| 欧美一级成年大片在线观看| 中文字幕亚洲字幕| 欧美激情精品久久久久久黑人| 国产精自产拍久久久久久蜜| 激情亚洲一区二区三区四区| 国产精品爽爽ⅴa在线观看| 亚洲精品电影久久久| 亚洲成人久久久| 国产欧美日韩中文字幕在线| 日本电影亚洲天堂| 亚洲精品视频播放| 欧美日韩成人免费| 亚洲第一福利在线观看| 中文字幕日韩在线播放| 亚洲精品理论电影| 欧美在线视频观看| 亚洲视频一区二区| 精品国产欧美成人夜夜嗨| 亚洲jizzjizz日本少妇| 国产精品第一视频| 亚洲专区国产精品| 亚洲午夜精品久久久久久性色| 26uuu亚洲国产精品| 国模精品一区二区三区色天香| 欧美日韩国产专区| 亚洲欧洲第一视频| 日韩成人av网| 亚洲第一区中文字幕| 久久精品国产精品| 国产不卡av在线免费观看| 国产亚洲欧美日韩一区二区| 欧美成人网在线| 98视频在线噜噜噜国产| 最近免费中文字幕视频2019| 国产精品久久久久久搜索| 九九热精品视频在线播放| 2021久久精品国产99国产精品|