T.DEEPIKA(INFO-TECH)
NADAR SARASWATHI COLLEGE OF ARTS AND
SCIENCE
JDBC - Java Database Connectivity
The objectives of this chapter are:
To describe the architecture of JDBC
To outline the classes in the java.sql package
To understand the use of JDBC
What is JDBC?
JDBC provides Java applications with access to most
database systems via SQL
The architecture and API closely resemble Microsoft's
ODBC
JDBC 1.0 was originally introduced into Java 1.1
JDBC 2.0 was added to Java 1.2
JDBC is based on SQL-92
JDBC classes are contained within the java.sql package
There are few classes
There are several interfaces
Database Connectivity History
Before APIs like JDBC and ODBC, database
connectivity was tedious
Each database vendor provided a function library for accessing
their database
The connectivity library was proprietary.
If the database vendor changed for the application, the data access
portions had to be rewritten
If the application was poorly structured, rewriting its data access
might involve rewriting the majority of the application
The costs incurred generally meant that application developers
were stuck with a particular database product for a given
application
JDBC Architecture
With JDBC, the application programmer uses the JDBC API
The developer never uses any proprietary APIs
• Any proprietary APIs are implemented by a JDBC driver
• There are 4 types of JDBC Drivers
JDBC Drivers
There are 4 types of JDBC Drivers
Type 1 - JDBC-ODBC Bridge
Type 2 - JDBC-Native Bridge
Type 3 - JDBC-Net Bridge
Type 4 - Direct JDBC Driver
Type 1 only runs on platforms where ODBC is available
ODBC must be configured separately
Type 2 Drivers map between a proprietary Database API and
the JDBC API
Type 3 Drivers are used with middleware products
Type 4 Drivers are written in Java
In most cases, type 4 drivers are preferred
JDBC Classes
DriverManager
Manages JDBC Drivers
Used to Obtain a connection to a Database
• Types
Defines constants which identify SQL types
Date
Used to Map between java.util.Date and the SQL DATE type
• Time
Used to Map between java.util.Date and the SQL TIME type
TimeStamp
Used to Map between java.util.Date and the SQL TIMESTAMP type
JDBC Interfaces
Driver
All JDBC Drivers must implement the Driver interface. Used to
obtain a connection to a specific database type
• Connection
Represents a connection to a specific database
Used for creating statements
Used for managing database transactions
Used for accessing stored procedures
Used for creating callable statements
Statement
Used for executing SQL statements against the database
JDBC Interfaces
ResultSet
Represents the result of an SQL statement
Provides methods for navigating through the resulting data
• PreparedStatement
Similar to a stored procedure
An SQL statement (which can contain parameters) is compiled and stored in
the database
CallableStatement
Used for executing stored procedures
DatabaseMetaData
Provides access to a database's system catalogue
ResultSetMetaData
Provides information about the data contained within a ResultSet
Using JDBC
To execute a statement against a database, the following
flow is observed
Load the driver (Only performed once)
Obtain a Connection to the database (Save for later use)
Obtain a Statement object from the Connection
Use the Statement object to execute SQL. Updates, inserts and
deletes return Boolean. Selects return a ResultSet
Navigate ResultSet, using data as required
Close ResultSet
Close Statement
• Do NOT close the connection
The same connection object can be used to create further statements
A Connection may only have one active Statement at a time. Do not
forget to close the statement when it is no longer needed.
Close the connection when you no longer need to access the database
Loading Drivers
Even a good API can have problems
Loading drivers fits into this category
The DriverManager is a singleton
Each JDBC Driver is also a singleton
When a JDBC Driver class is loaded, it must create an instance of
itself and register that instance with the JDBC DriverManager
How does one load a "class" into the Virtual machine?
Use the static method Class.forName()
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
Connecting to a Database
Once a Driver is loaded, a connection can be made to the database
The connection is defined by URL
The URL has the following form:
jdbc:driver:databasename
• Examples:
jdbc:odbc:MyOdbcDatabase
jdbc:postgres:WebsiteDatabase
jdbc:oracle:CustomerInfo
A connection is obtained in the following manner:
Connection aConnection = DriverManager.getConnection("jdbc:odbc:myDatabase");
• Overloaded versions of the getConnection method allow the
specification of a username and password for authentication with the
database.
Using a Connection
The Connection interface defines many methods for
managing and using a connection to the database
public Statement createStatement()
public PreparedStatement prepareStatement(String sql)
public void setAutoCommit(boolean)
public void commit()
public void rollback()
public void close()
• The most commonly used method is createStatement()
When an SQL statement is to be issued against the database, a
Statement object must be created through the Connection
Using a Statement
The Statement interface defines two methods for
executing SQL against the database
public ResultSet executeQuery(String sql)
public int executeUpdate(String sql)
• executeQuery returns a ResultSet
• All rows and columns which match the query are contained within the
ResultSet
• The developer navigates through the ResultSet and uses the data as
required.
• executeUpdate returns the number of rows changed by
the update statement
This is used for insert statements, update statements and delete
statements
Using a ResultSet
The ResultSet interface defines many navigation methods
public boolean first()
public boolean last()
public boolean next()
public boolean previous()
The ResultSet interface also defines data access methods
public int getInt(int columnNumber) -- Note: Columns are numbered
public int getInt(String columnName) -- from 1 (not 0)
public long getLong(int columnNumber)
public long getLong(String columnName)
public String getString(int columnNumber)
public String getString(String columnName)
There are MANY more methods. Check the API
documentation for a complete list
SQL Types/Java Types Mapping
SQL Type Java Type
CHAR String
VARCHAR String
LONGVARCHAR String
NUMERIC java.Math.BigDecimal
DECIMAL java.Math.BigDecimal
BIT boolean
TINYINT int
SMALLINT int
INTEGER int
BIGINT long
REAL float
FLOAT double
DOUBLE double
BINARY byte[]
VARBINARY byte[]
DATE java.sql.Date
TIME java.sql.Time
TIMESTAMP java.sql.Timestamp
Example Code:
Connection aConnection;
try
{
Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
}
catch(ClassNotFoundException x)
{
System.out.println("Cannot find driver class. Check CLASSPATH");
return;
}
try
{
aConnection = DriverManager.getConnection("jdbc:odbc:MyDatabase",
"Username", "Password");
}
catch(SQLException x)
{
System.out.println("Exception connecting to database:" + x);
return;
}
Example Code (continued):
try
{
Statement aStmt = aConnection.createStatement();
StringBuffer sb = new StringBuffer("SELECT Employee_id, Employee_Name");
sb.append(" FROM Employee WHERE EmployeeId>100");
ResultSet rs = aStmt.executeQuery(sb.toString());
while(rs.next())
{
int employeeId = rs.getInt(1);
String employeeName = rs.getString(2);
System.out.println("Id:" + employeeId + "nName:" + employeeName);
}
rs.close();
aStmt.close();
}
catch(SQLException x)
{
System.out.println("Exception while executing query:" + x);
}
THANKYOU

