You are on page 1of 12

Q.

1
select *
from emptemp
where ename regexp '.*AS$';
Empty set (0.04 sec)

mysql> select *
-> from emptemp
-> where ename regexp '.*ER$';

mysql> select *
-> from emptemp
-> where ename like '%ER';

+-------+--------+----------+------+------------+---------+------+--------+
| EMPNO | ENAME | job | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+----------+------+------------+---------+------+--------+
| 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 | 1725.00 | 0.00 | 30 |
| 7934 | MILLER | CLERK | 7782 | 1982-01-23 | 1495.00 | NULL | 10 |
+-------+--------+----------+------+------------+---------+------+--------+

###################################################################################
###

Q.2
select *
from emptemp
where ename regexp '^C.*K$';

select *
from emptemp
where ename like 'C%K';

+-------+-------+---------+------+------------+---------+------+--------+
| EMPNO | ENAME | job | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+-------+---------+------+------------+---------+------+--------+
| 7782 | CLARK | MANAGER | 7839 | 1981-06-09 | 2817.50 | NULL | 10 |
+-------+-------+---------+------+------------+---------+------+--------+

###################################################################################
###

Q.3
mysql> select *
-> from emptemp
-> where job regexp '..L.*M..';
+-------+--------+----------+------+------------+---------+---------+--------+
| EMPNO | ENAME | job | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+----------+------+------------+---------+---------+--------+
| 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 | 2116.00 | 300.00 | 30 |
| 7521 | WARD | SALESMAN | 7698 | 1981-02-22 | 1653.13 | 500.00 | 30 |
| 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 | 1653.13 | 1400.00 | 30 |
| 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 | 1725.00 | 0.00 | 30 |
+-------+--------+----------+------+------------+---------+---------+--------+

###################################################################################
######

Q.4
select *
from emp
where sal<>1250 and sal<>1100 and sal<>2850;
+-------+--------+-----------+------+------------+---------+--------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+-----------+------+------------+---------+--------+--------+
| 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800.00 | NULL | 20 |
| 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 | 1600.00 | 300.00 | 30 |
| 7566 | JONES | MANAGER | 7839 | 1981-04-02 | 2975.00 | NULL | 20 |
| 7782 | CLARK | MANAGER | 7839 | 1981-06-09 | 2450.00 | NULL | 10 |
| 7788 | SCOTT | ANALYST | 7566 | 1982-12-09 | 3000.00 | NULL | 20 |
| 7839 | KING | PRESIDENT | NULL | 1981-11-17 | 5000.00 | NULL | 10 |
| 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 | 1500.00 | 0.00 | 30 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 950.00 | NULL | 30 |
| 7902 | FORD | ANALYST | 7566 | 1981-12-03 | 3000.00 | NULL | 20 |
| 7934 | MILLER | CLERK | 7782 | 1982-01-23 | 1300.00 | NULL | 10 |
+-------+--------+-----------+------+------------+---------+--------+--------+

###################################################################################
######

Q.5
select *
from emp
where job regexp '^C.E.*K$';

+-------+--------+-------+------+------------+---------+------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+-------+------+------------+---------+------+--------+
| 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800.00 | NULL | 20 |
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1100.00 | NULL | 20 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 950.00 | NULL | 30 |
| 7934 | MILLER | CLERK | 7782 | 1982-01-23 | 1300.00 | NULL | 10 |
+-------+--------+-------+------+------------+---------+------+--------+

###################################################################################
######

Q.6
select *
from emp
where comm is null;
+-------+--------+-----------+------+------------+---------+------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+-----------+------+------------+---------+------+--------+
| 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800.00 | NULL | 20 |
| 7566 | JONES | MANAGER | 7839 | 1981-04-02 | 2975.00 | NULL | 20 |
| 7698 | BLAKE | MANAGER | 7839 | 1981-05-01 | 2850.00 | NULL | 30 |
| 7782 | CLARK | MANAGER | 7839 | 1981-06-09 | 2450.00 | NULL | 10 |
| 7788 | SCOTT | ANALYST | 7566 | 1982-12-09 | 3000.00 | NULL | 20 |
| 7839 | KING | PRESIDENT | NULL | 1981-11-17 | 5000.00 | NULL | 10 |
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1100.00 | NULL | 20 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 950.00 | NULL | 30 |
| 7902 | FORD | ANALYST | 7566 | 1981-12-03 | 3000.00 | NULL | 20 |
| 7934 | MILLER | CLERK | 7782 | 1982-01-23 | 1300.00 | NULL | 10 |
+-------+--------+-----------+------+------------+---------+------+--------+

