NOTES ON MYSQL
1.    Creating Database:
mysql> create database pradeep;
Query OK, 1 row affected (0.08 sec)
2.    Using Database Created
mysql> use pradeep;
Database changed
3.    Creating a table:
mysql> create table exam(rno int,name varchar(20),math int,phy int,chem int);
Query OK, 0 rows affected (0.06 sec)
mysql> create table office(eno int,ename varchar(20),addr varchar(30),cnt int);
mysql> create table library(bno int,bname varchar(20),writer varchar(20),price int);
mysql> create table item(itno int,itname varchar(20),dop date, price float);
Note: Classification Of Datatypes
Numeric Dataype :
INT (11 digits), TINYINT (4 digits), SMALLINT (5 digits), MEDIUMINT (9 digits), BIGINT (11 digits)
FLOAT(M,D) M is length & D is no. of decimal places -DEFAULT is FLOAT(10,2)
DOUBLE(M,D) M is length & D is no. of decimal places -DEFAULT is DOUBLE (16,4)
DECIMAL(M,D) M is length & D is no. of decimal places – There is no DEFAULT value and is must to
assign value for M and D.
To store 35.20
CREATE TABLE CHEM(MM FLOAT);                                             // DEFAULT is FLOAT(10,2)
0        0       0       0       0       0       3       5       2       0
CREATE TABLE CHEM(MM FLOAT(6,2));
0    0     3    5    2     0
CREATE TABLE CHEM(MM DOUBLE);                                                // DEFAULT is DOUBLE (16,4)
0        0       0   0       0       0       0       0       0       0       3     5    2    0    0        0
CREATE TABLE CHEM(MM DOUBLE(6,2));
0    0     3    5    2    0
CREATE TABLE CHEM(MM DECIMAL) -// IT WILL PRODUCE ERROR because there is no DEFAULT
value.
CREATE TABLE CHEM(MM DECIMAL(6,2));
0        0       3       5       2       0
4.       Viewing structure of table:
     mysql> describe exam;
     +-------+-------------+------+-----+---------+-------+
     | Field | Type       | Null | Key | Default | Extra |
     +-------+-------------+------+-----+---------+-------+
     | rno | int(11) | YES | | NULL |                 |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
    | name | varchar(20) | YES | | NULL |                  |
    | math | tinyint(4) | YES | | NULL |                 |
    | phy | tinyint(4) | YES | | NULL |                |
    | chem | tinyint(4) | YES | | NULL |                 |
    +-------+-------------+------+-----+---------+-------+
    5 rows in set (0.19 sec)
