DBMS Lab File
Submitted To: Submitted By:
Dr. Rahul Rishi Harsh Wardhan Gupta
Director Roll No. 19566
23541
UIET MDU, Rohtak CSE-I (3rd Sem.)
S.No. Name of Program P.No. Remarks
01. Introduction to SQL 02-04
02. To create and use database 05
03. Creation of table with and 06-07
without constraints
04. Add record into table 08
05. Retrieving data 09-13
06. Deleting records 14
07. Dropping table 15
08. Update table 16
09. Alter table 17-18
10. Ordering records 19
11. Aggregate Functions 20-21
12. Grouping Functions 22-23
13. Set Operations 24-25
14. Join Operations 26-28
15. String Operations 29-32
1
1. Introduction to SQL
Structure Query Language(SQL) is a database query language used for storing and managing
data in Relational DBMS. SQL was the first commercial language introduced for E.F
Cod’s Relational model of database. Today almost all RDBMS(MySQL, Oracle, Informix,
Sybase, MS Access) use SQL as the standard database query language. SQL is used to perform
all types of data operations in RDBMS.
SQL Command
SQL defines following ways to manipulate data stored in an RDBMS.
DDL: Data Definition Language
This includes changes to the structure of the table like creation of table, altering table, deleting a table
etc.
All DDL commands are auto-committed. That means it saves all the changes permanently in the
database.
Command Description
Create to create new table or database
Alter for alteration
Truncate delete data from table
Drop to drop a table
2
Rename to rename a table
DML: Data Manipulation Language
DML commands are used for manipulating the data stored in the table and not the table itself.
DML commands are not auto-committed. It means changes are not permanent to database, they can
be rolled back.
Command Description
Insert to insert a new row
Update to update existing row
Delete to delete a row
Merge merging two rows or two tables
TCL: Transaction Control Language
These commands are to keep a check on other commands and their affect on the database. These
commands can annul changes made by other commands by rolling the data back to its original state.
It can also make any temporary change permanent.
Command Description
3
Commit to permanently save
Rollback to undo change
save point to save temporarily
DCL: Data Control Language
Data control language are the commands to grant and take back authority from any database user.
Command Description
Grant grant permission of right
Revoke take back permission.
DQL: Data Query Language
Data query language is used to fetch data from tables based on conditions that we can easily apply.
Command Description
Select retrieve records from one or more table
4
2. TO CREATE AND USE DATABASE
(A). CREATE DATABASE :
The CREATE DATABASE statement is used to create a new SQL database.
SYNTAX:
CREATE DATABASE database_name;
EXAMPLE:
(B). SHOW DATABASES:
To list all databases on a MySQL server host.
SYNTAX:
SHOW DATABASES;
EXAMPLE:
(C). USE DATABSE:
Use SQL command USE to select a particular database.
SYNTAX:
USE database_name;
EXAMPLE:
5
3.CREATION OF TABLE WITH AND WITHOUT
CONSTRANTS:
(A).CREATE TABLES WITH CONSTRAINTS:
Constraints can be specified when the table is created with the CREATE TABLE statement, or
after the table is created with the ALTER TABLE statement. The following constraints are
commonly used in SQL:
• NOT NULL - Ensures that a column cannot have a NULL value
• UNIQUE - Ensures that all values in a column are different
• PRIMARY KEY - A combination of a NOT NULL and UNIQUE. Uniquely identifies
each row in a table
• FOREIGN KEY - Uniquely identifies a row/record in another table
• CHECK - Ensures that all values in a column satisfies a specific condition
• DEFAULT - Sets a default value for a column when no value is specified
• INDEX - Used to create and retrieve data from the database very quickly
SYNTAX:
CREATE TABLE table_name (
column1 datatype constraint,
column2 datatype constraint,
column3 datatype constraint,
....
);
EXAMPLE:
(B). CREATE TABLES WITHOUT CONSTRAINTS:
To create a new table within a database
SYNTAX:
CREATE TABLE table_name (
column1 datatype,
column2 datatype,
column3 datatype,
....
);
EXAMPLES:
6
(C). SHOW TABLES:
To list tables in a MySQL database
SYNTAX:
SHOW TABLES;
EXAMPLE:
7
4. ADD RECORDS INTO TABLES:
(A).SIMPLE INSERTION:
The INSERT Statement is used to add new rows of data to a table.
SYNTAX:
INSERT INTO table_name
VALUES (value1, value2, value3, ...);
EXAMPLE:
(B). INSERTING VALUES INTO SPECIFIC COLUMS:
It is also possible to only insert data in specific columns.
SYNTAX:
INSERT INTO table_name(column_name1, column_name2,…)
VALUES (value1, value2,...);
EXAMPLE:
8
5. RETRIEVING DATA FROM TABLE
(A). RETRIEVING ALL RECORDS:
The SELECT statement is used to select data from a database.
SYNTAX:
SELECT *FROM table_name;
EXAMPLE:
(B). RETRIEVING SPECIFIC COLUMNS:
The most common query from a database is to collect or retrieve all the elements in a specific column of the
database table.
SYNTAX:
SELECT column_name FROM table_name;
EXAMPLE:
( C ). PRINTING WITH USER DEFINED
Use a user-defined variable to store the value in table.
SYNTAX:
SELECT column_name AS userdefined_name, attribute AS userdefined_name FROM
table_name;
9
EXAMPLE:
(D). USING LOGICAL OPERATORS (AND, OR, NOT):
AND OPERATOR:
The AND operator displays a record if all the conditions separated by AND are TRUE.
SYNTAX:
SELECT * FROM table_name WHERE condition1 AND condition2 AND condition3 ...;
EXAMPLE:
OR OPERATOR:
The OR operator displays a record if any of the conditions separated by OR is TRUE.
SYNTAX:
SELECT * FROM table_name WHERE condition1 OR condition2 OR condition3 ...;
EXAMPLE:
10
NOT OPERATOR:
The NOT operator displays a record if the condition(s) is NOT TRUE.
SYNTAX:
SELECT * FROM table_name WHERE NOT condition;
EXAMPLE:
( E ). USING BETWEEN:
The BETWEEN operator selects values within a given range. The values can be numbers, text, or
dates. The BETWEEN operator is inclusive: begin and end values are included.
SYNTAX:
SELECT column_name FROM table_name WHERE column_name BETWEEN value1 AND value2;
EXAMPLE:
(F). USING IN :
The IN operator allows you to specify multiple values in a WHERE clause. The IN operator is a
shorthand for multiple OR conditions.
SYNTAX:
SELECT column_name
FROM table_name
WHERE column_name IN (value1, value2, ...);
11
EXAMPLE:
(G). USING LIKE:
The LIKE operator is used in a WHERE clause to search for a specified pattern in a column. There
are two wildcards often used in conjunction with the LIKE operator:
• %
• _
(i). %
The percent sign represents zero, one, or multiple characters.
SYNTAX:
SELECT * FROM table_name WHERE column_name LIKE 'a%';
EXAMPLE:
(ii). _
The underscore represents a single character
SYNTAX:
SELECT * FROM table_name WHERE column_name LIKE '_r%';
EXAMPLE:
12
(H). USING IS NULL:
A field with a NULL value is a field with no value. If a field in a table is optional, it is possible
to insert a new record or update a record without adding a value to this field. Then, the field will
be saved with a NULL value.
SYNTAX:
SELECT * FROM table_name WHERE column_name IS NULL;
EXAMPLE:
( I ). LIMIT NUMBER OF RECORD:
Limited number of records.
SYNTAX:
Select * from table_name limit limit_no;
EXAMPLE:
13
6.DELETING RECORDS
(A). DELETE SINGLE RECORD:
The DELETE statement is used to delete existing records in a table.
SYNTAX:
DELETE FROM table_name WHERE condition;
EXAMPLE:
(B). DELETE MULTIPLE RECORDS:
The DELETE statement is used to delete all existing records in a table.
SYNTAX:
DELETE FROM table_name WHERE id IN(1,2,3…,10);
EXAMPLE:
( C ). DELETE ALL RECORDS:
The DELETE statement is used to delete all existing records in a table.
SYNTAX:
DELETE FROM table_name
EXAMPLE:
14
7. DROPPING TABLE
The DROP DATABASE statement is used to drop an existing SQL database
SYNTAX:
DROP TABLE table_name
EXAMPLE:
15
8.UPDATE TABLE
(A). UPDATE WITHOUT
; WHERE CLAUSE:
The WHERE clause is used to filter records. The WHERE clause is used to extract only those
records that fulfill a specified condition
SYNTAX:
UPDATE table_name SET column_name;
EXAMPLE:
(B) UPDATE WITH WHERE CLAUSE:
The WHERE clause is used to filter records. The WHERE clause is used to extract only those
records that fulfill a specified condition.
SYNTAX:
UPDATE table_name SET column_name WHERE condition;
EXAMPLE:
16
9. ALTER TABLE
The ALTER TABLE statement is used to add, delete, or modify columns in an existing table.The
ALTER TABLE statement is also used to add and drop various constraints on an existing table.
.
(A). ADDING COLUMN:
To add a column in a table
SYNTAX:
ALTER TABLE table_name ADD COLUMN column_name DATATYPE(SIZE)
EXAMPLE:
(B). ADDING MULTIPLE COLUMNS:
Use the ALTER TABLE command to add columns to a table after it's created. The command
also allows you to add multiple columns in the one statement.
SYNTAX:
ALTER TABLE table_name ADD column (Column_name1 DATATYPE, Column_name2
DATATYPE);
EXAMPLE:
(C) CHANGING COLUMN WIDTH:
To change the data type of a column in a table
SYNTAX:
ALTER TABLE table_name MODIFY column_name DATATYPE;
EXAMPLE:
(D). DROPPING COLUMN:
To delete a column in a table
SYNTAX:
ALTER TABLE table_name DROP COLUMN column_name
EXAMPLE:
19
(E) ADDING COLUMN AT PARTICULAR POSITION:
To add a column at a specific position within a table
SYNTAX:
ALTER TABLE table_name ADD COLUMN column_name DATATYPE AFTER
column_name;
EXAMPLE: ;
(F). CHANGING COLUMN NAME :
Change the name of column
SYNTAX:
ALTER TABLE table_name RENAME COLUMN old_column_name TO new_column_name;
EXAMPLE:
(G). RENAME THE TABLE NAME:
To rename a table name to sql
SYNTAX:
RENAME TABLE old_table TO new_table;
EXAMPLE:
18
10. ORDERING RECORDS
(A). ASCENDING:
The order by statement in sql is used to sort the fetched data in ascending order.
SYNTAX:
SELECT * FROM table_name ORDER BY column_name ASC;
EXAMPLE:
(B). DESCENDING:
The order by statement in sql is used to sort the fetched data in descending order.
SYNTAX:
SELECT * FROM table_name ORDER BY column_name DESC;
EXAMPLE:
19
11. AGGREGATE FUNCTIONS
(A). AVERAGE:
The MySQL avg() function is used to return the average value of an expression.
SYNTAX:
SELECT AVG(column_name) as average_column_name FROM table_name;
EXAMPLE:
(B). MAXIMUM
The MySQL max() function is used to return the maximum value of an expression. It is used
when you need to get the maximum value from your table.
SYNTAX:
SELECT MAX(column_name) as maximum_column_name FROM table_name;
EXAMPLES:
(C). MINIMUM
The MySQL min() function is used to return the minimum value from the table.
SYNTAX:
SELECT MIN(column_name) as minimum_column_name FROM table_name;
20
EXAMPLES:
(D). COUNT
The MySQL count() function is used to return the count of an expression. It is used when you
need to count some records of your table.
SYNTAX:
SELECT COUNT (column_name) FROM table_name ;
EXAMPLES:
(E). SUM
The MySQL sum() function is used to return the total summed value of an expression.
SYNTAX:
SELECT SUM(column_name) FROM table_name;
EXAMPLES:
21
12. GROUPING FUNCTION
(A). GROUPING BY CLAUSE
The GROUP BY statement is often used with aggregate functions (COUNT, MAX, MIN, SUM,
AVG) to group the result-set by one or more columns.
SYNTAX:
SELECT column_name FROM table_name WHERE condition GROUP BY column_name;
EXAMPLE:
(B). HAVING CLAUSE
The HAVING clause was added to SQL because the WHERE keyword could not be used with
aggregate functions.
SYNTAX:
SELECT column_name FROM table_name WHERE condition GROUP BY column_name
HAVING condition;
EXAMPLE:
22
(C). ALL CLAUSE
ALL operator is used to select all tuples of SELECT STATEMENT. It is also used to compare a
value to every value in another value set or result from a subquery.
SYNTAX:
SELECT ALL column_name FROM table_name WHERE condition;
EXAMPLES:
23
13. SET OPERATIONS
(A). UNION
SYNTAX:
SELECT column_name FROM table_1 UNION SELECT column_name FROM table_2;
EXAMPLES:
(B). UNION ALL
SYNTAX:
SELECT column_name FROM table_1 UNION ALL SELECT column_name FROM table_2;
EXAMPLES:
24
(C). INTERSECT
SYNTAX:
SELECT column_name FROM table_1 INTERSECT SELECT column_name FROM table_2;
EXAMPLES:
(D) EXCEPT
SYNTAX:
SELECT column_name FROM table_1 EXCEPT SELECT column_name FROM table_2;
EXAMPLES:
25
14. JOIN OPERATION
(A). NATURAL JOIN
The NATURAL JOIN is such a join that performs the same task as an INNER or LEFT JOIN, in
which the ON or USING clause refers to all columns that the tables to be joined have in
common.
SYNTAX:
SELECT * FROM table_1 NATURAL JOIN table_2;
EXAMPLES:
(B). LEFT OUTER JOIN
A LEFT OUTER JOIN is one of the JOIN operations that allow you to specify a join clause. It
preserves the unmatched rows from the first (left) table, joining them with a NULL row in the
shape of the second (right) table.
SYNTAX:
SELECT table_1.column1, table_2.column2… FROM table_1 LEFT OUTER JOIN table_2 ON
table_1.common_field = table_2.common_field;
EXAMPLES:
26
(C). RIGHT OUTER JOIN
A RIGHT OUTER JOIN is one of the JOIN operations that allow you to specify a JOIN clause.
It preserves the unmatched rows from the second (right) table, joining them with a NULL in the
shape of the first (left) table.
SYNTAX:
SELECT table_1.column1, table_2.column2… FROM table_1 RIGHT OUTER JOIN table_2
ON table_1.common_field = table_2.common_field;
EXAMPLES:
(D). INNER JOIN
The INNER JOIN selects all rows from both participating tables as long as there is a match
between the columns. An SQL INNER JOIN is same as JOIN clause, combining rows from two
or more tables.
SYNTAX:
SELECT table_1.column1, table_2.column2… FROM table_1 INNER JOIN table_2 ON
table_1.common_field = table_2.common_field;
EXAMPLES:
(E). THETA JOIN
A theta join allows for arbitrary comparison relationships (such as ≥). An equijoin is a theta
join using the equality operator. A natural join is an equijoin on attributes that have the same
name in each relationship
SYNTAX:
SELECT * FROM table_1 THETA JOIN table_2;
27
EXAMPLES:
(F). CROSS JOIN
The SQL CROSS JOIN produces a result set which is the number of rows in the first table
multiplied by the number of rows in the second table if no WHERE clause is used along with
CROSS JOIN. This kind of result is called as Cartesian Product.
SYNTAX:
SELECT * FROM table_1 CROSS JOIN table_2;
EXAMPLES:
28
15. STRING OPERATION
(A) SUBSTRING
Return the substring as specified
SYNTAX:
SELECT SUBSTRING(string, start, length)
EXAMPLES:
(B). SUBSTRING_INDEX
The SUBSTRING_INDEX() function returns a substring of a string before a specified number of
delimiter occurs.
SYNTAX:
SELECT SUBSTRING_INDEX(string, delimiter, number)
EXAMPLES:
(C). UPPER
The UPPER() function converts a string to upper-case.
SYNTAX:
SELECT UPPER(text)
EXAMPLES:
(D). LOWER
The LOWER() function converts a string to lower-case.
SYNTAX:
SELECT LOWER(text)
29
EXAMPLES:
(F). LTRIM
The LTRIM() function removes leading spaces from a string.
SYNTAX:
SELECT LTRIM(string)
EXAMPLES:
(G). RTRIM
The RTRIM() function removes trailing spaces from a string.
SYNTAX:
SELECT RTRIM(string)
EXAMPLES:
(H). LEFT
The LEFT() function extracts a number of characters from a string (starting from left).
SYNTAX:
SELECT LEFT(string, number_of_chars);
EXAMPLES:
30
(I). RIGHT
The RIGHT() function repeats a string as many times as specified.
SYNTAX:
SELECT RIGHT(string, number);
EXAMPLES:
(J). REVERSE
The REVERSE() function reverses a string and returns the result .
SYNTAX:
SELECT REVERSE(string)
EXAMPLES:
(K). LPAD
The LPAD() function left-pads a string with another string, to a certain length.
SYNTAX:
SELECT LPAD(string, length, lpad_string);
EXAMPLES:
31
(L). RPAD
The RPAD() function right-pads a string with another string, to a certain length.
SYNTAX:
SELECT RPAD(string, length, rpad_string);
EXAMPLES:
32