More Related Content

PPTX
Java Database Connectivity (JDBC)
PPT
Jdbc complete
PDF
Overview Of JDBC
PPT
Jdbc (database in java)
PPTX
PPTX
Database Access With JDBC
Java Database Connectivity (JDBC)
Jdbc complete
Overview Of JDBC
Jdbc (database in java)
Database Access With JDBC

What's hot (20)

PPT
Basic Java Database Connectivity(JDBC)
PPT
Jdbc slide for beginers
PPT
Jdbc ppt
PPT
Java Database Connectivity
PPT
java jdbc connection
PPTX
JDBC ppt
PPTX
Java- JDBC- Mazenet Solution
PPT
JDBC,Types of JDBC,Resultset, statements,PreparedStatement,CallableStatements...
DOC
jdbc document
PPS
Jdbc architecture and driver types ppt
PPTX
Jdbc_ravi_2016
PPTX
1. java database connectivity (jdbc)
PPT
PDF
Database and Java Database Connectivity
PPTX
Jdbc in servlets
PPT
Java database connectivity
PDF
Jdbc connectivity in java
PPTX
java Jdbc
Basic Java Database Connectivity(JDBC)
Jdbc slide for beginers
Jdbc ppt
Java Database Connectivity
java jdbc connection
JDBC ppt
Java- JDBC- Mazenet Solution
JDBC,Types of JDBC,Resultset, statements,PreparedStatement,CallableStatements...
jdbc document
Jdbc architecture and driver types ppt
Jdbc_ravi_2016
1. java database connectivity (jdbc)
Database and Java Database Connectivity
Jdbc in servlets
Java database connectivity
Jdbc connectivity in java
java Jdbc
Ad