Notes : MYSQL is capable of creating database in many different storage engine that offer different
features. Examples of storage engines are ISAM, INNODB, etc. Default storage engine is
MyISAM. MyISAM does not support Foreign Key but InnoDB supports Foreign Key hence if we
want to apply Foreign Key Constraint in a Table then we must create it in InnoDB Engine.
a) Viewing Storage Engine of Table :
mysql> show create table exam;
--------------------------------------------------------------------------------
| Table | Create Table
----------------------------------------------------------------------------+
| exam | CREATE TABLE `exam` ( `rno` int(11) DEFAULT NULL, `name` varchar(20)
DEFAULT NULL, `math` tinyint(4) DEFAULT NULL, `phy` tinyint(4) DEFAULT NULL,
  `chem` tinyint(4) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
----------------------------------------------------------------------------
1 row in set (1.31 sec)
b) Creating Table in Required Storage Engine (InnoDB):
mysql> create table shop(pid integer, pname varchar(20), price double) Engine=InnoDB;
Query OK, 0 rows affected (2.03 sec)
c) Changing Storage Engine in already created table:
mysql> alter table workers engine=MyIsam;
Query OK, 2 rows affected (0.30 sec)
Records: 2 Duplicates: 0 Warnings: 0
5. Inserting data in table:
mysql> insert into exam values(1,'Amar',75,82,91);
Query OK, 1 row affected (0.08 sec)
mysql> insert into exam values(2,'Prakash',81,76,62);
Query OK, 1 row affected (0.03 sec)
mysql> insert into exam values(3,'Suresh',47,61,45);
Query OK, 1 row affected (0.01 sec)
Viewing records stored in a table :
mysql> select * from exam;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.01 sec)
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
NOTE:
1. Creating a Table From already existing Table:
(a) Creating a table from existing table( having all fields)
mysql> create table exam1 AS( select * from exam);
Query OK, 3 rows affected (0.17 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from exam1;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.00 sec)
(b) Creating a table from existing table( having selected fields)
mysql> create table exam2 AS(select rno,name,math from exam1);
Query OK, 3 rows affected (0.09 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from exam2;
+------+---------+------+
| rno | name | math |
+------+---------+------+
| 1 | Amar | 75 |
| 2 | Prakash | 81 |
| 3 | Suresh | 47 |
+------+---------+------+
3 rows in set (0.00 sec)
(c) Creating a table from existing table for selected records ( having all fields)
mysql> create table exam3 AS(select * from exam1 where rno>=2);
Query OK, 2 rows affected (0.11 sec)
Records: 2 Duplicates: 0 Warnings: 0
mysql> select * from exam3;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
2 rows in set (0.00 sec)
(d) Creating a table from existing table for selected records and selected field
mysql> create table exam4 AS(select rno,name,math from exam1 where rno>=2);
Query OK, 2 rows affected (0.17 sec)
Records: 2 Duplicates: 0 Warnings: 0
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
mysql> select * from exam4;
+------+---------+------+
| rno | name | math |
+------+---------+------+
| 2 | Prakash | 81 |
| 3 | Suresh | 47 |
+------+---------+------+
2 rows in set (0.00 sec)
2. Changing Structure of already created table :
(a) Adding New Column(s) in existing table
mysql> alter table exam2 add column(address varchar(20));
Query OK, 3 rows affected (0.34 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from exam2;
+------+---------+------+---------+
| rno | name | math | address |
+------+---------+------+---------+
| 1 | Amar | 75 | NULL |
| 2 | Prakash | 81 | NULL |
| 3 | Suresh | 47 | NULL |
+------+---------+------+---------+
3 rows in set (0.00 sec)
(b) Inserting records in selected fields:
mysql> update exam2 set address='Patna' where rno=1;
Query OK, 1 row affected (0.05 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> update exam2 set address='Delhi' where rno=2;
Query OK, 1 row affected (0.03 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> update exam2 set address='Ranchi' where rno=3;
Query OK, 1 row affected (0.06 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from exam2;
+------+---------+------+---------+
| rno | name | math | address |
+------+---------+------+---------+
| 1 | Amar | 75 | Patna |
| 2 | Prakash | 81 | Delhi |
| 3 | Suresh | 47 | Ranchi |
+------+---------+------+---------+
3 rows in set (0.00 sec)
(c ) Updating Record(Multiple fields):
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
(i) mysql> select * from exam2;
+------+---------+------+---------+
| rno | name | math | address |
+------+---------+------+---------+
| 1 | Amar | 75 | Patna |
| 2 | Prabhat | 91 | Mumbai |
| 3 | Suresh | 91 | Ranchi |
+------+---------+------+---------+
3 rows in set (0.02 sec)
mysql> update exam2 set name='Bhupesh',math=95,address='Kanpur' where rno=2;
Query OK, 1 row affected (0.02 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from exam2;
+------+---------+------+---------+
| rno | name | math | address |
+------+---------+------+---------+
| 1 | Amar | 75 | Patna |
| 2 | Bhupesh | 95 | Kanpur |
| 3 | Suresh | 91 | Ranchi |
+------+---------+------+---------+
3 rows in set (0.00 sec)
(d) Modify structure of already existing table/column:
(i) Changing size of a column in existing table
mysql> desc exam2;
+---------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| rno | int(11) | YES | | NULL |                 |
| name | varchar(20) | YES | | NULL |                 |
| math | tinyint(4) | YES | | NULL |               |
| address | varchar(20) | YES | | NULL |               |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.13 sec)
1st Method:
mysql> alter table exam2 modify name varchar(30);
Query OK, 3 rows affected (0.31 sec)
Records: 3 Duplicates: 0 Warnings: 0
2nd Method
mysql> alter table exam2 change name sname varchar(30);
Query OK, 3 rows affected (0.31 sec)
Records: 3 Duplicates: 0 Warnings: 0
Note: If we are using MODIFY we have to give the name of column only one time but with CHANGE we have to
write the name of column twice With MODIFY you cannot change the name of a column where as with CHANGE you
can do so.
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
mysql> desc exam2;
+---------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| rno | int(11) | YES | | NULL |                 |
| name | varchar(30) | YES | | NULL |                 |
| math | tinyint(4) | YES | | NULL |               |
| address | varchar(20) | YES | | NULL |               |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.03 sec)
(ii) Changing datatype of a column in existing table
mysql> desc exam2;
+---------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| rno | int(11) | YES | | NULL |                 |
| name | varchar(20) | YES | | NULL |                 |
| math | tinyint(4) | YES | | NULL |               |
| address | varchar(20) | YES | | NULL |               |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)
1st Method
mysql> alter table exam2 modify rno tinyint;
Query OK, 3 rows affected (0.53 sec)
Records: 3 Duplicates: 0 Warnings: 0
2nd Method
mysql> alter table exam2 change rno rno tinyint;
Query OK, 3 rows affected (0.53 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> desc exam2;
+---------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| rno | tinyint(4) | YES | | NULL |               |
| name | varchar(20) | YES | | NULL |                 |
| math | tinyint(4) | YES | | NULL |                |
| address | varchar(20) | YES | | NULL |               |
+---------+-------------+------+-----+---------+-------+
4 rows in set (0.02 sec)
(iii) Changing name of a column in existing table
mysql> select * from exam1;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.00 sec)
mysql> alter table exam1 change rno roll int;
Query OK, 0 rows affected (0.23 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> select * from exam1;
+------+---------+------+------+------+
| roll | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.00 sec)
(iv) Deleting column from existing table
mysql> desc exam2;
+---------+-------------+------+-----+---------+-------
| Field | Type        | Null | Key | Default | Extra
+---------+-------------+------+-----+---------+-------
| rno | tinyint(4) | YES | | NULL |
| name | varchar(20) | YES | | NULL |
| math | tinyint(4) | YES | | NULL |
| address | varchar(20) | YES | | NULL |
+---------+-------------+------+-----+---------+-------
4 rows in set (0.06 sec)
mysql> alter table exam2 drop column address;
Query OK, 3 rows affected (1.61 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> desc exam2;
+-------+-------------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| rno | tinyint(4) | YES | | NULL |              |
| name | varchar(20) | YES | | NULL |                |
| math | tinyint(4) | YES | | NULL |               |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.03 sec)
(v) Adding constraints in a column of existing table
mysql> desc exam2;
+-------+-------------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| rno | tinyint(4) | YES | | NULL |              |
| name | varchar(20) | YES | | NULL |               |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| math | tinyint(4) | YES | | NULL |              |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.03 sec)
mysql> alter table exam2 ADD constraint primary key(rno);
Query OK, 3 rows affected (0.34 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> desc exam2;
+-------+-------------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| rno | tinyint(4) | NO | PRI | 0        |    |
| name | varchar(20) | YES | | NULL |               |
| math | tinyint(4) | YES | | NULL |              |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.03 sec)
mysql> insert into exam2(name,math) values('Gagan',87);
Query OK, 1 row affected (0.20 sec)
mysql> select * from exam;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.33 sec)
mysql> select * from exam2;
+-----+---------+------+
| rno | name | math |
+-----+---------+------+
| 0 | Gagan | 87 |
| 1 | Amar | 75 |
| 2 | Prakash | 81 |
| 3 | Suresh | 47 |
+-----+---------+------+
4 rows in set (0.00 sec)
mysql> insert into exam2(name,math) values('Mahesh',77);
ERROR 1062 (23000): Duplicate entry '0' for key 'PRIMARY'
mysql>
(v) Enabling / Disabling constraints in a column of existing table
mysql> select * from exam2;
+-----+---------+------+
| rno | name | math |
+-----+---------+------+
| 0 | Gagan | 87 |
| 1 | Amar | 75 |
| 2 | Prakash | 81 |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| 3 | Suresh | 47 |
+-----+---------+------+
4 rows in set (0.00 sec)
mysql> desc exam2;
+-------+-------------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| rno | tinyint(4) | NO | PRI | 0         |    |
| name | varchar(20) | YES | | NULL |               |
| math | tinyint(4) | YES | | NULL |              |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.73 sec)
mysql> alter table exam2 drop primary key;
Query OK, 4 rows affected (0.78 sec)
Records: 4 Duplicates: 0 Warnings: 0
mysql> desc exam2;
+-------+-------------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| rno | tinyint(4) | NO | | 0          |     |
| name | varchar(20) | YES | | NULL |               |
| math | tinyint(4) | YES | | NULL |              |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
vi) Changing storage engine in already existing table
mysql> show create table workers;
| Table | Create Table
+---------+---------------------------------------------------------------------
| workers | CREATE TABLE `workers` (`ecode` smallint(6) DEFAULT NULL, `ename` char(20)
DEFAULT NULL, `sal` float(7,2) DEFAULT NULL ) ENGINE=InnoDB DEFAULT
CHARSET=latin1 |
---------------------------------------------------------------------------------
1 row in set (0.00 sec)
mysql> alter table workers engine=MyIsam;
Query OK, 2 rows affected (0.30 sec)
Records: 2 Duplicates: 0 Warnings: 0
(e) Using constraints while creating a table:
 (i) Unique Constraints:
