Specify mdw file in embedded connection string to another Jet mdb: possible?
Asked Answered
M

5

1

I can use the following syntax in a Jet (mdb) query to select data from another .mdb file:

SELECT * FROM [Database=C:\Tempo\AnotherDB.mdb;].MyTable

alternatively

SELECT * FROM MyTable IN 'C:\Tempo\Another.mdb'

I want to extend this to use workgroup security a.k.a. User Level Security (ULS). I know how to specify a userID and password e.g.

SELECT *
FROM
[Database=C:\Tempo\AnotherDB.mdb;UID=Admin;PWD=***;].MyTable

but this only works when both mdb's share the same mdw.

How would I specify the path of the mdw file used to secure the other mdb? Is it possible? If not, why not?

P.S. I asked this question many years ago in this Access newsgroup post but received no reply. I gave up after an Access MVP convinced me it was not possible; I don't recall the details but it was something to do with the underlying architecture (a workspace supports only one workgroup file and there is no mechanism for a Jet query to instantiate a new workspace? something like that anyway).

My renewed interest has been sparked by this SO comment.

Magpie answered 14/5, 2009 at 11:24 Comment(1)
It is likely impossible using Jet directly. But I'd think you could do it with OLEDB. Dunno if you can use ODBC to Jet in this context -- it's mostly prohibited within Access, but might work in a saved query.Pyralid
M
1

Simple answer: it's not possible.

Magpie answered 16/10, 2009 at 9:40 Comment(1)
Given that you're running your query within one workspace, and a workspace can use only a single workgroup file, it would stand to reason that it wouldn't work. In code within Access, you can instantiate a different workspace using a different workgroup and then pull data from that workspace into a temp table in the current database, which you could then use in the main workspace. That may solve your problem, though it doesn't do it in the elegant way you were seeking.Pyralid
S
2

Short answer is no. If you use the source db then you can't specify another workgroup and if leave it blank and specify a valid connection string then you will get an ISAM error. (Although that method works just fine for other databases such as SQL Server.) Example (does not work):

SELECT *
FROM Table1 IN '' [Provider=Microsoft.Jet.OLEDB.4.0;Password=foo;User ID=Oorang;Data Source=C:\Users\Oorang\Documents\db1.mdb;Persist Security Info=True;Jet OLEDB:System database=C:\Users\Oorang\Documents\Security.mdw];

However you can do it with ADO. I'm not sure what you are trying to accomplish once you have the query, but here is how to get it into a recordset:

Option Explicit
Sub ADODBExample()
    Dim cn As ADODB.Connection
    Dim rs As ADODB.Recordset
    Set cn = New ADODB.Connection
    cn.Open "Provider=Microsoft.Jet.OLEDB.4.0;Password=foo;User ID=Oorang;Data Source=C:\Users\Oorang\Documents\db1.mdb;Persist Security Info=True;Jet OLEDB:System database=C:\Users\Oorang\Documents\Security.mdw"
    Set rs = New ADODB.Recordset
    rs.Open "SELECT * FROM Table1;", cn
    Debug.Print rs.GetString
    rs.Close
    cn.Close
End Sub

It is worth noting that both methods end up hard coding the account credentials. It might be better to either A.) Prompt the user to provide said info, or B.) Use a special account with read-only access limited to the minimum. You might also be well advised to take a few steps to obfuscate the info in your code as well as password protecting your project does not actually obscure the text stored in the file in any way.

Storybook answered 18/5, 2009 at 3:51 Comment(2)
Thanks for the reply but I think you slightly missed the point with your "Example (does not work)". You can't just put an OLE DB connection string into the IN clause, it doesn't work like that. You can't even put an ODBC connection string in there, sadly. Rather, ACE/Jet it has its own peculiar syntax and the fact I cannot find (or guess) what the syntax for the mdw suggests it cannot be done (but it would good to learn the reason why it is not possible). Thanks anyway!Magpie
"I'm not sure what you are trying to accomplish" -- essentially, it's a quick and dirty way of copying data from one mdb to another with having to create a linked table etc. It appears one caveat is that both mdb's are secured using the same mdw's.Magpie
M
1

Simple answer: it's not possible.

Magpie answered 16/10, 2009 at 9:40 Comment(1)
Given that you're running your query within one workspace, and a workspace can use only a single workgroup file, it would stand to reason that it wouldn't work. In code within Access, you can instantiate a different workspace using a different workgroup and then pull data from that workspace into a temp table in the current database, which you could then use in the main workspace. That may solve your problem, though it doesn't do it in the elegant way you were seeking.Pyralid
S
0

Well... actually you can use the connection string. It works best with SQL Server. I was just showing how it would like if it worked with Access. The point I was trying to make is that there is a valid syntax... It's just that Access won't allow you to do that with Access. (It will let you do that if the connection is to another type of database.) Funny that the feature is compatible with other types of DBs and not Access... When it's Access, but true nevertheless.

Although if they are secured with the same MDW then all you have to do is this, and the query will run in the context of the currently logged in user:

