Introduction to databases
Hannes Kinks
2016
IAG0582
What is database?
-
Organized collection of data
- Telephone number catalogue
- List of students
- Excel spreadsheet
- File on a disk
- Computer-based database
- Accessibility
- Flexibility
- Easy data manipulation
- Security
data:image/s3,"s3://crabby-images/2c93b/2c93b4376f771b94a77a1b8993eea068704ceac7" alt=""
Brief history
- Ancient times - organizing paper documents
- 60's - computerized systems
- network model
- hierarchical model
- 70's - relational model
- 80's - SQL language
- 90's - Web integration
- 00's - No-SQL
- ...
Database model
Item,Count,Price,Location
'Acer monitor 24"',3,200,Tallinn
'Lenovo keyboard',10,50,Tallinn
'Printer Xerox',5,300,Tartu
'Printer Xerox',4,295,Tallinn
data:image/s3,"s3://crabby-images/acf64/acf64ebb282dba06d50303f67919c1ef8592fcb1" alt=""
- Flat file
Hierarhical Database Model
- Tree-like structure
data:image/s3,"s3://crabby-images/3d007/3d0073e20e17cc54da38b1867768d5af5c8a066a" alt=""
Network Database Model
- Network
- multiple parent records
data:image/s3,"s3://crabby-images/6a0ed/6a0ed571946e2520281a26934e415e21c9be8939" alt=""
Relational Database Model
- Main concepts
- relations - tables
- attributes - columns
- tuples - rows
- domains - set of values (datatype)
- Simpler to use
- More flexible
- SQL
data:image/s3,"s3://crabby-images/dbb04/dbb04a63fac16403fafe03e7a1b79b686be73e51" alt=""
data:image/s3,"s3://crabby-images/ab42c/ab42cb6defe8f39d65832f13c73d9e0ddb20d014" alt=""
Relational database
- Relations between tables
- Primary key
- only one per table
- cannot be NULL
- unique
- Foreign key
- Primary key
- Associations
- One to One - 1..1
- One to Many - 1..*
- None to Many - 0..*
- Many to Many - *..*
data:image/s3,"s3://crabby-images/6c38f/6c38f286f9015c50cbeb792ca6b4d7584c092e96" alt=""
data:image/s3,"s3://crabby-images/dbb04/dbb04a63fac16403fafe03e7a1b79b686be73e51" alt=""
data:image/s3,"s3://crabby-images/69a6a/69a6a566e4fd982aafd1d37a23a9d6b41399b85a" alt=""
One Customer can place orders to many Orders
How to use databases?
- Database Management System - DBMS
- Administration of databases
- Query, create, update, delete
- Databases, tables, data
-
Examples:
- PostgreSQL
- MySql
- Oracle database
- Microsoft SQL
- ...
data:image/s3,"s3://crabby-images/765df/765df0e666fa1d38d9b0e4f237f9e8e6ff926441" alt=""
data:image/s3,"s3://crabby-images/eac32/eac328aed26109018543ac26966ee1bd86ec9fbb" alt=""
data:image/s3,"s3://crabby-images/441f0/441f06a1a7117c2ae368a82ab99c54108fc4d905" alt=""
data:image/s3,"s3://crabby-images/66b38/66b3882bdeccdee85ebed65c3e2c23fce5feeb67" alt=""
Database management system
data:image/s3,"s3://crabby-images/c395d/c395ddfd1d4c6bf5b9ddebc97deb7b76106070e9" alt=""
DBMS =/= Database
Database management system
data:image/s3,"s3://crabby-images/c395d/c395ddfd1d4c6bf5b9ddebc97deb7b76106070e9" alt=""
PostgreSQL
pgAdmin III
Your own C program
Estonian river data
Querying database
- Structured Query Language - SQL
- Special-purpose programming language
- ISO standard
- Data definition and manipulation
- SELECT
- CREATE
- INSERT
- UPDATE
- DELETE
Querying database
data:image/s3,"s3://crabby-images/49b9b/49b9b089ce853890a31d877947d3e87e2723337f" alt=""
data:image/s3,"s3://crabby-images/477c2/477c2ff3944726aa67245f66663f6404fea22c00" alt=""
Querying database
data:image/s3,"s3://crabby-images/b7be9/b7be97bbbd5673bdad6983be5929aa95715f9faa" alt=""
data:image/s3,"s3://crabby-images/4f6a8/4f6a84ad6ec6d18c728a140760fd953e9fc7a409" alt=""
Querying database
data:image/s3,"s3://crabby-images/8550b/8550bf1ea66da75b415dfe7c884a49335d9b56cb" alt=""
Examples
data:image/s3,"s3://crabby-images/5414a/5414ab5aa0f0d99075ecef72ac4d61b9d1a1d1f2" alt=""
Examples
Examples
data:image/s3,"s3://crabby-images/59c24/59c243725a91c0ec20b35f272b0a90672e5b1e63" alt=""
- GIS - Geographical Information System
data:image/s3,"s3://crabby-images/3f340/3f340a1d9288b8c0f753f890e31532bec87f71ff" alt=""
Home task
Class task
-- querying all columns and all rows
SELECT * FROM river;
-- limit the rows
SELECT * FROM river LIMIT 10;
-- limit the columns
SELECT id_river, name, length_km FROM river;
-- order the data by name
SELECT id_river, name, length_km FROM river ORDER BY name ASC LIMIT 10;
-- giving alias
SELECT id_river AS id, name, length_km FROM river ORDER BY id ASC LIMIT 10;
-- filtering by condition. Shorter than 10 km and name starts with "Ke"
SELECT id_jogi, joenimi, pikkus_km FROM joe_andmed
WHERE pikkus_km < 10 AND joenimi LIKE 'Ke%';
-- join
SELECT * FROM tableA JOIN tableB ON tableA.foreignKey = tableB.primaryKey;
data:image/s3,"s3://crabby-images/f727e/f727eee491b5000222345c24066effa8a86a176e" alt=""
Databases
By Hannes Kinks
Databases
- 1,836