###################################################################################
######
Q.7
select *
from emp
where sal is null and ename regexp '^S';
Empty set (0.00 sec)

###################################################################################
######

Q.8
select *
from emp
where job regexp '^.....$';
+-------+--------+-------+------+------------+---------+------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+-------+------+------------+---------+------+--------+
| 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800.00 | NULL | 20 |
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1100.00 | NULL | 20 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 950.00 | NULL | 30 |
| 7934 | MILLER | CLERK | 7782 | 1982-01-23 | 1300.00 | NULL | 10 |
+-------+--------+-------+------+------------+---------+------+--------+

###################################################################################
######

Q.9
select *
from emp
where ename regexp '^A' and job regexp '^.....$';

+-------+-------+-------+------+------------+---------+------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+-------+-------+------+------------+---------+------+--------+
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1100.00 | NULL | 20 |
+-------+-------+-------+------+------------+---------+------+--------+

###################################################################################
######

Q.10
select ename,sal,deptno
from emp
where deptno in(20,30,40);

+--------+---------+--------+
| ename | sal | deptno |
+--------+---------+--------+
| SMITH | 800.00 | 20 |
| ALLEN | 1600.00 | 30 |
| WARD | 1250.00 | 30 |
| JONES | 2975.00 | 20 |
| MARTIN | 1250.00 | 30 |
| BLAKE | 2850.00 | 30 |
| SCOTT | 3000.00 | 20 |
| TURNER | 1500.00 | 30 |
| ADAMS | 1100.00 | 20 |
| JAMES | 950.00 | 30 |
| FORD | 3000.00 | 20 |
+--------+---------+--------+

###################################################################################
######

Q.11
select ename NAME,job JOB,hiredate HIREDATE
from emp
where hiredate<'1986-12-31' and sal between 1200 and 2500;
+--------+----------+------------+
| NAME | JOB | HIREDATE |
+--------+----------+------------+
| ALLEN | SALESMAN | 1981-02-20 |
| WARD | SALESMAN | 1981-02-22 |
| MARTIN | SALESMAN | 1981-09-28 |
| CLARK | MANAGER | 1981-06-09 |
| TURNER | SALESMAN | 1981-09-08 |
| MILLER | CLERK | 1982-01-23 |
+--------+----------+------------+

###################################################################################
######

Q.12
select empno,ename,deptno
from emp
where mgr=7698;
+-------+--------+--------+
| empno | ename | deptno |
+-------+--------+--------+
| 7499 | ALLEN | 30 |
| 7521 | WARD | 30 |
| 7654 | MARTIN | 30 |
| 7844 | TURNER | 30 |
| 7900 | JAMES | 30 |
+-------+--------+--------+

###################################################################################
######

Q.13
select ename,job,sal
from emp
where deptno in(10,30);
+--------+-----------+---------+
| ename | job | sal |
+--------+-----------+---------+
| ALLEN | SALESMAN | 1600.00 |
| WARD | SALESMAN | 1250.00 |
| MARTIN | SALESMAN | 1250.00 |
| BLAKE | MANAGER | 2850.00 |
| CLARK | MANAGER | 2450.00 |
| KING | PRESIDENT | 5000.00 |
| TURNER | SALESMAN | 1500.00 |
| JAMES | CLERK | 950.00 |
| MILLER | CLERK | 1300.00 |
+--------+-----------+---------+

###################################################################################
######

Q.14
select *
from emp
where ename regexp '^A.*S$|^.N.*|^..N.*[NS]$';

select *
from emp
where ename regexp '^A.*S$|^.N.*N$|^..N.*N$|^.N.*S$|^..N.*S$';

Select *
from emp
where ename like 'A%S' or ename like '_N%n' or ename like '__N%n' or ename like '_N
%s' or ename like '__N%S';
+-------+-------+-------+------+------------+---------+------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+-------+-------+------+------------+---------+------+--------+
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1100.00 | NULL | 20 |
+-------+-------+-------+------+------------+---------+------+--------+

