You are on page 1of 11

SQL

SQL stands for Structured Query Language. It is used for storing and managing data in relational database
management system (RDMS).
It is a standard language for Relational Database System. It enables a user to create, read, update and delete
relational databases and tables.
All the RDBMS like MySQL, Informix, Oracle, MS Access and SQL Server use SQL as their standard database
language.
SQL allows users to query the database in a number of ways, using English-like statements.
Rules:
SQL follows the following rules:
Structure query language is not case sensitive. Generally, keywords of SQL are written in uppercase.
Statements of SQL are dependent on text lines. We can use a single SQL statement on one or multiple text line.
Using the SQL statements, you can perform most of the actions in a database.
SQL depends on tuple relational calculus and relational algebra.
SQL process:
When an SQL command is executing for any RDBMS, then the system figure out the best way to carry out the
request and the SQL engine determines that how to interpret the task.
In the process, various components are included. These components can be optimization Engine, Query engine,
Query dispatcher, classic, etc.
All the non-SQL queries are handled by the classic query engine, but SQL query engine won't handle logical
files.

Characteristics of SQL
SQL is easy to learn.
SQL is used to access data from relational database management systems.
SQL can execute queries against the database.
SQL is used to describe the data.
SQL is used to define the data in the database and manipulate it when needed.
SQL is used to create and drop the database and table.
SQL is used to create a view, stored procedure, function in a database.
SQL allows users to set permissions on tables, procedures, and views.

Advantages of SQL
There are the following advantages of SQL:

High speed: Using the SQL queries, the user can quickly and efficiently retrieve a large amount of records from
a database.
No coding needed: In the standard SQL, it is very easy to manage the database system. It doesn't require a
substantial amount of code to manage the database system.
Well defined standards: Long established are used by the SQL databases that are being used by ISO and
ANSI.
Portability: SQL can be used in laptop, PCs, server and even some mobile phones.
Interactive language: SQL is a domain language used to communicate with the database. It is also used to
receive answers to the complex questions in seconds.
Multiple data view: Using the SQL language, the users can make different views of the database structure.

SQL Datatype
SQL Datatype is used to define the values that a column can contain.
Every column is required to have a name and data type in the database table.

Datatype of SQL:

1. Binary Datatypes
There are Three types of binary Datatypes which are given below:

Data Type Description

binary It has a maximum length of 8000 bytes. It contains fixed-length binary data.

varbinary It has a maximum length of 8000 bytes. It contains variable-length binary data.

image It has a maximum length of 2,147,483,647 bytes. It contains variable-length binary


data.

2. Approximate Numeric Datatype :


The subtypes are given below:

Data type From To Description

float -1.79E + 1.79E + 308 It is used to specify a floating-point value


308 e.g. 6.2, 2.9 etc.

real -3.40e + 38 3.40E + 38 It specifies a single precision floating


point number

3. Exact Numeric Datatype


The subtypes are given below:

Data type Description

int It is used to specify an integer value.

smallint It is used to specify small integer value.

bit It has the number of bits to store.

decimal It specifies a numeric value that can have a decimal number.


numeric It is used to specify a numeric value.

4. Character String Datatype


The subtypes are given below:

Data type Description

char It has a maximum length of 8000 characters. It contains Fixed-length non-


unicode characters.

varchar It has a maximum length of 8000 characters. It contains variable-length non-


unicode characters.

text It has a maximum length of 2,147,483,647 characters. It contains variable-


length non-unicode characters.

5. Date and time Datatypes


The subtypes are given below:

Datatype Description

date It is used to store the year, month, and days value.

time It is used to store the hour, minute, and second values.

timestamp It stores the year, month, day, hour, minute, and the second
value.

SQL Commands
SQL commands are instructions. It is used to communicate with the database. It is also used to perform specific
tasks, functions, and queries of data.
SQL can perform various tasks like create a table, add data to tables, drop the table, modify the table, set
permission for users.
Types of SQL Commands
There are five types of SQL commands: DDL, DML, DCL, TCL, and DQL.