mysql> create table fees(rno int NOT NULL unique, name varchar(20), fee Float(6,2));
Query OK, 0 rows affected (0.16 sec)
mysql> insert into fees values(1,'Trishul',1920.00);
Query OK, 1 row affected (0.25 sec)
mysql> insert into fees values(2,'Abhijeet',1920.00);
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
Query OK, 1 row affected (0.03 sec)
mysql> insert into fees values(1,'Rishabh',1920.00);
ERROR 1062 (23000): Duplicate entry '1' for key 'rno'
(ii) Using NULL/NOT NULL:
mysql> create table exam6(rno integer NOT NULL, name varchar(20),marks int);
Query OK, 0 rows affected (1.50 sec)
mysql> desc exam6;
+-------+-------------+------+-----+---------+-------+
| Field | Type           | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| rno | int(11)         | NO | | NULL |             |
| name | varchar(20) | YES | | NULL |                 |
| marks | int(11)      | YES | | NULL |             |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
mysql> insert into exam6 values(1,'Amar',85);
Query OK, 1 row affected (0.13 sec)
mysql> insert into exam6 values(2,'Jai’);
Error
mysql> insert into exam6(rno,name) values(2,'Jai');
Query OK, 1 row affected (0.16 sec)
mysql> insert into exam6(rno,marks) values(3,97);
Query OK, 1 row affected (0.05 sec)
mysql> insert into exam6(name,marks) values('Deepak',77);
ERROR 1364 (HY000): Field 'rno' doesn't have a default value
(c) Using DEFAULT:
mysql> create table exam5(rno integer,name varchar(20),marks integer default 0);
Query OK, 0 rows affected (0.36 sec)
mysql> insert into exam5 values(1,'Gagan',58);
Query OK, 1 row affected (0.11 sec)
mysql> insert into exam5(rno,marks) values(2,58);
Query OK, 1 row affected (0.05 sec)
mysql> insert into exam5(rno,name) values(3,'Sandeep');
Query OK, 1 row affected (0.03 sec)
mysql> select * from exam5;
+------+---------+-------+
| rno | name | marks |
+------+---------+-------+
| 1 | Gagan | 58 |
| 2 | NULL | 58 |
| 3 | Sandeep | 0 |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
+------+---------+-------+
3 rows in set (0.08 sec)
Note : To view All tables created in a database we use show tables command.
mysql> show tables;
+-------------------+
| Tables_in_pradeep |
+-------------------+
| exam               |
| exam1                |
| exam2                |
| exam3                |
| exam4                |
| exam6                |
| fees          |
| shop             |
| store           |
+-------------------+
9 rows in set (0.31 sec)
(d) Using PRIMARY KEY Constraint
mysql> create table shop(pid integer NOT NULL primary key, pname varchar(20), price double)
Engine=InnoDB;
Query OK, 0 rows affected (0.23 sec)
(e) Using Foreign Key Constraint
mysql> create table store(sid integer,sname varchar(20), loc varchar(20), pid integer, Foreign
Key(pid) references shop(pid)) engine=InnoDB;
Query OK, 0 rows affected (0.69 sec)
(f) Using CHECK constraint
(i) Column Constraints (Applying check in single column)
mysql> create table workers(ecode smallint, ename char(20), sal float(7,2) CHECK (sal>2000));
Query OK, 0 rows affected (0.19 sec)
Mysql> insert into workers values(1,”A”,2500)
Mysql> insert into workers values(2,”B”,1500)
Error
(ii) Table Constraints (Applying check in multiple column)
mysql> create table item (icode integer, descp char(20),ROL integer, QOH integer, check(ROL<QOH));
Query OK, 0 rows affected (0.22 sec)
Insert into item values(1,”A”,50,60)
Insert into item values(2,”B”,70,60)
Error
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
Note: Applying unique as table constant can be represented as : unique(icode,descp)
g) Naming a constraint
1) mysql> alter table exam2 ADD CONSTRAINT pk1 PRIMARY KEY(rno);
Query OK, 4 rows affected (1.14 sec)
Records: 4 Duplicates: 0 Warnings: 0
2) mysql> alter table OFFICE ADD CONSTRAINT fk1 FOREIGN KEY(EMPNO);
Note: Dropping a constraint/ Enabling -Disabling can be done using constraint name:
1. mysql> alter table exam2 DROP FOREIGN KEY fk1;
2.mysql> alter table exam2 DROP PRIMARY KEY pk1;
Query OK, 4 rows affected (0.20 sec)
Records: 4 Duplicates: 0 Warnings: 0
6. Viewing of Records:
a)       Viewing all records with all fields:
mysql> select * from exam;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.92 sec)
b)       Viewing of all records but with selected field:
mysql> select rno,name,phy from exam;
+------+---------+------+
| rno | name | phy |
+------+---------+------+
| 1 | Amar | 82 |
| 2 | Prakash | 76 |
| 3 | Suresh | 61 |
+------+---------+------+
3 rows in set (0.03 sec)
c)     Viewing of record with required Label:
mysql> select rno "ROLL NO.",name "STUDENTS NAME",math "MATHEMATICS" from exam;
| ROLL NO. | STUDENTS NAME | MATHEMATICS |
+----------+---------------+-------------+
|     1 | Amar         |       75 |
|     2 | Prakash       |      81 |
|     3 | Suresh       |      47 |
+----------+---------------+-------------+
3 rows in set (0.02 sec)
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
d) Viewing a particular record (using where clause):
mysql> select * from exam where rno=2;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 2 | Prakash | 81 | 76 | 62 |
+------+---------+------+------+------+
1 row in set (0.03 sec)
e) Viewing records arranging fields of table as per user’s choice :
mysql> select rno,math,name from exam;
+------+------+---------+
| rno | math | name |
+------+------+---------+
| 1 | 75 | Amar |
| 2 | 81 | Prakash |
| 3 | 47 | Suresh |
+------+------+---------+
3 rows in set (0.02 sec)
f) Viewing of records using relational operators(<, <= , > , >= , = , < > or !=)
(i) mysql> select * from exam where rno>2;
+------+--------+------+------+------+
| rno | name | math | phy | chem |
+------+--------+------+------+------+
| 3 | Suresh | 47 | 61 | 45 |
+------+--------+------+------+------+
1 row in set (0.02 sec)
(ii) mysql> select * from exam where rno<>2;
+------+--------+------+------+------+
| rno | name | math | phy | chem |
+------+--------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 3 | Suresh | 47 | 61 | 45 |
+------+--------+------+------+------+
2 rows in set (0.00 sec)
                 OR
