Database Testing Using Selenium WebDriver – MySQL
Database Testing Using Selenium WebDriver
In this post, let’s see how to do Database Testing using Selenium WebDriver. As we all know Selenium WebDriver is a tool to automate User Interface. We could only interact with Browser using Selenium WebDriver.
Sometimes, we may face a situation to get the data from the Database or to modify (update/delete) the data from the Database. If we plan to automate anything outside the vicinity of a browser, then we need to use other tools to achieve our task. To achieve the Database connection and work on it, we need to use JDBC API Driver.
Must Read: What is Gecko Driver and how to use it in Selenium WebDriver.
The Java Database Connectivity (JDBC) API provides universal data access from the Java programming language. Using the JDBC API, you can access virtually any data source, from relational databases to spreadsheets and flat files. It lets the user connect and interact with the Database and fetch the data based on the queries we use in the automation script. JDBC is a SQL level API that allows us to execute SQL statements. It creates a connectivity between Java Programming Language and the database.
Using JDBC Driver we could do the following
- Establish a Database connection
- Send SQL Queries to the Database
- Process the results
Loading the required JDBC (Java DataBase Connectivity) Driver class:
Class.forName("com.mysql.jdbc.Driver");
Note: The parameter varies between Data bases such as MSSQL Server, DB2 etc.,
Establishing a connection to the DataBase (MySQL Server):
Connection con = DriverManager.getConnection("DataBaseURL", "userName", "password");
DB Connection URL Syntax (MySQL Server):
jdbc:mysql://ipAddress:portNumber/dbName
Executing SQL Queries:
Statement sqlStatement = con.createStatement(); String sqlQuery = "SELECT * FROM table_name WHERE condition"; ResultSet resSet = sqlStatement.executeQuery(sqlQuery);
Results from the executed query are stored in the ResultSet Object.
Fetching data from result set:
while (resSet.next()) { System.out.println(resSet.getString(required_column_name)); }
Disconnecting the Database connection:
con.close();
List of Methods to process the results:
Note: Assuming that you have already Installed Database.
Steps to follow – Database Testing using Selenium WebDriver:
- Click here to download the jar files.
- Add the downloaded jar file to your project
Right click on your Java File – Click on Build Path – Configure build path – Select the libraries – Click on add external JARs – Select MySQL JDBC
jar – Click on open to add it to the project
3. Copy the below mentioned script and modify as per your requirement and execute it
Note: You could find the detailed explanation of the script in the code snippet below
Script to get the data from the Database – Database Testing:
package softwareTestingMaterial; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class DBTesting { public static void selectQuery() throws SQLException, ClassNotFoundException { String dbURL = "jdbc:mysql://ipAddress:portNumber/dbName"; String username = myUserName; String password = myPassword; //Load MySQL JDBC Driver Class.forName("com.mysql.jdbc.Driver"); //Creating connection to the database Connection con = DriverManager.getConnection(dbURL,username,password); //Creating statement object Statement st = con.createStatement(); String selectquery = "SELECT * FROM <tablename> WHERE <condition>"; //Executing the SQL Query and store the results in ResultSet ResultSet rs = st.executeQuery(selectquery); //While loop to iterate through all data and print results while (rs.next()) { System.out.println(rs.getString("transaction_datetime")); } //Closing DB Connection con.close(); } }
I would like to conclude this post “MySQL Database testing using Selenium WebDriver” here. If you find anything difficult, please comment below. Also, I have hand-picked few posts which will help you to learn more interview related stuff:
- Selenium WebDriver Tutorial
- Selenium Interview Questions
- Explain Test Automation Framework
- Test Automation Framework Interview Questions
- TestNG Interview Questions
- SQL Interview Questions
- Manual Testing Interview Questions
- Agile Interview Questions
- Why You Choose Software Testing As A Career
- General Interview Questions
If you have any more question, feel free to ask via comments. If you find this post useful, do share it with your friends on Social Networking.
Hi , I am willing to learn database testing but I don’t know about selenium . Can anyone learn database testing without learning selenium.And what topics have to cover for database testing.
Hi , I am willing to learn database testing but I don’t know about selenium . Can anyone learn database testing without learning selenium.And what topics have to cover for database testing.
Hi Gureet, You could learn Database testing without learning Selenium. In database testing we do test Data integrity, data validity, fine tunning performance of database, validating stored procedures, indexes, etc., Currently we are not dealing with database testing. But sure we write on that too. You could learn SQL for software testers by clicking here.