1. Data Definition Language (DDL)


DDL changes the structure of the table like creating a table, deleting a table, altering a table, etc.
All the command of DDL are auto-committed that means it permanently save all the changes in the database.
Here are some commands that come under DDL:
CREATE
ALTER
DROP
TRUNCATE
a. CREATE It is used to create a new table in the database.
Syntax:
CREATE TABLE TABLE_NAME (COLUMN_NAME DATATYPES[,....]);  
Example:
CREATE TABLE EMPLOYEE(Name VARCHAR2(20), Email VARCHAR2(100), DOB DATE);  
b. DROP: It is used to delete both the structure and record stored in the table.
Syntax
DROP TABLE table_name;  
Example
DROP TABLE EMPLOYEE;  
c. ALTER: It is used to alter the structure of the database. This change could be either to modify the
characteristics of an existing attribute or probably to add a new attribute.
Syntax:
To add a new column in the table.
ALTER TABLE table_name ADD column_name COLUMN-definition;    
To modify existing column in the table:
ALTER TABLE table_name MODIFY(column_definitions....);  
EXAMPLE
ALTER TABLE STU_DETAILS ADD(ADDRESS VARCHAR2(20));  
ALTER TABLE STU_DETAILS MODIFY (NAME VARCHAR2(20));  
d. TRUNCATE: It is used to delete all the rows from the table and free the space containing the table.
Syntax:
TRUNCATE TABLE table_name;  
Example:
TRUNCATE TABLE EMPLOYEE;  

2. Data Manipulation Language(DML)


DML commands are used to modify the database. It is responsible for all form of changes in the database.
The command of DML is not auto-committed that means it can't permanently save all the changes in the
database. They can be rollback.
Here are some commands that come under DML:
INSERT
UPDATE
DELETE
a. INSERT: The INSERT statement is a SQL query. It is used to insert data into the row of a table.
Syntax:
INSERT INTO TABLE_NAME    
(col1, col2, col3,.... col N)  
VALUES (value1, value2, value3, .... valueN);  
Or
INSERT INTO TABLE_NAME    
VALUES (value1, value2, value3, .... valueN);    
For example:
INSERT INTO book (Author, Subject) VALUES ("Sonoo", "DBMS");  
b. UPDATE: This command is used to update or modify the value of a column in the table.
Syntax:
UPDATE table_name SET [column_name1= value1,...column_nameN = valueN] [WHERE CONDITION]   
For example:
UPDATE students    
SET User_Name = 'Sonoo'    
WHERE Student_Id = '3'  
c. DELETE: It is used to remove one or more row from a table.
Syntax:
DELETE FROM table_name [WHERE condition];  
For example:
DELETE FROM javatpoint  
WHERE Author="Sonoo";  

3. Data Control Language(DCL)


DCL commands are used to grant and take back authority from any database user.
Here are some commands that come under DCL:
Grant
Revoke
a. Grant: It is used to give user access privileges to a database.
Example
GRANT SELECT, UPDATE ON MY_TABLE TO SOME_USER, ANOTHER_USER;  
b. Revoke: It is used to take back permissions from the user.
Example
REVOKE SELECT, UPDATE ON MY_TABLE FROM USER1, USER2;  

4. Transaction Control Language(TCL)


TCL commands can only use with DML commands like INSERT, DELETE and UPDATE only.
These operations are automatically committed in the database that's why they cannot be used while creating
tables or dropping them.
Here are some commands that come under TCL:
COMMIT
ROLLBACK
SAVEPOINT
a. Commit: Commit command is used to save all the transactions to the database.
Syntax:
COMMIT;  
Example:
DELETE FROM CUSTOMERS  
WHERE AGE = 25;  
COMMIT;  
b. Rollback: Rollback command is used to undo transactions that have not already been saved to the database.
Syntax:
ROLLBACK;  
Example:
DELETE FROM CUSTOMERS  
WHERE AGE = 25;  
ROLLBACK;  
c. SAVEPOINT: It is used to roll the transaction back to a certain point without rolling back the entire
transaction.
Syntax:
SAVEPOINT SAVEPOINT_NAME;  

