Solved

VB.NET Database programming question

Posted on 2004-10-12
8
185 Views
Last Modified: 2010-04-23
This connection string (should) connects to an Access database and its obvious here that it wont connect because VB.NET does not know where the underlying database resides.  What if the application is ported somewhere else like a different folder, would the application still be able to connect to the database.  Its obvious i would need a data source to specify where the underlying database is but what should i do to have the connection string dynamic in a such a way i can port the application without the need of the data source?
 
Dim ConnectionString _
            As String = "Provider=Microsoft.Jet.OLEDB.4.0;Integrated " & _
        "Security=SSPI;Persist Security Info=False;Initial " & _
        "Catalog=Students;Packet Size=4096;Workstation ID=Admin;" & _
        "Use Encryption for Data=False"

0
Comment
Question by:gbilios
8 Comments
 
LVL 25

Expert Comment

by:RonaldBiemans
ID: 12285736
When you say ported, do you mean the application is installed lets say on a different computer in a different directory ?,

Bye the way you posted your question twice
0
 

Author Comment

by:gbilios
ID: 12285783
okay, sorry for submitting the same question twice.

When i said port , i meant what would happen if the application is moved to a different directory or the database is moved to a different directory.

 
0
 
LVL 19

Expert Comment

by:arif_eqbal
ID: 12285841
Use Application.StartupPath to get the current Folder i.e. where your EXE is residing, either store the MDB file there or create a relative path

eg
say you store your database in a folder called Database within the folder that holds the exe then

Path=Application.StartupPath & "\YourDataBase.mdb"

then use it in the connection string
0
3 Use Cases for Connected Systems

Our Dev teams are like yours. They’re continually cranking out code for new features/bugs fixes, testing, deploying, testing some more, responding to production monitoring events and more. It’s complex. So, we thought you’d like to see what’s working for us.

 
LVL 9

Expert Comment

by:checoo
ID: 12285901
rather than hard coding the database path within the application, you can use a app.config file to store the location of the database. Then at runtime you can read that setting and build your connection string accordingly.
0
 

Author Comment

by:gbilios
ID: 12285936
I tried that.  I got an error.

The connection objects open method fails
0
 

Author Comment

by:gbilios
ID: 12285952
This is the connection string now to connect to an access database.
I tried that code you suggested.  The call to the connection object's open method fails

Dim ConnectionString As String = _
        "Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Registry Path=;" & _
        "Jet OLEDB:Database Locking Mode=1;Data Source=C:\SCC313\Project4\Students.mdb;" & _
        "Students.mdb;Mode=Share Deny None;" & _
        "Jet OLEDB:Engine Type=5;Provider=Microsoft.Jet.OLEDB.4.0;Jet OLEDB:" & _
        "System database=;Jet OLEDB:SFP=False;persist security info=False;" & _
        "Extended Properties=;Jet OLEDB:Compact Without Replica Repair=False;" & _
        "Jet OLEDB:Encrypt Database=False;Jet OLEDB:Create System Database=False;" & _
        "Jet OLEDB:Don't Copy Locale on Compact=False;User ID=Admin;Jet OLEDB:" & _
        "Global Bulk Transactions=1"
0
 
LVL 19

Expert Comment

by:arif_eqbal
ID: 12285958
what method are you trying config file or Application.StartupPath
Check the path that you have built through a msgbox is it OK ??

0
 
LVL 19

Accepted Solution

by:
arif_eqbal earned 125 total points
ID: 12285976
C:\SCC313\Project4\Students.mdb;" & _
        "Students.mdb;Mode=Share Deny None;" & _

the mdb name is repeating
0

Featured Post

Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This tutorial demonstrates one way to create an application that runs without any Forms but still has a GUI presence via an Icon in the System Tray. The magic lies in Inheriting from the ApplicationContext Class and passing that to Application.Ru…
The ECB site provides FX rates for major currencies since its inception in 1999 in the form of an XML feed. The files have the following format (reducted for brevity) (CODE) There are three files available HERE (http://www.ecb.europa.eu/stats/exch…
This Micro Tutorial hows how you can integrate  Mac OSX to a Windows Active Directory Domain. Apple has made it easy to allow users to bind their macs to a windows domain with relative ease. The following video show how to bind OSX Mavericks to …
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

809 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question