Similar to Jdbc (20)

PPT
Jdbc connectivity
PPTX
Core jdbc basics
PDF
PDF
Unit 5.pdf
PDF
JDBC Presentation with JAVA code Examples.pdf
PPT
JDBC.ppt
PPT
jdbc_presentation.ppt
PDF
Chapter 5 JDBC.pdf for stufent of computer andtudent It s
PPT
Java database connectivity
PPTX
Java Data Base Connectivity concepts.pptx
PPTX
Jdbc presentation
PPT
Chap3 3 12
PPTX
Jdbc introduction
PDF
Jdbc 1
PPTX
Java database connectivity
PPT
Jdbc ppt
PPT
JDBC java for learning java for learn.ppt
PPT
PPTX
JAVA DATABASE CONNECTIVITY(JDBC CONNECTIVITY).pptx
Jdbc connectivity
Core jdbc basics
Unit 5.pdf
JDBC Presentation with JAVA code Examples.pdf
JDBC.ppt
jdbc_presentation.ppt
Chapter 5 JDBC.pdf for stufent of computer andtudent It s
Java database connectivity
Java Data Base Connectivity concepts.pptx
Jdbc presentation
Chap3 3 12
Jdbc introduction
Jdbc 1
Java database connectivity
Jdbc ppt
JDBC java for learning java for learn.ppt
JAVA DATABASE CONNECTIVITY(JDBC CONNECTIVITY).pptx
Ad

More from DeepikaT13 (20)

PPTX
Mobile computing
PPTX
Image processing
PPT
aloha
PPT
Spatial filtering
PPT
Exceptions
PPTX
Hive architecture
PPTX
Rdbms
PPTX
Sotware engineering
PPTX
Data mining
PPT
Computer network
PPTX
Storage management in operating system
PPTX
Data mining
PPTX
Neural network
PPTX
memory reference instruction
PPTX
breadth first search
PPTX
constructors
PPTX
Disjoint set
PPTX
Destructors
PPTX
Crisp set
PPTX
Computer registers
Mobile computing
Image processing
aloha
Spatial filtering
Exceptions
Hive architecture
Rdbms
Sotware engineering
Data mining
Computer network
Storage management in operating system
Data mining
Neural network
memory reference instruction
breadth first search
constructors
Disjoint set
Destructors
Crisp set
Computer registers

Recently uploaded (20)

