 1992-2007 Pearson Education, Inc. All rights reserved. 1 25 Accessing Databases with JDBC.

Slides:



Advertisements
Similar presentations
CE203 - Application Programming Autumn 2013CE203 Part 51 Part 5.
Advertisements

 2003 Prentice Hall, Inc. All rights reserved. Chapter 22 – Database: SQL, MySQL, DBI and ADO.NET Outline 22.1 Introduction 22.2 Relational Database Model.
Lecture 9 Chapter 23: Java Database Connectivity with JDBC Outline 23.1 Introduction 23.2 Relational-Database Model 23.3 Relational Database Overview:
Introduction to Structured Query Language (SQL)
 Pearson Education, Inc. All rights reserved Accessing Databases with JDBC.
1 Introduction to Web Application Introduction to Data Base.
 2003 Prentice Hall, Inc. All rights reserved. Chapter 23: Java Database Connectivity with JDBC Outline 23.1 Introduction 23.2 Relational-Database Model.
CSCI 3328 Object Oriented Programming in C# Chapter 12: Databases and LINQ 1 Xiang Lian The University of Texas – Pan American Edinburg, TX 78539
Advance Computer Programming Java Database Connectivity (JDBC) – In order to connect a Java application to a database, you need to use a JDBC driver. –
CSCI 6962: Server-side Design and Programming
Java Database Connectivity (JDBC). Introduction Database –Collection of data DBMS –Database management system –Storing and organizing data SQL –Relational.
Session 5: Working with MySQL iNET Academy Open Source Web Development.
 Pearson Education, Inc. All rights reserved Accessing Databases with JDBC.
 Pearson Education, Inc. All rights reserved Accessing Databases with JDBC.
Databases and LINQ Visual Basic 2010 How to Program 1.
ASP.NET Programming with C# and SQL Server First Edition
CSE470 Software Engineering Fall Database Access through Java.
Intro to JDBC To effectively use Java Data Base Connectivity we must understand: 1.Relational Database Management Systems (RDBMS) 2.JDBC Drivers 3.SQL.
Java Database Connectivity (JDBC) Introduction to JDBC JDBC is a simple API for connecting from Java applications to multiple databases. Lets you smoothly.
Database Programming in Java Corresponds with Chapter 32, 33.
 2008 Pearson Education, Inc. All rights reserved Database: SQL, MySQL, ADO.NET 2.0 and Java DB.
