M Taimoor Khan
Course Objectives 1) Basic Concepts 2) Tools 3) Database architecture and design 4) Flow of data (DFDs) 5) Mappings (ERDs) 6) Formulating queries (Relational algebra) 7) Implementing Schema 8) Built-in Functions 9) Extracting data 10) Working with Joins 11) Normalization 12) Improving performance 13) Advanced topics
Extracting Data DML SHOW, DESCRIBE SELECT Projecting on certain columns o Applying conditions on records o Other KEYWORDS / OPERATORS
Student table stuIDstuNamecitypostCodeSem AftabIslamabad NaveedLahore KamalKarachi FawadMardan ZamanRawal pindi AdnanAttock FaisalHazro650002
Like Operator Q: Display the names and credits of CS programs SELECT crName, crCrdts, prName FROM course WHERE prName like '%CS‘;
Pattern Matching MySQL provides: standard SQL pattern matching; and regular expression pattern matching, similar to those used by Unix utilities such as vi, grep and sed. SQL Pattern matching: To perform pattern matching, use the LIKE or NOT LIKE comparison operators By default, patterns are case insensitive. Special Characters: _ Used to match any single character. % Used to match an arbitrary number of characters. 6
SELECT with Multi-conditions SELECT * FROM student WHERE city = ‘attock’; SELECT stuName, city FROM student WHERE postcode = 3344;
SELECT stuName, city FROM student WHERE stuName LIKE ‘%ali’ AND sem=4; SELECT * FROM student WHERE stuName = “salman” OR city = “Islamabad”;
SELECT * FROM student WHERE ( stuName LIKE “%ali%” OR stuName LIKE “%ghani%” ) AND sem = 4;
Not Operator Inverses the predicate’s value Q: list crCode, crName, prName with prName from other than MCS SELECT crCode, crName, prName FROM course WHERE not (prName = ‘MCS’)
SELECT crCode, crName, prName FROM course WHERE (prName != ‘MCS’)
The BETWEEN Operator Q: List the IDs of the students with course codes having marks between 70 and 80 SELECT stId, crCode, totMrks From ENROLL WHERE totMrks between 70 and 80
The IN Operator Checks in a list of values Q: Give the course names of MCS, BSTN, MS and BCS programs SELECT crName, prName From course Where prName in (‘MCS’, ‘BSTN’, ‘MS’, ‘BCS’)
“Order By” Clause Sorts the rows in a particular order SELECT select_list FROM table_source [ WHERE search_condition ] [ ORDER BY order_expression [ ASC | DESC ] [,……n] ]
ORDER BY It is used to arrange the result set on any of the columns in the result set Ordering can be applied in ascending or descending order SELECT crName, crCrdts, prName FROM course WHERE prName like '%CS‘ ORDER BY crName;
SELECT crName, crCrdts, prName FROM course WHERE prName like '%CS‘ ORDER BY crName ASC; SELECT crName, crCrdts, prName FROM course WHERE prName like '%CS‘ ORDER BY crName;
Group By Clause SELECT stName, avg(cgpa) as 'Average CGPA', max(cgpa) as 'Maximum CGPA' from student SELECT prName, max(cgpa) as ‘Max CGPA', min(cgpa) as ‘Min CGPA' FROM student GROUP BY prName
HAVING Clause We can restrict groups by using having clause; groups satisfying having condition will be selected
HAVING Clause SELECT select_list [ INTO new_table ] FROM table_source [ WHERE search_condition ] [ GROUP BY group_by_expression ] [ HAVING search_condition ] [ ORDER BY order_expression [ ASC | DESC ] ]
HAVING Example SELECT prName, min(cgpa), max(cgpa) FROM student GROUP BY prName HAVING max(cgpa) > 3
Working with NULLs NULL means missing value or unknown value. To test for NULL, you cannot use the arithmetic comparison operators, such as =,. Rather, you must use the IS NULL and IS NOT NULL operators instead. 21
Working with NULLs For example, to find all your dead pets (what a morbid example!) mysql> select name from pet where death IS NOT NULL; | name | | Bowser | row in set (0.01 sec) 22
More examples
Selecting Particular Columns mysql> select name, birth from pet; | name | birth | | Fluffy | | | Claws | | | Buffy | | | Fang | | | Bowser | | | Chirpy | | | Whistler | | | Slim | | rows in set (0.01 sec) 24
Sorting Data To sort a result, use an ORDER BY clause. For example, to view animal birthdays, sorted by date: 25 mysql> SELECT name, birth FROM pet ORDER BY birth; | name | birth | | Buffy | | | Claws | | | Slim | | | Whistler | | | Bowser | | | Chirpy | | | Fluffy | | | Fang | | rows in set (0.02 sec)
Sorting Data To sort in reverse order, add the DESC (descending keyword) 26 mysql> SELECT name, birth FROM pet ORDER BY birth DESC; | name | birth | | Fang | | | Fluffy | | | Chirpy | | | Bowser | | | Whistler | | | Slim | | | Claws | | | Buffy | | rows in set (0.02 sec)
Pattern Matching Example To find names beginning with ‘b’: mysql> SELECT * FROM pet WHERE name LIKE "b%"; | name | owner | species | sex | birth | death | | Buffy | Harold | dog | f | | NULL | | Bowser | Diane | dog | m | | |
Pattern Matching Example To find names ending with `fy': mysql> SELECT * FROM pet WHERE name LIKE "%fy"; | name | owner | species | sex | birth | death | | Fluffy | Harold | cat | f | | NULL | | Buffy | Harold | dog | f | | NULL |
Pattern Matching Example To find names containing a ‘w’: mysql> SELECT * FROM pet WHERE name LIKE "%w%"; | name | owner | species | sex | birth | death | | Claws | Gwen | cat | m | | NULL | | Bowser | Diane | dog | m | | | | Whistler | Gwen | bird | NULL | | NULL |
Pattern Matching Example To find names containing exactly five characters, use the _ pattern character: mysql> SELECT * FROM pet WHERE name LIKE "_____"; | name | owner | species | sex | birth | death | | Claws | Gwen | cat | m | | NULL | | Buffy | Harold | dog | f | | NULL |
Extracting Data DML SHOW, DESCRIBE SELECT Projecting on certain columns Applying conditions on records Other KEYWORDS / OPERATORS
Next Lecture Built-in Functions