PDF
Hospital Case Study .architecture design
PDF
M.Tech in Aerospace Engineering | BIT Mesra
PPT
REGULATION OF RESPIRATION lecture note 200L [Autosaved]-1-1.ppt
PDF
The TKT Course. Modules 1, 2, 3.for self study
PDF
PUBH1000 - Module 6: Global Health Tute Slides
PDF
African Communication Research: A review
PPTX
Reproductive system-Human anatomy and physiology
PDF
Laparoscopic Colorectal Surgery at WLH Hospital
PPTX
CAPACITY BUILDING PROGRAMME IN ADOLESCENT EDUCATION
PDF
Nurlina - Urban Planner Portfolio (english ver)
PPTX
Thinking Routines and Learning Engagements.pptx
PDF
Compact First Student's Book Cambridge Official
PDF
MICROENCAPSULATION_NDDS_BPHARMACY__SEM VII_PCI Syllabus.pdf
PPTX
Macbeth play - analysis .pptx english lit
PDF
Environmental Education MCQ BD2EE - Share Source.pdf
PDF
Myanmar Dental Journal, The Journal of the Myanmar Dental Association (2015).pdf
PDF
Fun with Grammar (Communicative Activities for the Azar Grammar Series)
PDF
Farming Based Livelihood Systems English Notes
PDF
Controlled Drug Delivery System-NDDS UNIT-1 B.Pharm 7th sem
PPTX
Climate Change and Its Global Impact.pptx
Hospital Case Study .architecture design
M.Tech in Aerospace Engineering | BIT Mesra
REGULATION OF RESPIRATION lecture note 200L [Autosaved]-1-1.ppt
The TKT Course. Modules 1, 2, 3.for self study
PUBH1000 - Module 6: Global Health Tute Slides
African Communication Research: A review
Reproductive system-Human anatomy and physiology
Laparoscopic Colorectal Surgery at WLH Hospital
CAPACITY BUILDING PROGRAMME IN ADOLESCENT EDUCATION
Nurlina - Urban Planner Portfolio (english ver)
Thinking Routines and Learning Engagements.pptx
Compact First Student's Book Cambridge Official
MICROENCAPSULATION_NDDS_BPHARMACY__SEM VII_PCI Syllabus.pdf
Macbeth play - analysis .pptx english lit
Environmental Education MCQ BD2EE - Share Source.pdf
Myanmar Dental Journal, The Journal of the Myanmar Dental Association (2015).pdf
Fun with Grammar (Communicative Activities for the Azar Grammar Series)
Farming Based Livelihood Systems English Notes
Controlled Drug Delivery System-NDDS UNIT-1 B.Pharm 7th sem
Climate Change and Its Global Impact.pptx

