VBA|excel连接access 没有使用“../*.mdb”对象权限


1、VBA程序1:A.excel ado连接B.access,读取数据
2、VBA程序2: C.access(代码)生成B.access
3、在VBA程序1文件夹路径下手动创建B1.access,程序运行正常
4、将VBA程序2生成的 B2.access 替换B1.access(改名),出现使用权限错误信息

原因在于access的打开方式,独占方式就会出现上述错误
改成只读或读写就可

adModeUnknown:缺省。当前的许可权未设置
adModeRead:只读
adModeWrite:只写
adModeReadWrite:可以读写
adModeShareDenyRead:阻止其它Connection对象以读权限打开连接
adModeShareDenyWrite:阻止其它Connection对象以写权限打开连接
adModeShareExclusive:阻止其它Connection对象以读写权限打开连接
adModeShareDenyNone:阻止其它Connection对象以任何权限打开连接

连接串例子:
1 只读
Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:/temp/123.mdb;Mode=Read;Persist Security Info=False

2 独占方式
Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d:/temp/123.mdb;Mode=Share Deny Read|Share Deny Write;Persist Security Info=False 
要从 Linux 上的 PHP 连接到 MS Access 远程 .mdb 文件,需要使用 ODBC(Driver for Microsoft Access)。 以下是连接步骤: 1. 安装 unixODBC 和 php-odbc 扩展 ``` sudo apt-get install unixodbc php-odbc ``` 2. 安装 ODBC Driver for Microsoft Access 下载适合您的系统的 ODBC Driver for Microsoft Access,并按照说明进行安装。 3. 配置 ODBC 数据源 使用命令行工具 odbcinst 配置 ODBC 数据源: ``` sudo odbcinst -i -d -f /usr/local/easysoft/access/odbc-access/driver/etc/odbcinst.ini ``` 其中 /usr/local/easysoft/access/odbc-access/driver/etc/odbcinst.ini 是您安装 ODBC Driver for Microsoft Access 后的 odbcinst.ini 文件路径。 4. 配置 DSN(数据源名称) 使用命令行工具 odbcconf 配置 DSN: ``` sudo odbcconf -a -s "accessdsn" -f /usr/local/easysoft/access/odbc-access/driver/etc/odbc.ini -c "DSN=accessdsn|DBQ=/path/to/your/access/database.mdb" ``` 其中 /path/to/your/access/database.mdb 是您要连接的远程 .mdb 文件路径。 5. 编写 PHP 代码 使用 PHP 的 odbc_connect 函数连接到 MS Access 数据库: ```php $conn = odbc_connect("accessdsn", "", ""); if (!$conn) { exit("连接数据库失败!"); } ``` 请注意,您需要将 "accessdsn" 更改为您在步骤 4 中配置的 DSN 名称。 6. 查询数据 使用 PHP 的 odbc_exec 函数查询数据,例如: ```php $result = odbc_exec($conn, "SELECT * FROM table_name"); while ($row = odbc_fetch_array($result)) { echo $row["column_name"]; } ``` 以上是从 Linux 上的 PHP 连接到 MS Access 远程 .mdb 文件的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值