access中链接表的问题
程序员文章站
2022-03-25 21:38:57
一个使用asp和mdb的站点,某个mdb中使用了链接表,链接到当前目录的另一个mdb中的表,这样可以达到数据共享。 faq-it.org/delph...
一个使用asp和mdb的站点,某个mdb中使用了链接表,链接到当前目录的另一个mdb中的表,这样可以达到数据共享。
faq-it.org/delphi_win_sdk/问题来了,当将网站发布到网站的时候,因为网上空间路径和我本机不同,所以链接表失败,网页当然也不能打开。
我觉得解决办法有:
一种,在本机上创建与网上空间完全相同的目录结构。但这很麻烦,特别是经常要换网站的话。
一种,如何让链接表使用相对路径,就是链接到当前目录下的那个mdb文件?(对了,access很弱智,链接表记录的是绝对路径)。
还一种,如何通过编程(asp 或者本地vba)来实现对链接表的链接的修改?(又对了,access还是弱智,更新链接表我只能使用手工更新,一定要找到那个路径下的mdb才行!可本地路径和网上不一样呀)
谁能告诉我如何实现上面的后两种方法?
---------------------------------------------------------------
以下是我自己在用的adox代码,只为了证明我说的access有此功能(说句不好听的:这关access p事啊?这是ado模型该解决的问题。而且你也提错地方了,提到asp那一块更合适),做access编程的都应该看得懂,如果你看不懂我也只能说遗憾了。
public function newlinkedexternaltablemdb()
dim strtargetdb() as string
dim strproviderstring() as string
dim strsourcetbl() as string
dim strlinktblname() as string
dim catdb as adox.catalog
dim tbllink as adox.table
dim tmplink as adox.table
dim i as integer
dim j as integer
set catdb = new adox.catalog
catdb.activeconnection = currentproject.connection
i = catdb.tables.count
redim strtargetdb(i)
redim strproviderstring(i)
redim strsourcetbl(i)
redim strlinktblname(i)
i = 1
for each tmplink in catdb.tables
if tmplink.properties("jet oledb:create link") then
if trim(tmplink.properties("jet oledb:remote table name")) <> "" then
strlinktblname(i) = tmplink.name
strtargetdb(i) = tmplink.properties("jet oledb:link datasource")
strproviderstring(i) = tmplink.properties("jet oledb:link provider string")
strsourcetbl(i) = tmplink.properties("jet oledb:remote table name")
do while instr(1, strtargetdb(i), "/") <> 0
strtargetdb(i) = mid(strtargetdb(i), instr(1, strtargetdb(i), "/") + 1, len(strtargetdb(i)))
loop
strtargetdb(i) = currentproject.path & "/" & strtargetdb(i)
i = i + 1
end if
end if
next
j = i - 1
for i = 1 to j
catdb.tables.delete strlinktblname(i)
set tbllink = new adox.table
with tbllink
.name = strlinktblname(i)
set .parentcatalog = catdb
.properties("jet oledb:create link") = true
.properties("jet oledb:link datasource") = strtargetdb(i)
.properties("jet oledb:link provider string") = strproviderstring(i)
.properties("jet oledb:remote table name") = strsourcetbl(i)
end with
catdb.tables.append tbllink
set tbllink = nothing
next
set catdb = nothing
end function
faq-it.org/delphi_win_sdk/问题来了,当将网站发布到网站的时候,因为网上空间路径和我本机不同,所以链接表失败,网页当然也不能打开。
我觉得解决办法有:
一种,在本机上创建与网上空间完全相同的目录结构。但这很麻烦,特别是经常要换网站的话。
一种,如何让链接表使用相对路径,就是链接到当前目录下的那个mdb文件?(对了,access很弱智,链接表记录的是绝对路径)。
还一种,如何通过编程(asp 或者本地vba)来实现对链接表的链接的修改?(又对了,access还是弱智,更新链接表我只能使用手工更新,一定要找到那个路径下的mdb才行!可本地路径和网上不一样呀)
谁能告诉我如何实现上面的后两种方法?
---------------------------------------------------------------
以下是我自己在用的adox代码,只为了证明我说的access有此功能(说句不好听的:这关access p事啊?这是ado模型该解决的问题。而且你也提错地方了,提到asp那一块更合适),做access编程的都应该看得懂,如果你看不懂我也只能说遗憾了。
public function newlinkedexternaltablemdb()
dim strtargetdb() as string
dim strproviderstring() as string
dim strsourcetbl() as string
dim strlinktblname() as string
dim catdb as adox.catalog
dim tbllink as adox.table
dim tmplink as adox.table
dim i as integer
dim j as integer
set catdb = new adox.catalog
catdb.activeconnection = currentproject.connection
i = catdb.tables.count
redim strtargetdb(i)
redim strproviderstring(i)
redim strsourcetbl(i)
redim strlinktblname(i)
i = 1
for each tmplink in catdb.tables
if tmplink.properties("jet oledb:create link") then
if trim(tmplink.properties("jet oledb:remote table name")) <> "" then
strlinktblname(i) = tmplink.name
strtargetdb(i) = tmplink.properties("jet oledb:link datasource")
strproviderstring(i) = tmplink.properties("jet oledb:link provider string")
strsourcetbl(i) = tmplink.properties("jet oledb:remote table name")
do while instr(1, strtargetdb(i), "/") <> 0
strtargetdb(i) = mid(strtargetdb(i), instr(1, strtargetdb(i), "/") + 1, len(strtargetdb(i)))
loop
strtargetdb(i) = currentproject.path & "/" & strtargetdb(i)
i = i + 1
end if
end if
next
j = i - 1
for i = 1 to j
catdb.tables.delete strlinktblname(i)
set tbllink = new adox.table
with tbllink
.name = strlinktblname(i)
set .parentcatalog = catdb
.properties("jet oledb:create link") = true
.properties("jet oledb:link datasource") = strtargetdb(i)
.properties("jet oledb:link provider string") = strproviderstring(i)
.properties("jet oledb:remote table name") = strsourcetbl(i)
end with
catdb.tables.append tbllink
set tbllink = nothing
next
set catdb = nothing
end function
上一篇: 比较不错的asp单表单字段多条件查询
推荐阅读
-
php的swoole扩展中onclose和onconnect接口不被调用的问题,swooleonclose_PHP教程
-
python-关于mysql中的位图索引和位片索引问题
-
关于php中sql注射的有关问题
-
完美解决PHP中的Cannot modify header information 问题_PHP教程
-
解决php中Cannot send session cache limiter 的有关问题
-
由 php 中 if 想到的些问题
-
解决Mysql 8.0.17 winx64版本安装过程中遇到的问题
-
内蒙古自治区*管理局 深入探讨PHP中的内存管理问题
-
浅谈Docker-compose中的depends_on顺序的问题解决
-
PHP中的&传值引用的问题,在foreach循环的结果能帮解释下输出的结果原理是什么? - 红藕香残