Jdbc

  • 2. JDBC - Java Database Connectivity The objectives of this chapter are: To describe the architecture of JDBC To outline the classes in the java.sql package To understand the use of JDBC
  • 3. What is JDBC? JDBC provides Java applications with access to most database systems via SQL The architecture and API closely resemble Microsoft's ODBC JDBC 1.0 was originally introduced into Java 1.1 JDBC 2.0 was added to Java 1.2 JDBC is based on SQL-92 JDBC classes are contained within the java.sql package There are few classes There are several interfaces
  • 4. Database Connectivity History Before APIs like JDBC and ODBC, database connectivity was tedious Each database vendor provided a function library for accessing their database The connectivity library was proprietary. If the database vendor changed for the application, the data access portions had to be rewritten If the application was poorly structured, rewriting its data access might involve rewriting the majority of the application The costs incurred generally meant that application developers were stuck with a particular database product for a given application
  • 5. JDBC Architecture With JDBC, the application programmer uses the JDBC API The developer never uses any proprietary APIs • Any proprietary APIs are implemented by a JDBC driver • There are 4 types of JDBC Drivers
  • 6. JDBC Drivers There are 4 types of JDBC Drivers Type 1 - JDBC-ODBC Bridge Type 2 - JDBC-Native Bridge Type 3 - JDBC-Net Bridge Type 4 - Direct JDBC Driver Type 1 only runs on platforms where ODBC is available ODBC must be configured separately Type 2 Drivers map between a proprietary Database API and the JDBC API Type 3 Drivers are used with middleware products Type 4 Drivers are written in Java In most cases, type 4 drivers are preferred
  • 7. JDBC Classes DriverManager Manages JDBC Drivers Used to Obtain a connection to a Database • Types Defines constants which identify SQL types Date Used to Map between java.util.Date and the SQL DATE type • Time Used to Map between java.util.Date and the SQL TIME type TimeStamp Used to Map between java.util.Date and the SQL TIMESTAMP type
  • 8. JDBC Interfaces Driver All JDBC Drivers must implement the Driver interface. Used to obtain a connection to a specific database type • Connection Represents a connection to a specific database Used for creating statements Used for managing database transactions Used for accessing stored procedures Used for creating callable statements Statement Used for executing SQL statements against the database
  • 9. JDBC Interfaces ResultSet Represents the result of an SQL statement Provides methods for navigating through the resulting data • PreparedStatement Similar to a stored procedure An SQL statement (which can contain parameters) is compiled and stored in the database CallableStatement Used for executing stored procedures DatabaseMetaData Provides access to a database's system catalogue ResultSetMetaData Provides information about the data contained within a ResultSet
  • 10. Using JDBC To execute a statement against a database, the following flow is observed Load the driver (Only performed once) Obtain a Connection to the database (Save for later use) Obtain a Statement object from the Connection Use the Statement object to execute SQL. Updates, inserts and deletes return Boolean. Selects return a ResultSet Navigate ResultSet, using data as required Close ResultSet Close Statement • Do NOT close the connection The same connection object can be used to create further statements A Connection may only have one active Statement at a time. Do not forget to close the statement when it is no longer needed. Close the connection when you no longer need to access the database
  • 11. Loading Drivers Even a good API can have problems Loading drivers fits into this category The DriverManager is a singleton Each JDBC Driver is also a singleton When a JDBC Driver class is loaded, it must create an instance of itself and register that instance with the JDBC DriverManager How does one load a "class" into the Virtual machine? Use the static method Class.forName() Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
  • 12. Connecting to a Database Once a Driver is loaded, a connection can be made to the database The connection is defined by URL The URL has the following form: jdbc:driver:databasename • Examples: jdbc:odbc:MyOdbcDatabase jdbc:postgres:WebsiteDatabase jdbc:oracle:CustomerInfo A connection is obtained in the following manner: Connection aConnection = DriverManager.getConnection("jdbc:odbc:myDatabase"); • Overloaded versions of the getConnection method allow the specification of a username and password for authentication with the database.
  • 13. Using a Connection The Connection interface defines many methods for managing and using a connection to the database public Statement createStatement() public PreparedStatement prepareStatement(String sql) public void setAutoCommit(boolean) public void commit() public void rollback() public void close() • The most commonly used method is createStatement() When an SQL statement is to be issued against the database, a Statement object must be created through the Connection
  • 14. Using a Statement The Statement interface defines two methods for executing SQL against the database public ResultSet executeQuery(String sql) public int executeUpdate(String sql) • executeQuery returns a ResultSet • All rows and columns which match the query are contained within the ResultSet • The developer navigates through the ResultSet and uses the data as required. • executeUpdate returns the number of rows changed by the update statement This is used for insert statements, update statements and delete statements
  • 15. Using a ResultSet The ResultSet interface defines many navigation methods public boolean first() public boolean last() public boolean next() public boolean previous() The ResultSet interface also defines data access methods public int getInt(int columnNumber) -- Note: Columns are numbered public int getInt(String columnName) -- from 1 (not 0) public long getLong(int columnNumber) public long getLong(String columnName) public String getString(int columnNumber) public String getString(String columnName) There are MANY more methods. Check the API documentation for a complete list
  • 16. SQL Types/Java Types Mapping SQL Type Java Type CHAR String VARCHAR String LONGVARCHAR String NUMERIC java.Math.BigDecimal DECIMAL java.Math.BigDecimal BIT boolean TINYINT int SMALLINT int INTEGER int BIGINT long REAL float FLOAT double DOUBLE double BINARY byte[] VARBINARY byte[] DATE java.sql.Date TIME java.sql.Time TIMESTAMP java.sql.Timestamp
  • 17. Example Code: Connection aConnection; try { Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); } catch(ClassNotFoundException x) { System.out.println("Cannot find driver class. Check CLASSPATH"); return; } try { aConnection = DriverManager.getConnection("jdbc:odbc:MyDatabase", "Username", "Password"); } catch(SQLException x) { System.out.println("Exception connecting to database:" + x); return; }
  • 18. Example Code (continued): try { Statement aStmt = aConnection.createStatement(); StringBuffer sb = new StringBuffer("SELECT Employee_id, Employee_Name"); sb.append(" FROM Employee WHERE EmployeeId>100"); ResultSet rs = aStmt.executeQuery(sb.toString()); while(rs.next()) { int employeeId = rs.getInt(1); String employeeName = rs.getString(2); System.out.println("Id:" + employeeId + "nName:" + employeeName); } rs.close(); aStmt.close(); } catch(SQLException x) { System.out.println("Exception while executing query:" + x); }