5. Data Query Language(DQL)


DQL is used to fetch the data from the database.
It uses only one command:
SELECT
a. SELECT: This is the same as the projection operation of relational algebra. It is used to select the attribute
based on the condition described by WHERE clause.
Syntax:
SELECT expressions    
FROM TABLES    
WHERE conditions;  
For example:
SELECT emp_name  
FROM employee  
WHERE age > 20;  

SQL Operator
There are various types of SQL operator:
SQL Arithmetic Operators
Let's assume 'variable a' and 'variable b'. Here, 'a' contains 20 and 'b' contains 10.

Operator Description Example

+ It adds the value of both operands. a+b will give 30

- It is used to subtract the right-hand operand from a-b will give 10


the left-hand operand.

* It is used to multiply the value of both operands. a*b will give 200

/ It is used to divide the left-hand operand by the a/b will give 2


right-hand operand.

% It is used to divide the left-hand operand by the a%b will give 0


right-hand operand and returns reminder.

SQL Comparison Operators:


Let's assume 'variable a' and 'variable b'. Here, 'a' contains 20 and 'b' contains 10.

Operato Description Example


r

= It checks if two operands values are equal or not, if the values are (a=b) is not
queal then condition becomes true. true

!= It checks if two operands values are equal or not, if values are (a!=b) is true
not equal, then condition becomes true.

<> It checks if two operands values are equal or not, if values are (a<>b) is true
not equal then condition becomes true.

> It checks if the left operand value is greater than right operand (a>b) is not
value, if yes then condition becomes true. true

< It checks if the left operand value is less than right operand (a<b) is true
value, if yes then condition becomes true.

>= It checks if the left operand value is greater than or equal to the (a>=b) is not
right operand value, if yes then condition becomes true. true

<= It checks if the left operand value is less than or equal to the right (a<=b) is true
operand value, if yes then condition becomes true.

!< It checks if the left operand value is not less than the right (a!=b) is not
operand value, if yes then condition becomes true. true

!> It checks if the left operand value is not greater than the right (a!>b) is true
operand value, if yes then condition becomes true.

SQL Logical Operators


There is the list of logical operator used in SQL:

Operator Description

ALL It compares a value to all values in another value set.

AND It allows the existence of multiple conditions in an SQL


statement.

ANY It compares the values in the list according to the condition.

BETWEEN It is used to search for values that are within a set of values.

IN It compares a value to that specified list value.

NOT It reverses the meaning of any logical operator.

OR It combines multiple conditions in SQL statements.

EXISTS It is used to search for the presence of a row in a specified


table.

LIKE It compares a value to similar values using wildcard


operator.

Views in SQL
Views in SQL are considered as a virtual table. A view also contains rows and columns.
To create the view, we can select the fields from one or more tables present in the database.
A view can either have specific rows based on certain condition or all the rows of a table.
Sample table:
Student_Detail & Student_Marks

STU_ID NAME ADDRESS

1 Stephan Delhi

2 Kathrin Noida

3 David Ghaziabad
4 Alina Gurugram

STU_ID NAME MARK AGE


S

1 Stephan 97 19

2 Kathrin 86 21

3 David 74 18

4 Alina 90 20

5 John 96 18

1. Creating view
A view can be created using the CREATE VIEW statement. We can create a view from a single table or
multiple tables.
Syntax:
CREATE VIEW view_name AS  
SELECT column1, column2.....  
FROM table_name  
WHERE condition;  

2. Creating View from a single table


In this example, we create a View named DetailsView from the table Student_Detail.
Query:
CREATE VIEW DetailsView AS  
SELECT NAME, ADDRESS  
FROM Student_Details  
WHERE STU_ID < 4;  
Just like table query, we can query the view to view the data.
SELECT * FROM DetailsView;  
Output:

