on 2012 Oct 04 5:11 AM
Hi All
I connect with our IDE (Servoy, an Eclipse plug-in) to SQL Anywhere 12.0.1 using the jconn3.jar driver. Among the JDBC parameters, the URL and Driver are set to: URL: jdbc:sybase:Tds:localhost:2638?ServiceName=dbName&CHARSET=utf8 Driver: com.sybase.jdbc3.jdbc.SybDriver
This works fine (for years already 🙂
Now i would like to use the sajdbc4.jar driver and set the 2 above mentioned parameters to: URL: jdbc:sqlanywhere:localhost:2638?ServiceName=dbName&CHARSET=utf8 Driver: sybase.jdbc4.sqlanywhere.IDriver
but get the error message (when I try to save the newly defined Database Server, i. e. JDBC Adaptor): Save Failed no dbjdbc12 in Java.library.path
I am on OS X 10.7.5 and Java 1.6.0_35
It's true that there is no dbjdbc12.jar in the library path, because in OS X it's called libdbjdbc12.dylib as described here: http://dcx.sybase.com/index.html#1201/en/dbprogramming/jdbc-driver-deploy.html But may be the error message is not adjusted for OS X, could that be?
Has anyone an idea what the missing piece could be to connect with this (sajdbc4.jar) driver?
PS: According to the info here: http://iablog.sybase.com/hinsperg/2009/10/connecting-to-sql-anywhere-using-jdbc/ it seems to me that there is no need to specify the Driver any more, i. e. leaving the field empty?
Thanks for any help and hints, Robert
For the SAJDBC driver on Mac OS X, we search the "DYLD_LIBRARY_PATH" environment variable to locate system libraries.
Does "libdbjdbc12.dylib" exist in a path specified by this environment variable, for this Java executable seesion? (Java's "java.library.path" will include these paths by default upon JVM launch).
Alternatively, can you source sa_config.sh prior to launching the Java session?
(And yes, with JDBC 4.0, you no longer have to use the DriverManager.registerDriver() call to register the JAR file - this now happens automatically)
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Thank you. I just can't seem to get it to work with the sajdbc4.jar file. I have put the file in the same place as the jconn3.jar file, but no luck. I tested with removing the jconn3.jar and looking if connection is not possible (it's not), putting it back in place and connection is possible again. Unfortunatly that does not work with the sajdbc4.jar file.
I used for URL: jdbc:sqlanywhere:localhost:2638?ServiceName=dbName&CHARSET=utf8 Driver: field leaving empty DYLD_LIBRARY_PATH=/Library/SQLAnywhere12/System/lib32/ -> same as for jconn3.jar
I also tried setting the DYLD_LIBRARY_PATH to .../lib64 -> no luck either.
It seems I am missing one more piece to get it to run. Any hint?
Regards, Robert
I used for URL: jdbc:sqlanywhere:localhost:2638?ServiceName=dbName&CHARSET=utf8
That's unfortunately a jConnect URL, not a SQL Anywhere JDBC URL. A SQL Anywhere JDBC URL should look like the examples in the documentation and normally contain the regular SQL Anywhere database connection parameters.
e.g.
jdbc:sqlanywhere:UID=dba;PWD=sql;SERVER=MyServer;DBN=dbName;LINKS=shmem,tcpip(host=localhost;port=2638)
Are you getting the same "No dbjdbc12 in path" error when you try this?
I also tried setting the DYLD_LIBRARY_PATH to .../lib64 -> no luck either
Is Eclipse running/launching a 32-bit or 64-bit JVM? Are you sure that you're setting this value for your Eclipse launch environment correctly?
Hi Jeff, unfortunatly yes, I still get no dbjdbc12 in path, or sometimes, I get JDBC Driver '' not found in class path or drivers directory : java.lang.ClassNotFoundException: (depending whether the Driver field is filled or not), but assume this message is saying the same. I have the sajdbc4.jar at the same place as the jconn3.jar file, which is recognized. I am running a JVM 64 bit, and as far as I understand the OS X version of SQL Anywhere is a 32 bit version, but I also tried pointing to the 64 bit library and that didn't help. Somehow my picture about what should be in what place is blurry, so I am not sure what dedicated action to take to get one step further.
The sajdbc4.jar file should be in the Java environment's classpath (e.g. java -cp /path/to/sajdbc4.jar:/..
). The libdbjdbc12.dylib
should be in the DYLD_LIBRARY_PATH
path, which should match the bitness of the JVM you are running (64-bit in this case). This path value should be passed into the JVM's "java.libaray.path" variable. If you echo this variable ( System.getProperty("java.library.path");
) in your Java program, does it return the same value as DYLD_LIBRARY_PATH
(to ../lib64
), or is it being overridden by your IDE to another value perhaps...?
Jeff
The Java Library Path of my IDE (Servoy Developer) when I read System.getProperty("java.library.path") is: .:/Library/Java/Extensions:/System/Library/Java/Extensions:/usr/lib/java
The Startup of of my IDE (Servoy Developer) incl. the DYLD_LIBRARY_PATH is: /Library/SQLAnywhere12/System/bin32/dbspawn|/Library/SQLAnywhere12/System/bin32/dbsrv12|@/Library/SQLAnywhere12/SQLAnywhere.config#LC_CTYPE=C|LANG=C|DYLD_LIBRARY_PATH=/Library/SQLAnywhere12/System/lib32/
My SQLAnywhere12.config file looks like:
-n walker
-x tcpip{dobroadcast=no;port=2638}
-gd dba
-ti 0
-c 1024m
-ca 0
-qw
-o /Library/SQLAnywhere12/sybase_log.txt
/Library/SQLAnywhere12/databases/servoy_repository.db /Library/SQLAnywhere12/databases/Hades.db
This setup works with the jconn3.jar driver but not with the sajdbc4.jar driver. The jconn3.jar file is in a sub folder of the Servoy installation, as is the sajdbc4.jar file.
I also tried with 2 other tools (WOLips Entity Modeler and Cayenne Modeler) which connect via JDBC to SQL Anywhere, but get the same error. And these tools use the Java Library Path: /System/Library/Java/Extensions
You are saying that I should point to the 64 bit path, but SQLAnywhere 12 on OS X only exists as a 32 bit version.
I did startup with the 32 bit Java, but that didn't help either.
FWIW, AFAIK the SAJDBC driver does not use jConnect's particular syntax to specify connection information but does use the usual SQL Anywhere connection parameters, as documented here.
So I guess once your driver loading problem is solved, you will have to adapt the connection string accordingly to be able to connect.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
User | Count |
---|---|
73 | |
10 | |
8 | |
7 | |
7 | |
6 | |
6 | |
6 | |
6 | |
6 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.