mysql> select * from exam where rno!=2;
+------+--------+------+------+------+
| rno | name | math | phy | chem |
+------+--------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 3 | Suresh | 47 | 61 | 45 |
+------+--------+------+------+------+
2 rows in set (0.00 sec)
f1) Using Distinct
mysql> select distinct name from exam;
+---------+
| name |
+---------+
| Amar |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| Prakash |
| Suresh |
+---------+
3 rows in set (0.00 sec)
g) Viewing of records using LOGICAL operators(AND,OR,NOT)
mysql> select * from exam;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.00 sec)
(i) mysql> select * from exam where math>=75 AND phy>=75 AND chem>=75;
+------+------+------+------+------+
| rno | name | math | phy | chem |
+------+------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
+------+------+------+------+------+
1 row in set (0.05 sec)
(ii) mysql> select * from exam where math>=90 OR phy>=90 OR chem>=90;
+------+------+------+------+------+
| rno | name | math | phy | chem |
+------+------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
+------+------+------+------+------+
1 row in set (0.00 sec)
(iii) mysql> select * from exam where NOT CHEM>=90;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
2 rows in set (0.00 sec)
h) Viewing of records using Range(using BETWEEN , NOT BETWEEN):
mysql> select * from exam where math BETWEEN 60 AND 80;
+------+------+------+------+------+
| rno | name | math | phy | chem |
+------+------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
+------+------+------+------+------+
1 row in set (0.05 sec)
(ii) mysql> select * from exam where math NOT BETWEEN 60 AND 80;
+------+---------------+------+------+------+
| rno | name         | math | phy | chem |
+------+---------------+------+------+------+
| 2 | PRAKASH MEHRA | 81 | 76 | 62 |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| 3 | SURESH PRASAD | 47 | 61 | 45 |
+------+---------------+------+------+------+
2 rows in set (1.39 sec)
i) Viewing of Records using list(Use of IN):
mysql> select * from exam where rno IN(1,3);
+------+--------+------+------+------+
| rno | name | math | phy | chem |
+------+--------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 3 | Suresh | 47 | 61 | 45 |
+------+--------+------+------+------+
2 rows in set (0.00 sec)
j) Viewing of records using LIKE(Using % and -):
(i) mysql> select * from exam where name LIKE 'P%';
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 2 | Prakash | 81 | 76 | 62 |
+------+---------+------+------+------+
1 row in set (0.03 sec)
(ii) mysql> select * from exam where name LIKE "%h";
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
2 rows in set (1.52 sec)
(iii) mysql> select * from exam where name LIKE "_ _ _ _";
+------+------+------+------+------+
| rno | name | math | phy | chem |
+------+------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
+------+------+------+------+------+
1 row in set (0.00 sec)
(iv) mysql> select * from exam where math LIKE "_5";
+------+------+------+------+------+
| rno | name | math | phy | chem |
+------+------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
+------+------+------+------+------+
1 row in set (0.02 sec)
k) Arranging records in Ascending/Descending order of selected records
(i) Viewing records in “ascending order” of marks obtained in math
mysql> select * from exam order by math;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
+------+---------+------+------+------+
| 3 | Suresh | 47 | 61 | 45 |
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
+------+---------+------+------+------+
3 rows in set (0.00 sec)
(ii) Viewing records in “descending order” of marks obtained in math
mysql> select * from exam order by math desc;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 2 | Prakash | 81 | 76 | 62 |
| 1 | Amar | 75 | 82 | 91 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.00 sec)
Creating table for Applying Group By And Joins
mysql> create table shop(pid integer, pname varchar(20), price double, SID Integer) Engine=InnoDB;
Query OK, 0 rows affected (2.03 sec)
mysql> desc shop;
+-------+-------------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| pid | int(11) | NO | PRI | NULL |                |
| pname | varchar(20) | YES | | NULL |               |
| price | double     | YES | | NULL |             |
| SID | int(11) | YES | | NULL |                 |
+-------+-------------+------+-----+---------+-------+
4 rows in set (0.14 sec)
mysql> insert into shop values(1,'Lux',18.00, 222);
Query OK, 1 row affected (0.16 sec)
mysql> insert into shop values(2,'Dettol',16.00, 333);
Query OK, 1 row affected (0.03 sec)
mysql> insert into shop values(3,'Lifebuoy',14.00,111);
Query OK, 1 row affected (0.05 sec)
mysql> insert into shop values(4,'Ponds',19.00,333);
Query OK, 1 row affected (0.06 sec)
mysql> insert into shop values(5,'Dove',38.00,222);
Query OK, 1 row affected (0.03 sec)
mysql> select * from shop;
+-----+----------+-------+------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| pid | pname | price | SID |
+-----+----------+-------+------+
| 1 | Lux     | 18 | 222 |
| 2 | Dettol | 16 | 333 |
| 3 | Lifebuoy | 14 | 111 |
| 4 | Ponds | 19 | 333 |
| 5 | Dove | 38 | 222 |
+-----+----------+-------+------+
5 rows in set (0.20 sec)
mysql> create table store(SID Integer, sname varchar(20), loc varchar(20));
Query OK, 0 rows affected (2.25 sec)
mysql> insert into store values(111,'Deepak Stores','New Delhi');
Query OK, 1 row affected (0.16 sec)
mysql> insert into store values(222,'Arpan Stores','Patna');
Query OK, 1 row affected (0.02 sec)
mysql> insert into store values(333,'Ayangar Stores','Chennai');
Query OK, 1 row affected (0.05 sec)
mysql> select * from store;
+------+----------------+-----------+
| SID | sname          | loc    |
+------+----------------+-----------+
| 111 | Deppak Stores | New Delhi |
| 222 | Arpan Stores | Patna |
| 333 | Ayangar Stores | Chennai |
+------+----------------+-----------+
3 rows in set (0.05 sec)
Why two tables? Due to concept of Normalisation because it saves memory and data can be handled
efficiently.
Let 1000 records are to be stored.
In case of 01 table (06 columns-pid,pname,price,sid,sname,loc) :
No of entries required =1000x06=6000 entries.
In case 02 tables(1st table shop – 04 column pid,pname,price, sid, 2nd table – 03 column
sid,sname,loc)
No of entries required for 1st table =1000x04=4000 entries.
No of entries required for 2nd table =03*03=09 entries.
Total No of entries required for two table =4000+09=4009 entries.
Saving=6000-4009=1991 entries
(l) Using Group by:
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
(a) Viewing details from table shop using aggregate function and group by SID
mysql> select SID,sum(price) from shop GROUP BY SID;
+------+------------+
| SID | sum(price) |
+------+------------+
| 111 |      14 |
| 222 |      56 |
| 333 |      35 |
+------+------------+
3 rows in set (0.02 sec)
(b) counting no. of records in each group
mysql> select sid, count(*) from shop group by SID;
+------+----------+
| sid | count(*) |
+------+----------+
| 111 |      1|
| 222 |      2|
| 333 |      2|
+------+----------+
3 rows in set (0.06 sec)
(c) Use of having clause in group by
mysql> select SID,sum(price) from shop GROUP BY SID having SID=222;
+------+------------+
| SID | sum(price) |
+------+------------+
| 222 |      56 |
+------+------------+
1 row in set (0.64 sec)
(J) Using SQL as calculator
mysql> select 4*3;
+-----+
| 4*3 |
+-----+
| 12 |
1 row in set (0.05 sec)
 (K) Use of delete to remove records from table