NAME ADDRESS

Stephan Delhi

Kathrin Noida

David Ghaziabad

3. Creating View from multiple tables


View from multiple tables can be created by simply include multiple tables in the SELECT statement.
In the given example, a view is created named MarksView from two tables Student_Detail and Student_Marks.
Query:
CREATE VIEW MarksView AS  
SELECT Student_Detail.NAME, Student_Detail.ADDRESS, Student_Marks.MARKS  
FROM Student_Detail, Student_Mark  
WHERE Student_Detail.NAME = Student_Marks.NAME;  
To display data of View MarksView:
SELECT * FROM MarksView;  

NAME ADDRESS MARKS


Stephan Delhi 97

Kathrin Noida 86

David Ghaziabad 74

Alina Gurugram 90

4. Deleting View
A view can be deleted using the Drop View statement.
Syntax
DROP VIEW view_name;  
Example: If we want to delete the View MarksView, we can do this as:
DROP VIEW MarksView;  

SQL Clauses
The following are the various SQL clauses:

1. GROUP BY
SQL GROUP BY statement is used to arrange identical data into groups. The GROUP BY statement is used
with the SQL SELECT statement.
The GROUP BY statement follows the WHERE clause in a SELECT statement and precedes the ORDER BY
clause. The GROUP BY statement is used with aggregation function.
Syntax:
SELECT column  
FROM table_name  
WHERE conditions   
GROUP BY column  
ORDER BY column  
Sample table:
PRODUCT_MAST

PRODUCT COMPANY QTY RATE COST

Item1 Com1 2 10 20

Item2 Com2 3 25 75

Item3 Com1 2 30 60

Item4 Com3 5 10 50

Item5 Com2 2 20 40

Item6 Cpm1 3 25 75
Item7 Com1 5 30 150

Item8 Com1 3 10 30

Item9 Com2 2 25 50

Item10 Com3 4 30 120


Example:
SELECT COMPANY, COUNT(*)  
FROM PRODUCT_MAST   
GROUP BY COMPANY;  
Output:
Com1 5
Com2 3
Com3 2

2. HAVING
HAVING clause is used to specify a search condition for a group or an aggregate.
Having is used in a GROUP BY clause. If you are not using GROUP BY clause then you can use HAVING
function like a WHERE clause.
Syntax:
SELECT column1, column2   
FROM table_name  
WHERE conditions   
GROUP BY column1, column2   
HAVING conditions  
ORDER BY column1, column2;  
Example:
SELECT COMPANY, COUNT(*)  
FROM PRODUCT_MAST   
GROUP BY COMPANY  
HAVING COUNT(*)>2;  
Output:
Com1 5
Com2 3

3. ORDER BY
The ORDER BY clause sorts the result-set in ascending or descending order.
It sorts the records in ascending order by default. DESC keyword is used to sort the records in descending order.
Syntax:
SELECT column1, column2  
FROM table_name  
WHERE condition  
ORDER BY column1, column2... ASC|DESC;  
Where
ASC: It is used to sort the result set in ascending order by expression.
DESC: It sorts the result set in descending order by expression.
Example: Sorting Results in Ascending Order
Table:
CUSTOMER

CUSTOMER_ID NAME ADDRESS

12 Kathrin US

23 David Bangkok
34 Alina Dubai

45 John UK

56 Harry US
Enter the following SQL statement:
SELECT *  
FROM CUSTOMER  
ORDER BY NAME;  
Output:

CUSTOMER_ID NAME ADDRESS

34 Alina Dubai

23 David Bangkok

56 Harry US

45 John UK

12 Kathrin US
Example: Sorting Results in Descending Order
Using the above CUSTOMER table
SELECT *  
FROM CUSTOMER  
ORDER BY NAME DESC;  
Output:

CUSTOMER_ID NAME ADDRESS

12 Kathrin US

45 John UK

56 Harry US

23 David Bangkok

34 Alina Dubai

You might also like