jdbc
DESCRIPTION
JDBC. Java Database Connectivity. CC52N - Computación para el trabajo grupal Profesor: Nélson Baloian Por: Edgard Pineda. Introducción. JDBC es una API, formada por conjunto de clases e interfaces en el lenguaje de programación Java, para ejecutar sentencias SQL. - PowerPoint PPT PresentationTRANSCRIPT
JDBCJava Database Connectivity
CC52N - Computación para el trabajo grupal
Profesor: Nélson Baloian
Por: Edgard Pineda
Introducción JDBC es una API, formada por
conjunto de clases e interfaces en el lenguaje de programación Java, para ejecutar sentencias SQL.
Ofrece un estándar de conexión a cualquier base de datos disponible en el mercado.
Permite obtener los datos en forma fácil y cómoda en ambientes cliente-servidor a través de Internet/Intranet.
¿Qué hace JDBC? Establece una conexión a una
base de datos. Envía sentencias SQL. Procesa los resultados de estas
sentencias.
Arquitectura JDBC Arquitectura normal Puente JDBC-ODBC
Aplicaciones Java
JDBC API
Adm. de controladores JDBC
Controlador
JDBC
DB
Controlador
JDBC
DB
Aplicaciones Java
JDBC API
Adm. de controladores JDBC
C. ODBC
DB
C. ODBC
DB
Adm. de controladoresODBC
Puente JDBC/ODBC
Primer ejemplo básico Connection con = DriverManager.getConnection (
"jdbc:odbc:nombre", "login", "password");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table1");
while (rs.next()) {
int x = rs.getInt("a");
String s = rs.getString("b");
float f = rs.getFloat("c");
} JDBC usa una URL para
especificar la base de datos.
...Primer ejemplo básico Ejemplos de URL:
jdbc:mysql://myserver:4444/db1 jdbc:oracle://oraserver jdbc:odbc:mydatabase
JDBC vs. ODBC Se puede usar ODBC desde Java,
pero el puente JDBC-ODBC ayuda bastante.
ODBC tiene una interfaz tipo C rompiendo el esquema de seguridad, robustez e implementación de Java.
ODBC mezcla funciones simple y complejas.
Los controladores de ODBC deben ser instalados en cada cliente.
...JDBC vs. ODBC JDBC es una interfaz natural en
Java.
Modelos de acceso a BD De 2 capas
La aplicación “habla” directamente con la base de datos.
Controlador JDBC se comunica con el sistema específico que maneja la base de datos.
La base de datos puede estar en otra máquina, con lo que el cliente se comunica por red. Esta es la configuración llamada cliente/servidor.
Aplicación
Java
JDBC
DBMS
Cliente
Servidor
BD
Protocolo
BD
Modelos de acceso a BD De 3 capas
Los comandos son enviados a la capa intermedia de servicios, la cual envía sentencias SQL a la base de datos. Ésta las procesa y envía los resultados de vuelta a la capa intermedia, para luego ser enviados al cliente.
Permite un control de acceso y de actualización.
Provee ventajas de performance.
Aplicación
Java
JDBC
DBMS
Applet en Java o
Navegador HTML
Cliente (GUI)
Llamadas HTTP,
RMI,CORBA
Servidor
BD
Servidor
Protocolo
BD
Categorías de los controladores JDBC Puente JDBC-ODBC. Parte API Nativa-Parte Java. Se
convierte las llamadas JDBC al sistema de la Base de datos.
JDBC-Red. Es sólo Java. Las llamadas JDBC son convertidas a un protocolo de red independiente del sistema de la base de datos. Este protocolo es convertido en un servidor
Protocolo Nativo. Es sólo Java. Se usa un protocolo de red con la BD.
Conexión Un objeto “Connection” representa
una conexión a una base de datos. Una sesión incluye las sentencias
SQL que son ejecutadas y los resultados de éstas.
Establecer la conexión: “DriverManager.getConnection”
La clase “DriverManager” intenta ubicar el controlador que pueda conectarse a la base de datos representada en la URL.
...Conexión Sintáxis de una URL JDBC:
jdbc:<subprotocolo>:<subnombre> <subprotocolo> es el nombre del
controlador o del mecanismo de conexión. Ejemplo: odbc.
<subnombre> es la identificación de la base de datos. El formato varia según el controlador especificado. Ejemplo: //servidor:puerto/etc
Enviando sentencias SQL JDBC permite que se escriba
cualquier tipo de sentencia SQL. Aunque ésta fuera dependiente de la base de datos sólo se correría el riesgo de incompatibilidad al cambiar de base de datos. Llamadas a procedimientos
almacenados Formatos de fecha
...Enviando sentencias SQL JDBC provee 3 clases:
“Statement”: Este objeto es usado para enviar sentecias SQL simples. Es creado por el método “createStatement”.
“PreparedStatement”: Este objeto es usado para sentencias que requieren uno o más parámetros. La sentencia es precompilada y guardada para uso futuro.
“CallableStatement”: Es usado para ejecutar procedimientos almacenados.
Transacciones Una transacción consiste en una o
más sentencias que han sido ejecutadas y luego confirmadas (commit) o deshechas (rolled back)
Auto-commit está predeterminado. Si Auto-commit está desactivado
se debe usar los métodos “commit” o “rollback” explícitamente.
Procesando respuestas Las respuestas a las sentencias
SQL se reciben en el objeto “ResultSet” que mantiene las filas.
Este objeto provee el acceso a los datos de esas filas a través de un conjunto de métodos “get”, los cuales, a su vez, permiten el acceso a cada columna de estas filas.
Cargando la clase del controlador JDBC Ejemplo:Class.forName(”empresa.db.Driver");
Esto crea una instancia del controlador y llama al método “DriverManager.registerDriver” registrando este controlador en la lista de controladores disponibles para conexiones.
Ejemplo de sentencia Connection con = DriverManager.getConnection (
"jdbc:odbc:nombre", "login", "password");
PreparedStatement pstmt = con.prepareStatement( “UPDATE tabla1 SET m=? WHERE x=?”);
pstmt.setString(1, "Hola");
for (int i = 0; i < 10; i++) {
pstmt.setInt(2, i);
int rowCount = pstmt.executeUpdate();
}
Primer ejemplo básico Connection con = DriverManager.getConnection (
"jdbc:odbc:nombre", "login", "password");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table1");
while (rs.next()) {
int x = rs.getInt("a");
String s = rs.getString("b");
float f = rs.getFloat("c");
}