(i) To remove all records of table exam4
mysql> delete from exam4;
Query OK, 2 rows affected (0.39 sec)
mysql> select * from exam4;
Empty set (0.01 sec)
(ii) To remove particular record of table exam5
mysql> delete from exam5 where rno=3;
Query OK, 1 row affected (0.11 sec)
(iii) To remove all records of table exam6 coming under a range
mysql> delete from exam6 where rno>=2 AND rno<=3;
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
Query OK, 2 rows affected (0.09 sec)
(L) Creating VIEW of table
(i) Creating view of all records with all fields
mysql> create view chk1 as select * from exam;
Query OK, 0 rows affected (2.84 sec)
mysql> select * from chk1;
+------+---------+------+------+------+
| rno | name | math | phy | chem |
+------+---------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
| 2 | Prakash | 81 | 76 | 62 |
| 3 | Suresh | 47 | 61 | 45 |
+------+---------+------+------+------+
3 rows in set (0.33 sec)
(ii) Creating view of all records with selected fields
mysql> create view chk2 as select rno,name,math from exam;
Query OK, 0 rows affected (0.05 sec)
mysql> select * from chk2;
+------+---------+------+
| rno | name | math |
+------+---------+------+
| 1 | Amar | 75 |
| 2 | Prakash | 81 |
| 3 | Suresh | 47 |
+------+---------+------+
3 rows in set (0.03 sec)
(iii) Creating view of selected records with all fields
mysql> create view chk3 as select * from exam where chem>=90;
Query OK, 0 rows affected (0.17 sec)
mysql> select * from chk3;
+------+------+------+------+------+
| rno | name | math | phy | chem |
+------+------+------+------+------+
| 1 | Amar | 75 | 82 | 91 |
+------+------+------+------+------+
1 row in set (0.08 sec)
(N) USING JOINS
(a) Viewing PID,PNAME,PRICE from table shop and SNAME,LOC from table store:
mysql> select pid,pname,price,sname,loc from shop,store where shop.sid=store.sid;
+-----+----------+-------+----------------+-----------+
| pid | pname | price | sname           | loc     |
+-----+----------+-------+----------------+-----------+
| 1 | Lux     | 18 | Arpan Stores | Patna |
| 2 | Dettol | 16 | Ayangar Stores | Chennai |
| 3 | Lifebuoy | 14 | Deppak Stores | New Delhi |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| 4 | Ponds | 19 | Ayangar Stores | Chennai |
| 5 | Dove | 38 | Arpan Stores | Patna |
+-----+----------+-------+----------------+-----------+
5 rows in set (0.45 sec)
(b) Viewing PID,PNAME,PRICE,SID from table shop and SNAME,LOC from table store:
Note: When content of a table whose column is present in both tables (SID) have to printed then we
have to explicitly specify the name of table from which it has to be printed otherwise following will
happen as shown below:
mysql> select pid,pname,price,sid,sname,loc from shop,store where shop.sid=store.sid;
ERROR 1052 (23000): Column 'sid' in field list is ambiguous
Correct Method:
mysql> select pid,pname,price,shop.sid,sname,loc from shop,store where shop.sid=store.sid;
+-----+----------+-------+------+----------------+-----------+
| pid | pname | price | sid | sname           | loc    |
+-----+----------+-------+------+----------------+-----------+
| 1 | Lux     | 18 | 222 | Arpan Stores | Patna |
| 2 | Dettol | 16 | 333 | Ayangar Stores | Chennai |
| 3 | Lifebuoy | 14 | 111 | Deppak Stores | New Delhi |
| 4 | Ponds | 19 | 333 | Ayangar Stores | Chennai |
| 5 | Dove | 38 | 222 | Arpan Stores | Patna |
+-----+----------+-------+------+----------------+-----------+
5 rows in set (0.00 sec)
(c) Viewing PID,PNAME,PRICE,SID from table shop and SNAME,LOC from table store for
Product Name “PONDS”:
mysql> select pid,pname,price,shop.sid,sname,loc from shop,store where pname="Ponds" AND
shop.sid=store.sid;
+-----+-------+-------+------+----------------+---------+
| pid | pname | price | sid | sname         | loc |
+-----+-------+-------+------+----------------+---------+
| 4 | Ponds | 19 | 333 | Ayangar Stores | Chennai |
+-----+-------+-------+------+----------------+---------+
1 row in set (0.41 sec)
(d) Using table alias in joins
mysql> select pid, pname, price,A.sid, sname,loc from shop A, store B where pname="Ponds" AND
A.sid=B.sid;
+-----+-------+-------+------+----------------+---------+
| pid | pname | price | sid | sname         | loc |
+-----+-------+-------+------+----------------+---------+
| 4 | Ponds | 19 | 333 | Ayangar Stores | Chennai |
+-----+-------+-------+------+----------------+---------+
1 row in set (0.01 sec)
(e) Viewing records in case of joins in sorted manner
mysql> select pid,pname,price,A.sid,sname,loc from shop A,store B where A.sid=B.
sid order by price;
+-----+----------+-------+------+----------------+-----------+
| pid | pname | price | sid | sname           | loc    |
+-----+----------+-------+------+----------------+-----------+
| 3 | Lifebuoy | 14 | 111 | Deppak Stores | New Delhi |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| 2 | Dettol | 16 | 333 | Ayangar Stores | Chennai |
| 1 | Lux     | 18 | 222 | Arpan Stores | Patna |
| 4 | Ponds | 19 | 333 | Ayangar Stores | Chennai |
| 5 | Dove | 38 | 222 | Arpan Stores | Patna |
+-----+----------+-------+------+----------------+-----------+
5 rows in set (0.02 sec)
(O) SUB-QUERY
(i) Viewing all record of table shop whose SID is same as that of pname as “LUX”.
Method 1:(Using Normal Query method not using SUB QUERY)
mysql> select sid from shop where pname="LUX";
+------+
| sid |
+------+
| 222 |
+------+
1 row in set (0.00 sec)
mysql> select * from shop where sid=222;
+-----+-------+-------+------+
| pid | pname | price | SID |
+-----+-------+-------+------+
| 1 | Lux | 18 | 222 |
| 5 | Dove | 38 | 222 |
+-----+-------+-------+------+
2 rows in set (0.02 sec)
Method 2: (Using Sub-Query)
mysql> select * from shop where sid= (select sid from shop where pname="LUX");
+-----+-------+-------+------+
| pid | pname | price | SID |
+-----+-------+-------+------+
| 1 | Lux | 18 | 222 |
| 5 | Dove | 38 | 222 |
+-----+-------+-------+------+
2 rows in set (0.08 sec)
(b) Viewing those records of table shop whose price is more than average price of all products
mysql> select * from shop where price>=(select avg(price) from shop);
+-----+-------+-------+------+
| pid | pname | price | SID |
+-----+-------+-------+------+
| 5 | Dove | 38 | 222 |
+-----+-------+-------+------+
1 row in set (0.02 sec)
(c) Viewing record having maximum price
mysql> select * from shop where price=(select max(price) from shop);
+-----+-------+-------+------+
| pid | pname | price | SID |
+-----+-------+-------+------+
| 5 | Dove | 38 | 222 |
+-----+-------+-------+------+
1 row in set (0.03 sec)
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
(P) DROPPING A TABLE : It will remove both the table structure and the records
mysql> show tables;
+-------------------+
| Tables_in_pradeep |
+-------------------+
| chk1            |
| chk2            |
| chk3            |
| exam              |
| exam1               |
| exam2               |
| exam3               |
| exam4               |
| exam5               |
| exam6                |
| fees          |
| item           |
| shop            |
| store         |
| workers             |
+-------------------+
15 rows in set (0.69 sec)
mysql> drop table exam6;
Query OK, 0 rows affected (0.67 sec)
mysql> show tables;
+-------------------+
| Tables_in_pradeep |
+-------------------+
| chk1            |
| chk2            |
| chk3            |
| exam              |
| exam1               |
| exam2               |
| exam3               |
| exam4               |
| exam5               |
| fees          |
| item           |
| shop            |
| store         |
| workers             |
+-------------------+
14 rows in set (0.01 sec)
Q) TRUNCATE TABLE : It will remove all the records only (structure will remain as it is)
mysql> show tables;
+-------------------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| Tables_in_pradeep |
+-------------------+
| chk1            |
| chk2            |
| chk3            |
| exam              |
| exam1               |
| exam2               |
| exam3               |
| exam4               |
| fees          |
| item           |
| shop            |
| store         |
| workers             |
+-------------------+
13 rows in set (0.14 sec)
mysql> truncate table exam4;
Query OK, 0 rows affected (0.19 se
mysql> show tables;
+-------------------+
| Tables_in_pradeep |
+-------------------+
| chk1            |
| chk2            |
| chk3            |
| exam              |
| exam1               |
| exam2               |
| exam3               |
| exam4               |
| fees          |
| item           |
| shop            |
| store         |
| workers             |
+-------------------+
13 rows in set (0.00 sec)
Note : Table dropped can be retained using rollback but records deleted using truncate table
cannot be retained using rollback(If records are deleted using delete command than it can be
retained using rollback.)
(R) COMMIT : It finalises the transaction.
mysql> commit;
(S) ROLLBACK : It undo all the recent transaction done until the previous commit command.
mysql> rollback;
(T) SAVEPOINT: It is a point in a transaction, uptil which all changes have been saved
permanently.
mysql> savepoint A;
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
 (U) ROLLBACK TO : It undo all the transaction done upto specified savepoint.
 mysql> rollback to savepoint A;
  FUNCTIONS : A function is a special type of predefined command set that performs some
  operation and returns a single value.
  MYSQL functions can be categorized in two types:
1)               Single Row Functions : These operate on single row and returns one result per row.
2)               Multiple Row Functions : These operate on multiple row and returns one result only.
 A) SINGLE ROW FUNCTIONS:
                                        STRING FUNCTIONS
 mysql> SELECT * FROM EXAM;
 +------+---------------+------+------+------+
 | rno | name         | math | phy | chem |
 +------+---------------+------+------+------+
 | 1 | AMAR KUMAR | 75 | 82 | 91 |
 | 2 | PRAKASH MEHRA | 81 | 76 | 62 |
 | 3 | SURESH PRASAD | 47 | 61 | 45 |
 +------+---------------+------+------+------+
 3 rows in set (0.06 sec)
 1) CONCAT( )
 (i) mysql> select concat(name,math) from exam;
 +-------------------+
 | concat(name,math) |
 +-------------------+
 | AMAR KUMAR75           |
 | PRAKASH MEHRA81 |
 | SURESH PRASAD47 |
 +-------------------+
 3 rows in set (0.06 sec)
 (ii) mysql> select concat('Com','puter');
 +-----------------------+
 | concat('Com','puter') |
 +-----------------------+
 | Computer             |
 +-----------------------+
 1 row in set (0.03 sec)
 2) CHAR( ) :
 ASCII CODES :
 A=65,B=66,C=67,D=68,E=69,F=70…,Z=90                               (A-Z -------     65-90)
 a=97,b=98,c=99,d=100,…,z=122                       (a-z    ------- 97-122)
 0=48,1=49,2=50,3=51,…,9=57                         (0-9    ------- 48-57)
 Blank=32
 mysql> select char(70,65,67,69);
 +-------------------+
 | char(70,65,67,69) |
 +-------------------+
 By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| FACE             |