CHAPTER 7 Database: SQL, MySQL. Topics  Introduction  Relational Database Model  Relational Database Overview: Books.mdb Database  SQL (Structured.
PHP Programming with MySQL Slide 8-1 CHAPTER 8 Working with Databases and MySQL.
A CCESSING D ATABASES WITH JDBC CH 24 C S 442: A DVANCED J AVA P ROGRAMMING.
 2003 Prentice Hall, Inc. All rights reserved. 1 Java Database Connectivity with JDBC TM.
CIS 270—Application Development II Chapter 25—Accessing Databases with JDBC.
Chapter 7 Working with Databases and MySQL PHP Programming with MySQL 2 nd Edition.
Chapter 7 Working with Databases and MySQL PHP Programming with MySQL 2 nd Edition.
Liang, Introduction to Java Programming, Seventh Edition, (c) 2009 Pearson Education, Inc. All rights reserved Chapter 38 Advanced Java Database.
CHAPTER 8 Database: SQL, MySQL. Topics  Introduction  Relational Database Model  Relational Database Overview: Books.mdb Database  SQL (Structured.
CSC 411/511: DBMS Design Dr. Nan WangCSC411_L12_JDBC_MySQL 1 MySQL and JDBC.
Database: SQL and MySQL
1 Databases November 15, 2005 Slides modified from Internet & World Wide Web: How to Program (3rd) edition. By Deitel, Deitel, and Goldberg. Published.
 2004 Prentice Hall, Inc. All rights reserved. 1 Segment – 6 Web Server & database.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 23: Java Database Connectivity with JDBC Outline 23.1 Introduction 23.2 Relational-Database Model.
Java How to Program, 9/e © Copyright by Pearson Education, Inc. All Rights Reserved.
JDBC. Preliminaries Database Database Collection of data Collection of data DBMS DBMS Database management system Database management system Stores and.
Accessing Database using JDBC. JDBC Objectives Gain basic knowledge of Java JDBC Become familiar with the basics of interacting with a database using.
Chapter 25 Databases. Chapter Scope Database concepts Tables and queries SQL statements Managing data in a database Java Foundations, 3rd Edition, Lewis/DePasquale/Chase25.
Visual C# 2012 How to Program © by Pearson Education, Inc. All Rights Reserved.
Java How to Program, 9/e © Copyright by Pearson Education, Inc. All Rights Reserved.
Database Systems Design, Implementation, and Management Coronel | Morris 11e ©2015 Cengage Learning. All Rights Reserved. May not be scanned, copied or.
Copyright © 2002 ProsoftTraining. All rights reserved. Building Database Client Applications Using JDBC 2.0.
JDBC. Java.sql.package The java.sql package contains various interfaces and classes used by the JDBC API. This collection of interfaces and classes enable.
Internet & World Wide Web How to Program, 5/e. © by Pearson Education, Inc. All Rights Reserved. 2 Revised by Dr. T. Tran for CSI3140.
© Copyright by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. 1 Outline 25.1 Test-Driving the ATM Application 25.2.
 2005 Pearson Education, Inc. All rights reserved Accessing Databases with JDBC.
A CCESSING D ATABASES WITH JDBC CH 24 C S 442: A DVANCED J AVA P ROGRAMMING.
DataBases and SQL INFSY 547 Spring Course Wrap Up April 12: Complete Work on Servlets Review of Team Projects Close of Portfolio Work April 19:
 2008 Pearson Education, Inc. All rights reserved Database: SQL, MySQL, ADO.NET 2.0 and Java DB.
 2001 Prentice Hall, Inc. All rights reserved. 1 Chapter 22 - SQL, MySQL, DBI and ADO Outline 22.1 Introduction 22.2 Relational Database Model 22.3 Relational.
 2009 Pearson Education, Inc. All rights reserved Databases and LINQ to SQL.
Database: SQL, MySQL, LINQ and Java DB © by Pearson Education, Inc. All Rights Reserved.
LINQ to DATABASE-2.  Creating the BooksDataContext  The code combines data from the three tables in the Books database and displays the relationships.
CSCI 3327 Visual Basic Chapter 13: Databases and LINQ UTPA – Fall 2011.
COM621: Advanced Interactive Web Development Lecture 11 MySQL – Data Manipulation Language.
ORDER BY Clause The result of a query can be sorted in ascending or descending order using the optional ORDER BY clause. The simplest form of.
Database, SQL and ADO.NET
Visual Basic 2010 How to Program
Chapter 5 Introduction to SQL.
 2012 Pearson Education, Inc. All rights reserved.
Accessing Databases with JDBC
JDBC.
Databases Intro (from Deitel)
Chapter 7 Working with Databases and MySQL
Chapter 8 Working with Databases and MySQL
Chapter 22 - SQL, MySQL, DBI and ADO
MSIS 655 Advanced Business Applications Programming
Java Chapter 6 (Estifanos Tilahun Mihret--Tech with Estif)
Presentation transcript:

 Pearson Education, Inc. All rights reserved Accessing Databases with JDBC

 Pearson Education, Inc. All rights reserved. 2 OBJECTIVES In this chapter you will learn:  Relational database concepts.  To use Structured Query Language (SQL) to retrieve data from and manipulate data in a database.  To use the JDBC™ API of package java.sql to access databases.  To use the RowSet interface from package javax.sql to manipulate databases.  To use JDBC 4.0’s automatic JDBC driver discovery.

 Pearson Education, Inc. All rights reserved Introduction 25.2Relational Databases 25.3Relational Database Overview: The books Database 25.4SQL Basic SELECT Query WHERE Claus ORDER BY Claus Merging Data from Multiple Tables: INNER JOIN INSERT Statement UPDATE Statement DELETE Statement 25.5Instructions for installing MySQL and MySQL Connector/J

 Pearson Education, Inc. All rights reserved Instructions for Setting Up a MySQL User Account 25.7 Creating Database book in MySQL 25.8 Manipulating Databases with JDBC Connecting to and Querying a Database Querying the books Database 25.9 RowSet Interface

 Pearson Education, Inc. All rights reserved Introduction  Database – Collection of data  DBMS – Database management system – Storing and organizing data  SQL – Relational database – Structured Query Language

 Pearson Education, Inc. All rights reserved Introduction (Cont.)  RDBMS – Relational database management system – MySQL - Open source - Available for both Windows and Linux - dev.mysql.com/downloads/mysql/4.0.hml  JDBC – Java Database Connectivity – JDBC driver - Enable Java applications to connect to database - Enable programmers to manipulate databases using JDBC

 2005 Pearson Education, Inc. All rights reserved Relational Databases Relational database – Table Rows, columns – Primary key Unique data SQL queries – Specify which data to select from a table

 Pearson Education, Inc. All rights reserved. 8 Fig | Employee table sample data.

 Pearson Education, Inc. All rights reserved. 9 Fig | Result of selecting distinct Department and Location data from table Employee.

 2005 Pearson Education, Inc. All rights reserved Relational Database Overview: The books Database Sample books database – Four tables authors – authorID, firstName, lastName titles – isbn, title, editionNumber, copyright, publisherID, imageFile, price authorISBN – authorID, isbn

 Pearson Education, Inc. All rights reserved. 11 Fig | authors table from the books database.

 Pearson Education, Inc. All rights reserved. 12 Fig | Sample data from the authors table.

 2005 Pearson Education, Inc. All rights reserved Relational Database Overview: The books Database (Cont.) Foreign key – A column matches the primary key column in another table – Helps maintain the Rule of Referential Integrity Every foreign key value must appear as another table ’ s primary key value

 Pearson Education, Inc. All rights reserved. 14 Fig | authorISBN table from the books database.

 Pearson Education, Inc. All rights reserved. 15 Fig | Sample data from the authorISBN table of books.

 Pearson Education, Inc. All rights reserved. 16 Fig | titles table from the books database.

 Pearson Education, Inc. All rights reserved. 17 Fig | Sample data from the titles table of the books database.

 2005 Pearson Education, Inc. All rights reserved Relational Database Overview: The books Database (Cont.) Entity-relationship (ER) diagram – Tables in the database – Relationships among tables Rule of Entity Integrity – Primary key uniquely identifies each row – Every row must have a value for every column of the primary key – Value of the primary key must be unique in the table

 Pearson Education, Inc. All rights reserved. 19 Fig | Table relationships in the books database.

 2005 Pearson Education, Inc. All rights reserved SQL SQL keywords – SQL queries and statements

 Pearson Education, Inc. All rights reserved. 21 Fig | SQL query keywords.

 2005 Pearson Education, Inc. All rights reserved Basic SELECT Query Simplest format of a SELECT query – SELECT * FROM tableName SELECT * FROM authors Select specific fields from a table – SELECT authorID, lastName FROM authors

 Pearson Education, Inc. All rights reserved. 23 Fig | Sample authorID and lastName data from the authors table.

 2005 Pearson Education, Inc. All rights reserved WHERE Clause specify the selection criteria – SELECT columnName1, columnName2, … FROM tableName WHERE criteria SELECT title, editionNumber, copyright FROM titles WHERE copyright > 2002

 Pearson Education, Inc. All rights reserved. 25 Fig | Sampling of titles with copyrights after 2005 from table titles.

 2005 Pearson Education, Inc. All rights reserved WHERE Clause (Cont.) WHERE clause condition operators –, =, =, <> – LIKE wildcard characters % and _ SELECT authorID, firstName, lastName FROM authors WHERE lastName LIKE ‘ D% ’

 Pearson Education, Inc. All rights reserved. 27 Fig | Authors whose last name starts with D from the authors table.

 2005 Pearson Education, Inc. All rights reserved WHERE Clause (Cont.) SELECT authorID, firstName, lastName FROM authors WHERE lastName LIKE ‘ _i% ’

 Pearson Education, Inc. All rights reserved. 29 Fig | The only author from the authors table whose last name contains o as the second letter.

 2005 Pearson Education, Inc. All rights reserved ORDER BY Clause Optional ORDER BY clause – SELECT columnName1, columnName2, … FROM tableName ORDER BY column ASC SELECT authorID, firstName, lastName FROM authors ORDER BY lastName ASC – SELECT columnName1, columnName2, … FROM tableName ORDER BY column DESC SELECT authorID, firstName, lastName FROM authors ORDER BY lastName DESC

 Pearson Education, Inc. All rights reserved. 31 Fig | Sample data from table authors in ascending order by lastName.

 Pearson Education, Inc. All rights reserved. 32 Fig | Sample data from table authors in descending order by lastName.

 2005 Pearson Education, Inc. All rights reserved ORDER BY Clause (Cont.) ORDER BY multiple fields – ORDER BY column1 sortingOrder, column2 sortingOrder, … SELECT authorID, firstName, lastName FROM authors ORDER BY lastName, firstName

 Pearson Education, Inc. All rights reserved. 34 Fig | Sample data from authors in ascending order by lastName and firstName.

 2005 Pearson Education, Inc. All rights reserved ORDER BY Clause (Cont.) Combine the WHERE and ORDER BY clauses SELECT isbn, title, editionNumber, copyright, price FROM titles WHERE title LIKE ‘ %How to Program ’ ORDER BY title ASC

 Pearson Education, Inc. All rights reserved. 36 Fig | Sampling of books from table titles whose titles end with How to Program in ascending order by title.

 2005 Pearson Education, Inc. All rights reserved Merging Data from Multiple Tables: INNER JOIN Split related data into separate tables Join the tables – Merge data from multiple tables into a single view – INNER JOIN SELECT columnName1, columnName2, … FROM table1 INNER JOIN table2 ON table1.columnName = table2.column2Name SELECT firstName, lastName, isbn FROM authors, authorISBN INNER JOIN authorISBN ON authors.authorID = authorISBN.authorID ORDER BY lastName, firstName

 Pearson Education, Inc. All rights reserved. 38 Fig | Sampling of authors and ISBNs for the books they have written in ascending order by lastName and firstName.

 2005 Pearson Education, Inc. All rights reserved INSERT Statement Insert a row into a table – INSERT INTO tableName ( columnName1, …, columnNameN ) VALUES ( value1, …, valueN ) INSERT INTO authors ( firstName, lastName ) VALUES ( ‘ Sue ’, ‘ Smith ’ )

 Pearson Education, Inc. All rights reserved. 40 Fig | Sample data from table Authors after an INSERT operation.

 2005 Pearson Education, Inc. All rights reserved UPDATE Statement Modify data in a table – UPDATE tableName SET columnName1 = value1, …, columnNameN = valueN WHERE criteria UPDATE authors SET lastName = ‘ Jones ’ WHERE lastName = ‘ Smith ’ AND firstName = ‘ Sue ’

 Pearson Education, Inc. All rights reserved. 42 Fig | Sample data from table authors after an UPDATE operation.

 2005 Pearson Education, Inc. All rights reserved DELETE Statement Remove data from a table – DELETE FROM tableName WHERE criteria DELETE FROM authors WHERE lastName = ‘ Jones ’ AND firstName = ‘ Sue ’

 Pearson Education, Inc. All rights reserved. 44 Fig | Sample data from table authors after a DELETE operation.

 2005 Pearson Education, Inc. All rights reserved Instructions to Install MySQL and MySQL Connector/J Install MySQL – Platform-specific installation requirements: dev.mysql.com/doc/refman/5.0/en/general- installation-issues.html – Download your platform ’ s installer from: dev.mysql.com/downloads/mysql/5.0.html Need only the Windows Essentials package on Microsoft Windows – Double click mysql-essential win32.msi to start the installer. – Choose typical for the Setup Type and click Next >. Then click install.

 2005 Pearson Education, Inc. All rights reserved Instructions to Install MySQL and MySQL Connector/J MySQL Server Instance Configuration Wizard – Click Next > then select Standard Configuration and click Next > again. – Not necessary to install MySQL as a Windows service for our examples Uncheck Install as a Windows Service Check Include Bin Directory in Windows PATH – Click Next > then click Execute to perform the server configuration. – Click Finish to close the wizard.

 2005 Pearson Education, Inc. All rights reserved Instructions to Install MySQL and MySQL Connector/J Install MySQL Connector/J – Must install Connector/J JDBC driver from: dev.mysql.com/downloads/connector/j/ 5.0.html – Download mysql-connector-java zip – Extract mysql-connector-java zip to your hard disk into the folder mysql-connector-java – Documentation for MySQL Connector/J is in connector-j.pdf in the docs subdirectory of mysql-connector-java – Docs also online at dev.mysql.com/doc/connector/j/en/ connector-j.html

 2005 Pearson Education, Inc. All rights reserved Instructions on Setting MySQL User Account Set up a user account – Start database server mysqld-nt.exe on Windows – Start the MySQL monitor mysql –h localhost –u root – Select the built-in database mysql USE mysql; – Add the user account jhtp7 and specify privileges create user identified by 'jhtp7'; grant select, insert, update, delete, create, drop, references, execute on *.* to – Exit the MySQL Monitor exit;

 2005 Pearson Education, Inc. All rights reserved Creating Database books in MySQL Create books database – Open Command Prompt and change to the directory containing the SQL script books.sql – Start the MySQL monitor mysql –h localhost –u jhtp7 –p – Execute the script source books.sql; – Exit the MySQL Monitor exit;

 2005 Pearson Education, Inc. All rights reserved Manipulating Databases with JDBC Connect to a database Query the database Display the results of the query in JTable

 2005 Pearson Education, Inc. All rights reserved Connecting to and Querying a Database DisplayAuthors – Retrieves the entire authors table – Displays the data in the standard output stream – Example illustrates Connect to the database Query the database Process the result

 Pearson Education, Inc. All rights reserved. 52 Outline DisplayAuthors. java (1 of 3 ) Imports for the JDBC classes and interfaces from package java.sql Declare a String constant that specifies the JDBC driver’s class name Loads the class definition for the database driver. Declare a String constant that specifies the database URL

 Pearson Education, Inc. All rights reserved. 53 Outline DisplayAuthors. java (2 of 3 ) Invokes Connection method createStatement to obtain an object that implements interface Statement. Use the Statement object’s executeQuery method to execute a query that selects all the author information from table authors. Obtains the metadata for the ResultSet. Uses ResultSetMetaData method getColumnCount to retrieve the number of columns in the ResultSet. Obtain column name using method getColumnName Position the ResultSet cursor to the first row in the ResultSet with method next Extract the contents of one column in the current row Initialize a Connection reference called connection.

 Pearson Education, Inc. All rights reserved. 54 Outline DisplayAuthors. java (3 of 3 ) Catch SQLException, which is thrown if the query execution or ResultSet process fails ClassNotFoundException is thrown if the class loader cannot locate the driver class Close the Statement and the database Connection.

 Pearson Education, Inc. All rights reserved. 55 Fig | Popular JDBC database URL formats.

 2005 Pearson Education, Inc. All rights reserved Querying the books Database Allow the user to enter any query into the program Display the results of a query in a JTable

 Pearson Education, Inc. All rights reserved. 57 Outline ResultSetTable Model.java (1 of 7 ) Class ResultSetTableModel extends class AbstractTableModel, which implements interface TableModel. Instance variable keeps track of database connection status

 Pearson Education, Inc. All rights reserved. 58 Outline ResultSetTable Model.java (2 of 7 ) Establishes a connection to the database. Invokes Connection method createStatement to create a Statement object. Constructor accepts five String arguments—the driver class name, the database URL, the username, the password and the default query to perform Indicate that connect to database is successful Invokes ResultSetTableModel method setQuery to perform the default query.

 Pearson Education, Inc. All rights reserved. 59 Outline ResultSetTable Model.java (3 of 7 ) Override method getColumnClass to obtain a Class object that represents the superclass of all objects in a particular column Verify database connection status Loads the class definition for the class and returns the corresponding Class object. Returns the default type. Obtains the fully qualified class name for the specified column. Override method getColumnCount to obtain the number of columns in the model’s underlying ResultSet

 Pearson Education, Inc. All rights reserved. 60 Outline ResultSetTable Model.java (4 of 7 ) Obtains the number of columns in the ResultSet. Override method getColumnName to obtain the name of the column in the model’s underlying ResultSet Obtains the column name from the ResultSet.

 Pearson Education, Inc. All rights reserved. 61 Outline ResultSetTable Model.java (5 of 7 ) Override method getColumnCount to obtain the number of rows in the model’s underlying ResultSet Uses ResultSet method absolute to position the ResultSet cursor at a specific row. Override method getValueAt to obtain the Object in a particular row and column of the model’s underlying ResultSet Uses ResultSet method getObject to obtain the Object in a specific column of the current row.

 Pearson Education, Inc. All rights reserved. 62 Outline ResultSetTable Model.java (6 of 7 ) Executes the query to obtain a new ResultSet. Uses ResultSet method last to position the ResultSet cursor at the last row in the ResultSet. Uses ResultSet method getRow to obtain the row number for the current row in the ResultSet. Invokes method fireTableAStructureChanged to notify any JTable using this ResultSetTableModel object as its model that the structure of the model has changed.

 Pearson Education, Inc. All rights reserved. 63 Outline ResultSetTable Model.java (7 of 7 ) Method disconnectFromDatabase implement an appropriate termination method for class ResultSetTableModel Verify whether the connection is already terminated Close the Statement and Connection if a ResultSetTableModel object is garbage collected. Set connectedToDatabase to false to ensure that clients do not use an instance of ResultSetTableModel after that instance has already been terminated

 Pearson Education, Inc. All rights reserved. 64 Fig | ResultSet constants for specifying ResultSet type.

 Pearson Education, Inc. All rights reserved. 65 Fig | ResultSet constants for specifying result properties.

 2005 Pearson Education, Inc. All rights reserved RowSet Interface Interface RowSet – Configures the database connection automatically – Prepares query statements automatically – Provides set methods to specify the properties needed to establish a connection – Part of the javax.sql package Two types of RowSet – Connected RowSet Connects to database once and remain connected – Disconnected RowSet Connects to database, executes a query and then closes connection

 2005 Pearson Education, Inc. All rights reserved RowSet Interface (Cont.) Package javax.sql.rowset – JdbcRowSet Connected RowSet Wrapper around a ResultSet Scrollable and updatable by default – CachedRowSet Disconnected RowSet Cache the data of ResultSet in memory Scrollable and updatable by default Serializable – Can be passed between Java application Limitation – Amount of data that can be stored in memory is limited

 Pearson Education, Inc. All rights reserved. 68 Portability Tip 25.5 A RowSet can provide scrolling capability for drivers that do not support scrollable ResultSet s.

 Pearson Education, Inc. All rights reserved. 69 Outline JdbcRowSetTest. java (1 of 3 )

 Pearson Education, Inc. All rights reserved. 70 Outline JdbcRowSetTest. java (2 of 3 ) Use Sun’s reference implementation of JdbcRowSet interface ( JdbcRowSetImpl ) to create a JdbcRowSet object Invoke JdbcRowSet method setUrl to specify the database URL Invoke JdbcRowSet method setUsername to specify the username Invoke JdbcRowSet method setUsername to specify the password Invoke JdbcRowSet method setCommand to specify the query Invoke JdbcRowSet method execute to execute the query

 Pearson Education, Inc. All rights reserved. 71 Outline JdbcRowSetTest. java (3 of 3 )