Dealing with databases on SAP NetWeaver Java stack is is usually done by using JDBC.
Each installation of an app server has a standard db schema named sap<db name>db
which SAP encourages you to use for your applications viaOpenSQL, SAP's database
abstraction layer for Java. There are a couple of advantages that you get by using
OpenSQL, e.g. support for Java Dictionary (which lets you deploy your table definitions
and data types from NWDS), Table Buffer, Statement Pool, SQL Checker and SQL Trace.
Further by using SQLJ, part of the OpenSQL framework, you get compile time checks
for your SQL statements and that's one thing we all really like in ABAP, do we?
When connecting from outside of EJB you should use a DataSource Alias (DSA) instead.
You define a resource reference and DSA as parts of your application. By that your
application is easy portable once you need to move it to a new database instance or
schema. You'll find more on this in the DataSource Alias FAQ.
1. OpenSQL is only supported in the standard schema. Each additional schema has to use
either Native_SQL or Vendor_SQL. That means you'll loose a couple to many of the
advantages mentioned before, because they are only supported in OpenSQL.
2. It may not always easy for a developer to get the necessary access to the server for
setting up a new DataSource and as a developer being dependent from an administrator
isn't always desirable.
2. Second best known is probably the web based version using NW Administrator but to
get access to it you'll face the same hurdles as with VA. (email@example.com).
3. For the ones who prefer to use a shell there is the MAKE_DATA_SOURCE from
DBPOOL. Be sure to have file system access on the server here. (firstname.lastname@example.org
4. There is a fourth way to deploy your new DataSource as a part of your application. The
only thing you need here is the SDM password that you probably already have for your
usual deployments. The official documentation is a little weak on that point. So let's take
a look at the necessary steps for this task.
A DataSource definition used in a NW Java stack is described by a XML file that is based
on adata- sources.dtd. You can generate a proper data-sources.xml file from this DTD
definition. Another way is to create a new DataSource in Visual Admin underServi ces-
>JDBC Connector and export it as shown below.
That way you already have the necessary information filled into the right place. Just
make sure to set for thep a ssword tag the attributeencrypted tofalse and provide the right
Next you have to store both files data-sources.dtd and data-sources.xml into the META- INF directory inside your Enterprise Application Project so that they will get deployed as part of your .ear archive.
Now bringing you back...
Does that email address look wrong? Try again with a different email.