+-------------------+
1 row in set (0.00 sec)
mysql> select char(65,67.3,'69.3');
+----------------------+
| char(65,67.3,'69.3') |
+----------------------+
| ACE               |
+----------------------+
1 row in set, 1 warning (0.03 sec)
3) LOWER( )
a) mysql> select lcase(name) from exam;
+---------------+
| lcase(name) |
+---------------+
| amar kumar |
| prakash mehra |
| suresh prasad |
+---------------+
3 rows in set (0.13 sec)
b) mysql> select lower(name) from exam;
+---------------+
| lower(name) |
+---------------+
| amar kumar |
| prakash mehra |
| suresh prasad |
+---------------+
3 rows in set (0.02 sec)
mysql> select lower('HOW IS THAT?') ;
+-----------------------+
| lower('HOW IS THAT?') |
+-----------------------+
| how is that?         |
+-----------------------+
1 row in set (0.00 sec)
4) UPPER( )
mysql> select upper(name) from exam;
+---------------+
| upper(name) |
+---------------+
| AMAR KUMAR |
| PRAKASH MEHRA |
| SURESH PRASAD |
+---------------+
3 rows in set (0.00 sec)
mysql> select upper('how are you?') ;
+-----------------------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| upper('how are you?') |
+-----------------------+
| HOW ARE YOU?            |
+-----------------------+
1 row in set (0.00 sec)
(5) LPAD( )
(i) mysql> select lpad('hello',15,'*') ;
+----------------------+
| lpad('hello',15,'*') |
+----------------------+
| **********hello        |
+----------------------+
1 row in set (0.00 sec)
(ii) mysql> select lpad(name,25,'*') from exam;
+---------------------------+
| lpad(name,25,'*')         |
+---------------------------+
| ***************AMAR KUMAR |
| ************PRAKASH MEHRA |
| ************SURESH PRASAD |
+---------------------------+
3 rows in set (0.00 sec)
(6) RPAD( )
(i) mysql> select rpad(name,25,'*') from exam;
+---------------------------+
| rpad(name,25,'*')         |
+---------------------------+
| AMAR KUMAR*************** |
| PRAKASH MEHRA************ |
| SURESH PRASAD************ |
+---------------------------+
3 rows in set (0.00 sec)
(ii) mysql> select rpad('hello',15,'*') ;
+----------------------+
| rpad('hello',15,'*') |
+----------------------+
| hello**********        |
+----------------------+
1 row in set (0.00 sec)
(7) SUBSTR( ) / MID( ) / SUBSTRING( ) : It is used to extract specified no. of characters from
a position
mysql> select substr('ABCDEFG',3,4);
+-----------------------+
| substr('ABCDEFG',3,4) |
+-----------------------+
| CDEF                |
+-----------------------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
1 row in set (0.05 sec)
mysql> select mid('ABCDEFG',3,6);
+--------------------+
| mid('ABCDEFG',3,6) |
+--------------------+
| CDEFG              |
+--------------------+
1 row in set (0.00 sec)
mysql> select substring('ABCDEFG',3,6);
+--------------------------+
| substring('ABCDEFG',3,6) |
+--------------------------+
| CDEFG                   |
+--------------------------+
1 row in set (0.00 sec)
mysql> select substr(NAME,1,8) FROM exam;
+------------------+
| substr(NAME,1,8) |
+------------------+
| AMAR KUM               |
| PRAKASH              |
| SURESH P           |
+------------------+
3 rows in set (0.00 sec)
(8) LTRIM( )
(i) mysql> select ltrim('         Hello how are you?         ');
+-----------------------------------------------+
| ltrim('     Hello how are you?             ') |
+-----------------------------------------------+
| Hello how are you?                         |
+-----------------------------------------------+
1 row in set (0.02 sec)
(9) RTRIM( )
(i) mysql> select rtrim('         Hello how are you?         ');
+-----------------------------------------------+
| rtrim('     Hello how are you?             ') |
+-----------------------------------------------+
|      Hello how are you?                    |
+-----------------------------------------------+
1 row in set (0.00 sec)
(10) TRIM( )
mysql> select trim('         Hello how are you?        ');
+----------------------------------------------+
| trim('     Hello how are you?             ') |
+----------------------------------------------+
| Hello how are you?                         |
+----------------------------------------------+
1 row in set (0.01 sec)
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
(11) LENGTH( )
mysql> select length('Hello how are you?') ;
+------------------------------+
| length('Hello how are you?') |
+------------------------------+
|                   18 |
+------------------------------+
1 row in set (0.03 sec)
mysql> select name,length(name) from exam;
+---------------+--------------+
| name         | length(name) |
+---------------+--------------+
| AMAR KUMAR |                   10 |
| PRAKASH MEHRA |                  13 |
| SURESH PRASAD |                 13 |
+---------------+--------------+
3 rows in set (0.00 sec)
(12) INSTR( )
(i) mysql> select instr('CORPORATE FLOOR','OR');
+-------------------------------+
| instr('CORPORATE FLOOR','OR') |
+-------------------------------+
|                     2|
+-------------------------------+
1 row in set (0.01 sec)
13) LEFT( )
mysql> select left('USS/23/67/09',3);
+------------------------+
| left('USS/23/67/09',3) |
+------------------------+
| USS                |
+------------------------+
1 row in set (0.02 sec)
14) RIGHT( )
mysql> select right('USS/23/67/09',3);
+-------------------------+
| right('USS/23/67/09',3) |
+-------------------------+
| /09               |
+-------------------------+
1 row in set (0.00 sec)
                                    NUMERIC FUNCTIONS