###################################################################################
######

Q.15
select *
from emp
where ename regexp '^_$';

###################################################################################
######

Q.16
select concat(ename,', ',deptno) as 'Emp info'
from emp;
+------------+
| Emp info |
+------------+
| SMITH, 20 |
| ALLEN, 30 |
| WARD, 30 |
| JONES, 20 |
| MARTIN, 30 |
| BLAKE, 30 |
| CLARK, 10 |
| SCOTT, 20 |
| KING, 10 |
| TURNER, 30 |
| ADAMS, 20 |
| JAMES, 30 |
| FORD, 20 |
| MILLER, 10 |
+------------+

###################################################################################
######

Q.17
select ename,deptno,hiredate
from emp
where hiredate between '1981-01-01' and '1983-03-31'
order by hiredate;
+--------+--------+------------+
| ename | deptno | hiredate |
+--------+--------+------------+
| ALLEN | 30 | 1981-02-20 |
| WARD | 30 | 1981-02-22 |
| JONES | 20 | 1981-04-02 |
| BLAKE | 30 | 1981-05-01 |
| CLARK | 10 | 1981-06-09 |
| TURNER | 30 | 1981-09-08 |
| MARTIN | 30 | 1981-09-28 |
| KING | 10 | 1981-11-17 |
| JAMES | 30 | 1981-12-03 |
| FORD | 20 | 1981-12-03 |
| MILLER | 10 | 1982-01-23 |
| SCOTT | 20 | 1982-12-09 |
| ADAMS | 20 | 1983-01-12 |
+--------+--------+------------+

###################################################################################
######

Q.18
select ename
NAME,concat(lower(substr(ename,2,4)),lower(substr(job,2,3)),'@mycompany.com') as
EMAIL
from emp;
+--------+-----------------------+
| NAME | EMAIL |
+--------+-----------------------+
| SMITH | mithler@mycompany.com |
| ALLEN | llenale@mycompany.com |
| WARD | ardale@mycompany.com |
| JONES | onesana@mycompany.com |
| MARTIN | artiale@mycompany.com |
| BLAKE | lakeana@mycompany.com |
| CLARK | larkana@mycompany.com |
| SCOTT | cottnal@mycompany.com |
| KING | ingres@mycompany.com |
| TURNER | urneale@mycompany.com |
| ADAMS | damsler@mycompany.com |
| JAMES | amesler@mycompany.com |
| FORD | ordnal@mycompany.com |
| MILLER | illeler@mycompany.com |
+--------+-----------------------+

###################################################################################
######

Q.19
select ename,deptno,hiredate
from emp
where hiredate between '1981-01-01' and '1983-03-31'
+--------+--------+------------+
| ename | deptno | hiredate |
+--------+--------+------------+
| ALLEN | 30 | 1981-02-20 |
| WARD | 30 | 1981-02-22 |
| JONES | 20 | 1981-04-02 |
| MARTIN | 30 | 1981-09-28 |
| BLAKE | 30 | 1981-05-01 |
| CLARK | 10 | 1981-06-09 |
| SCOTT | 20 | 1982-12-09 |
| KING | 10 | 1981-11-17 |
| TURNER | 30 | 1981-09-08 |
| ADAMS | 20 | 1983-01-12 |
| JAMES | 30 | 1981-12-03 |
| FORD | 20 | 1981-12-03 |
| MILLER | 10 | 1982-01-23 |
+--------+--------+------------+

###################################################################################
######

