Two Laptop Bag
The moose likes JDBC and Relational Databases and the fly likes Call-level API Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login
JavaRanch » Java Forums » Databases » JDBC and Relational Databases
Bookmark "Call-level API" Watch "Call-level API" New topic

Call-level API

Panagiotis Varlagas
Ranch Hand

Joined: Nov 27, 2000
Posts: 233
Hi all. I've got a rookie question to ask you all.
Reads the JDBC spec:
"The JDBC TM API is the Java TM platform standard call-level API for database access."
My question should be quite simple to answer for all you JDBC/DB gurus: What do we mean by the term "call-level API"?
Thanks in advance,
Panagiotis Varlagas.
Thomas Paul
mister krabs
Ranch Hand

Joined: May 05, 2000
Posts: 13974
from the Sun web site: <A HREF="<p rel="nofollow">" TARGET=_blank>

JDBC Is a Low-level API and a Base for Higher-level APIs
JDBC is a ``low-level'' interface, which means that it is used to invoke (or ``call'') SQL commands directly. It works very well in this capacity and is easier to use than other database connectivity APIs, but it was designed also to be a base upon which to build higher-level interfaces and tools. A higher-level interface is ``user-friendly,'' using a more understandable or more convenient API that is translated behind the scenes into a low-level interface such as JDBC. At the time of this writing, two kinds of higher-level APIs are under development on top of JDBC:

an embedded SQL for Java. At least one vendor plans to build this. DBMSs implement SQL, a language designed specifically for use with databases. JDBC requires that the SQL statements be passed as strings to Java methods. An embedded SQL preprocessor allows a programmer to instead mix SQL statements directly with Java: for example, a Java variable can be used in an SQL statement to receive or provide SQL values. The embedded SQL preprocessor then translates this Java/SQL mix into Java with JDBC calls.
a direct mapping of relational database tables to Java classes. JavaSoft and others have announced plans to implement this. In this ``object/relational'' mapping, each row of the table becomes an instance of that class, and each column value corresponds to an attribute of that instance. Programmers can then operate directly on Java objects; the required SQL calls to fetch and store data are automatically generated ``beneath the covers''. More sophisticated mappings are also provided, for example, where rows of multiple tables are combined in a Java class.
As interest in JDBC has grown, more developers have been working on JDBC-based tools to make building programs easier, as well. Programmers have also been writing applications that make accessing a database easier for the end user. For example, an application might present a menu of database tasks from which to choose. After a task is selected, the application presents prompts and blanks for filling in information needed to carry out the selected task. With the requested input typed in, the application then automatically invokes the necessary SQL commands. With the help of such an application, users can perform database tasks even when they have little or no knowledge of SQL syntax.

Associate Instructor - Hofstra University
Amazon Top 750 reviewer - Blog - Unresolved References - Book Review Blog
I agree. Here's the link:
subject: Call-level API
It's not a secret anymore!