(1) MOD ( )
mysql> select mod(11,2) "Modulus";
+---------+
| Modulus |
+---------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
|    1|
+---------+
1 row in set (0.03 sec)
mysql> select mod(54,7) ;
+---------+
| mod(54,7) |
+---------+
|    5 |
+---------+
1 row in set (0.03 sec)
(2) POWER( )
mysql> select power(5,2);
+--------+
| power(5,2)|
  |
+--------+
|   25 |
+--------+
1 row in set (0.00 sec)
mysql> select power(3,2) "Value";
+--------+
| Value|
+--------+
|   9|
+--------+
1 row in set (0.00 sec)
(3) ROUND( )
(i) mysql> select round(15.685,2) "Round";
+-------+
| Round |
+-------+
| 15.69 |
+-------+
1 row in set (0.02 sec)
mysql> select round(15.6853,3) "Round";
+-------+
| Round |
+-------+
| 15.685 |
+-------+
1 row in set (0.02 sec)
mysql> select round(15.6859,3) "Round";
+-------+
| Round |
+-------+
| 15.686 |
+-------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
1 row in set (0.02 sec)
mysql> select round(15.6859,1) "Round";
+-------+
| Round |
+-------+
| 15.7 |
+-------+
1 row in set (0.02 sec)
mysql> select round(15.6359,1) "Round";
+-------+
| Round |
+-------+
| 15.6 |
+-------+
1 row in set (0.02 sec)
mysql> select round(15.6859) "Round";
+-------+
| Round |
+-------+
| 16 |
+-------+
1 row in set (0.02 sec)
mysql> select round(15.3859) "Round";
+-------+
| Round |
+-------+
| 15 |
+-------+
1 row in set (0.02 sec)
(ii) mysql> select round(15.193,-1) "Round";
+-------+
| Round |
+-------+
| 20 |
+-------+
1 row in set (0.00 sec)
(iii) mysql> select round(178.193,-2) "Round";
+-------+
| Round |
+-------+
| 200 |
+-------+
1 row in set (0.00 sec)
(iv) mysql> select round(115.193,-2) "Round";
+-------+
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
| Round |
+-------+
| 100 |
+-------+
1 row in set (0.00 sec)
(4) SIGN( )
(i) mysql> select sign(0);
+---------+
| sign(0) |
+---------+
|     0|
+---------+
1 row in set (0.00 sec)
(ii) mysql> select sign(23);
+----------+
| sign(23) |
+----------+
|     1|
+----------+
1 row in set (0.00 sec)
(iii) mysql> select sign(-23);
+-----------+
| sign(-23) |
+-----------+
|      -1 |
+-----------+
1 row in set (0.00 sec)
(5) SQRT( )
mysql> select sqrt(25);
+----------+
| sqrt(25) |
+----------+
|      5|
+----------+
1 row in set (0.00 sec)
(6) TRUNC( )
(i) mysql> select truncate(15.79,1);
+-------------------+
| truncate(15.79,1) |
+-------------------+
|         15.7 |
+-------------------+
1 row in set (0.00 sec)
(ii) mysql> select truncate(15.79,2);
+-------------------+
| truncate(15.79,2) |
+-------------------+
|         15.79 |
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
+-------------------+
1 row in set (0.00 sec)
(iii) mysql> select truncate(15.79,-1);
+--------------------+
| truncate(15.79,-1) |
+--------------------+
|            10 |
+--------------------+
1 row in set (0.00 sec)
(iv) mysql> select truncate(15.79,-2);
+--------------------+
| truncate(15.79,-2) |
+--------------------+
|            0|
+--------------------+
1 row in set (0.00 sec)
(v) mysql> select truncate(115.79,-2);
+---------------------+
| truncate(115.79,-2) |
+---------------------+
|            100 |
+---------------------+
1 row in set (0.00 sec)
(vi) mysql> select truncate(115.79,0);
+--------------------+
| truncate(115.79,0) |
+--------------------+
|           115 |
+--------------------+
1 row in set (0.00 sec)
                                  DATE AND TIME FUNCTIONS