Q.20
delete
from emptemp
where deptno<>20 and deptno<>30;
mysql> select * from emptemp;
+-------+--------+--------------+------+------------+---------+---------+--------+
| EMPNO | ENAME | job | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+--------------+------+------------+---------+---------+--------+
| 7369 | SMITH | senior clerk | 7902 | 1980-12-17 | 920.00 | NULL | 20 |
| 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 | 2116.00 | 300.00 | 30 |
| 7521 | WARD | SALESMAN | 7698 | 1981-02-22 | 1653.13 | 500.00 | 30 |
| 7566 | JONES | MANAGER | 7839 | 1981-04-02 | 3421.25 | NULL | 20 |
| 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 | 1653.13 | 1400.00 | 30 |
| 7698 | BLAKE | MANAGER | 7839 | 1981-05-01 | 3277.50 | NULL | 30 |
| 7788 | SCOTT | ANALYST | 7566 | 1982-12-09 | 3450.00 | NULL | 20 |
| 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 | 1725.00 | 0.00 | 30 |
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1265.00 | NULL | 20 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 1092.50 | NULL | 30 |
| 7902 | FORD | ANALYST | 7566 | 1981-12-03 | 3450.00 | NULL | 20 |
+-------+--------+--------------+------+------------+---------+---------+--------+

###################################################################################
######

Q.21

###################################################################################
######

Q.22
update emptemp
set job='manager', mgr=7777
where deptno=20;
mysql> select * from emptemp;
+-------+--------+----------+------+------------+---------+---------+--------+
| EMPNO | ENAME | job | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+----------+------+------------+---------+---------+--------+
| 7369 | SMITH | manager | 7777 | 1980-12-17 | 920.00 | NULL | 20 |
| 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 | 2116.00 | 300.00 | 30 |
| 7521 | WARD | SALESMAN | 7698 | 1981-02-22 | 1653.13 | 500.00 | 30 |
| 7566 | JONES | manager | 7777 | 1981-04-02 | 3421.25 | NULL | 20 |
| 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 | 1653.13 | 1400.00 | 30 |
| 7698 | BLAKE | MANAGER | 7839 | 1981-05-01 | 3277.50 | NULL | 30 |
| 7788 | SCOTT | manager | 7777 | 1982-12-09 | 3450.00 | NULL | 20 |
| 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 | 1725.00 | 0.00 | 30 |
| 7876 | ADAMS | manager | 7777 | 1983-01-12 | 1265.00 | NULL | 20 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 1092.50 | NULL | 30 |
| 7902 | FORD | manager | 7777 | 1981-12-03 | 3450.00 | NULL | 20 |
+-------+--------+----------+------+------------+---------+---------+--------+

###################################################################################
######

Q.23

###################################################################################
######

Q.24
select ename,sal
from emp
where sal>2000;
+-------+---------+
| ename | sal |
+-------+---------+
| JONES | 2975.00 |
| BLAKE | 2850.00 |
| CLARK | 2450.00 |
| SCOTT | 3000.00 |
| KING | 5000.00 |
| FORD | 3000.00 |
+-------+---------+

###################################################################################
######

Q.25
create table trainer
(
tid int ,
tname varchar(15) NOT NULL,
cid int,
constraint pk_tid primary key (tid),
constraint fk_cid foreign key (cid) references course(cid)
);

insert into trainer


values(1,'dipali',11);

insert into trainer


values(2,'trupti',22);

insert into trainer


values(3,'dhanshree',33);

insert into trainer


values(4,'bakul',44);
insert into trainer
values(5,'roopali',55);

create table course


(
cid int ,
cname varchar(15)NOT NULL,
constraint pk_cid primary key (cid)
)

insert into course


values(11,'DBMS');

insert into course


values(22,'LINUX');

insert into course


values(33,'OS');

insert into course


values(44,'CORE JAVA');

insert into course


values(55,'SOFT. DEV');

mysql> alter table course


-> add column fees float(8,2);
Query OK, 0 rows affected, 1 warning (0.04 sec)
Records: 0 Duplicates: 0 Warnings: 1

mysql> select * from course;


+-----+-----------+------+
| cid | cname | fees |
+-----+-----------+------+
| 11 | DBMS | NULL |
| 22 | LINUX | NULL |
| 33 | OS | NULL |
| 44 | CORE JAVA | NULL |
| 55 | SOFT. DEV | NULL |
+-----+-----------+------+

###################################################################################
######