SELECT *
FROM Table1 IN 'C:\Users\Oorang\Documents\db2.mdb';
Storybook answered 19/5, 2009 at 0:32 Comment(1)
I still can't get the OLE DB connection string to work, either for Jet or for SQL Server. See my answer posted below...Magpie
S
0

Maybe I should reconsolidate and clarify:) In the context of your original question, the answer is: You can't do it via SQL/Query Builder, if the databases are: both Access, and have a different mdw. However, if both databases are Access and have the same mdw, (as your later comment indicated) then you can do it via SQL/Query Builder. In that specific scenario you would not (can't) do it via a connection string you would do it following the steps 1-4 below, then replace step 5a with 5b.

If the databases are both Access and have a different mdw, the only way to specify a different workgroup is with the connection string. However the SQL/Query Builder will throw a ISAM error if you try to via the connection string property (in step 5a below). So you can't do it via the Query builder. You can do it with VBA using ADO as in my example posted previously.

Remember that the connection string property in the query builder is for non-Access databases, source database is for Access databases with the same (or no) mdw. For Access databases with different mdws the only solution I am aware of is the VBA one I posted previously.

Now as to using the connection string directly in SQL. You can do this. But there are some caveats: It won't work with other Access databases. If you do it with SQL Sever dbo tables, you will have to edit the SQL the query builder generates to remove the "dbo." prefix.

I think the simplest way is to just walk you through what I am trying to say.

  1. Set up a working connection string to a non-access database. (I suggest to keep it easy, just use an Excel file.)
  2. Once you have the string open the query builder in Access.
  3. Close the select table dialog.
  4. Press Alt-Enter to open Query Properties. 5a. In "Source Connect Str" paste the Connection String. *5b. Paste the path to the other database in "Source Database".
  5. Now add your tables and build your query.
  6. Go to the SQL view. See what was built.

But it's almost irrelevant as this approach, while valid for non-Access databases, does not work for Access. (It's a bit frustrating I know.)

Example of connection string in use:

SELECT [Sheet1$].F1
FROM [Sheet1$] IN '' [Excel 5.0;HDR=NO;IMEX=2;DATABASE=C:\Users\Oorang\Documents\Book1.xls];

I really do not think it is valid ACE/Jet syntax to put an OLE DB connection string into the IN database clause.

Just as an FYI, you use the connection string, as shown above, but if you use the Source Db property, you will get what is below:) (I tested all my examples before I posted them:))

SELECT *
FROM Table1 IN 'C:\Users\Oorang\Documents\db2.mdb';
Storybook answered 20/5, 2009 at 18:44 Comment(0)
S
0

You can use a User Defined Function to READ data from another workgroup while using ACCESS.

The restriction to Access is because only Access has the VB hooks which allow you to use User Defined Functions. It is equivilant to using SQL server user defined functions -- which run only if you have SQL Server.

The restriction to read-only is because Access does not provide hooks to User Defined variables, only user defined functions.

In Access, in a User Defined Function, you put code like this:

Dim dbe As DAO.DBEngine
Dim ws As DAO.Workspace
Dim db as DAO.database

    Set dbe = New DAO.PrivDBEngine
    dbe.SystemDB = "whatever.mdw"
    dbe.DefaultUser = "whatever"
    dbe.DefaultPassword = "whatever"

    Set ws = dbe.Workspaces(0)
    Set db = ws.opendatabase( ... )

In that UDF you can use that workspace to read data from from another database, using the "whatever" workgroup file.

Note: If you call this from a select query, make dbe and ws and db and rs global, so that you don't have open the files every time you touch a field in a record. Then the function just has

if rs is empty then
   set dbe = ...
   ...
   set rs = db.openrecordset(...)
end if 
...

Note: If you really want to, you can put an update query into a udf called from a select statement. Do that if you hope to see it posted on thedailywtf.com at some later date.

PS: it's an unusual solution. I was around in 2004, but you wouldn't have got this by posting to "gettingstarted"

Superelevation answered 19/8, 2013 at 1:49 Comment(3)
"[using] Access...User Defined Functions...is equivilant[sic] to using SQL server user defined functions -- which run only if you have SQL Server" -- I believe that is a misstatement. If I do not have SQL Server installed on my local machine but I open an OLE DB connection to a SQL Server database on a remote machine that does have SQL Server installed then I can create/drop/use UDFs (subject to privileges etc)...Magpie
...However, if I do not have Access installed on my local machine and I open an OLE DB connection to an Access Database Engine database on a remote machine then I cannot create/drop/use UDFs (regardless of whether Access is installed on that remote machine). Or have I remembered incorrectly?Magpie
PS: I never really actually used Access (the 'Windows forms'-like RAD member of the MS Office suite) myself back then, rather I used Jet... which almost everyone called 'Access', much to my frustration! There were never any Jet newsgroups so I had to lurk in the Access groups. I seem to recall difficulty in picking the right subgroup to avoid an Access-not-Jet answer and assume that picking gettingstarted was an attempt to do so; the same difficulty exists with SO tags, as you have proved ;)Magpie

© 2022 - 2025 — McMap. All rights reserved.