(i) CURDATE( ) : It Returns the current date.
    mysql> select curdate();
    +------------+
    | curdate() |
    +------------+
    | 2020-12-16 |
    +------------+
    1 row in set (0.03 sec)
(ii) DATE( ) : Extracts the date part of a date or datetime expression.
     mysql> select date('2009-12-31 01:01:03');
     +-----------------------------+
     | date('2009-12-31 01:01:03') |
     +-----------------------------+
     | 2009-12-31                |
     +-----------------------------+
     1 row in set (0.00 sec)
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
(iii) MONTH ( ) : Returns the month from the date
      mysql> select month('2009-12-31');
      +---------------------+
      | month('2009-12-31') |
      +---------------------+
      |            12 |
      +---------------------+
      1 row in set (0.00 sec)
(iv) YEAR( ) : Returns the year of the date.
     mysql> select year('2009-12-31');
     +--------------------+
     | year('2009-12-31') |
     +--------------------+
     |          2009 |
     +--------------------+
     1 row in set (0.01 sec)
(v) DAYNAME( ) : Returns the weekday name of the date.
mysql> select dayname('2020-12-14');
+-----------------------+
| dayname(‘2020-12-14’) |
+-----------------------+
| Friday             |
+-----------------------+
1 row in set (0.11 sec)
(vi) DAYOFMONTHNAME( ) : Returns the day of the month (1-31) of the date.
mysql> select dayofmonth('2011-05-06');
+--------------------------+
| dayofmonth('2011-05-06') |
+--------------------------+
|                 6|
+--------------------------+
1 row in set (0.06 sec)
(vii) DAYOFWEEK( ) : Returns the weekday index of the argument (date).
mysql> select dayofweek('2011-05-06');
+-------------------------+
| dayofweek('2011-05-06') |
+-------------------------+
|                6|
+-------------------------+
1 row in set (0.00 sec)
(viii) DAYOFYEAR( ) : Returns the Day of the YEAR(1-366)
mysql> select dayofyear('2011-05-06');
+-------------------------+
| dayofyear('2011-05-06') |
+-------------------------+
|               126 |
+-------------------------+
1 row in set (0.00 sec)
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow
31+28+31+30+6=126
(ix) NOW( ): Returns the current date and time.
mysql> select now();
+---------------------+
| now()            |
+---------------------+
| 2011-05-05 22:50:05 |
+---------------------+
1 row in set (0.09 sec).
(x) SYSDATE( ) : Returns the time which the function executes.
mysql> select sysdate();
+---------------------+
| sysdate()         |
+---------------------+
| 2011-05-05 22:53:24 |
+---------------------+
1 row in set (0.03 sec)
mysql> select now( ),sleep(2),now( );
2011-05-05 22:50:05 2011-05-05 22:50:05
mysql> select sysdate( ),sleep(5),sysdate( );
2011-05-05 22:50:05 2011-05-05 22:50:10
Note : Now( ) is not effected by sleep ( ) function but sysdate( ) gets effected by sleep( );
By : Pradeep Kumar Sarma, PGT(Computer Sc.), KV Lucknow Cantt.,Lucknow