Q.26
select *
from emp
order by job ,sal ;
+-------+--------+-----------+------+------------+---------+---------+--------+
| EMPNO | ENAME | JOB | MGR | HIREDATE | SAL | COMM | DEPTNO |
+-------+--------+-----------+------+------------+---------+---------+--------+
| 7788 | SCOTT | ANALYST | 7566 | 1982-12-09 | 3000.00 | NULL | 20 |
| 7902 | FORD | ANALYST | 7566 | 1981-12-03 | 3000.00 | NULL | 20 |
| 7369 | SMITH | CLERK | 7902 | 1980-12-17 | 800.00 | NULL | 20 |
| 7900 | JAMES | CLERK | 7698 | 1981-12-03 | 950.00 | NULL | 30 |
| 7876 | ADAMS | CLERK | 7788 | 1983-01-12 | 1100.00 | NULL | 20 |
| 7934 | MILLER | CLERK | 7782 | 1982-01-23 | 1300.00 | NULL | 10 |
| 7782 | CLARK | MANAGER | 7839 | 1981-06-09 | 2450.00 | NULL | 10 |
| 7698 | BLAKE | MANAGER | 7839 | 1981-05-01 | 2850.00 | NULL | 30 |
| 7566 | JONES | MANAGER | 7839 | 1981-04-02 | 2975.00 | NULL | 20 |
| 7839 | KING | PRESIDENT | NULL | 1981-11-17 | 5000.00 | NULL | 10 |
| 7521 | WARD | SALESMAN | 7698 | 1981-02-22 | 1250.00 | 500.00 | 30 |
| 7654 | MARTIN | SALESMAN | 7698 | 1981-09-28 | 1250.00 | 1400.00 | 30 |
| 7844 | TURNER | SALESMAN | 7698 | 1981-09-08 | 1500.00 | 0.00 | 30 |
| 7499 | ALLEN | SALESMAN | 7698 | 1981-02-20 | 1600.00 | 300.00 | 30 |
+-------+--------+-----------+------+------------+---------+---------+--------+

###################################################################################
######

Q.27

create table location


(
locid int,
city varchar(15)not null,
constraint pk_locid primary key (locid)
);

insert into location


values(11,'Pune');
insert into location
values(22,'Ahmadnagar');
insert into location
values(33,'Mumbai');
insert into location
values(44,'Nashik');
insert into location
values(55,'Nagpur');

create table product


(
pid int unique,
pname varchar(10) ,
pcid int ,
constraint pk_pid primary key(pid)

);

insert into product


values(1,'pen',10);
insert into product
values(2,'Eraser',20);
insert into product
values(3,'jeans',20);
insert into product
values(4,'tShirt',20);
insert into product
values(5,'5star',30);

alter table product


add column locid int;
alter table product
add constraint fk_locid foreign key (locid) references location(locid) on delete
cascade ;

update product
set locid=11
where pid=1;
update product
set locid=22
where pid=2;
update product
set locid=33
where pid=3;
update product
set locid=44
where pid=4;
update product
set locid=55
where pid=5;

//if we delete no changes in location


mysql> delete
-> from product
-> where locid=11;
Query OK, 1 row affected (0.00 sec)

mysql> select * from location


-> ;
+-------+------------+
| locid | city |
+-------+------------+
| 11 | Pune |
| 22 | Ahmadnagar |
| 33 | Mumbai |
| 44 | Nashik |
| 55 | Nagpur |
+-------+------------+
5 rows in set (0.00 sec)

mysql> select * from product;


+-----+--------+------+-------+
| pid | pname | pcid | locid |
+-----+--------+------+-------+
| 2 | Eraser | 20 | 22 |
| 3 | jeans | 20 | 33 |
| 4 | tShirt | 20 | 44 |
| 5 | 5star | 30 | 55 |
+-----+--------+------+-------+

//if we delete from location we can see changes in product.


mysql> delete
-> from location
-> where locid=22;
Query OK, 1 row affected (0.00 sec)

mysql> select * from product;


+-----+--------+------+-------+
| pid | pname | pcid | locid |
+-----+--------+------+-------+
| 3 | jeans | 20 | 33 |
| 4 | tShirt | 20 | 44 |
| 5 | 5star | 30 | 55 |
+-----+--------+------+-------+
3 rows in set (0.00 sec)

mysql> select * from location;


+-------+--------+
| locid | city |
+-------+--------+
| 11 | Pune |
| 33 | Mumbai |
| 44 | Nashik |
| 55 | Nagpur |
+-------+--------+
4 rows in set (0.00 sec)

You might also like