SQL - Overview
SQL - Overview
SQL - Overview
SQL tutorial gives unique learning on Structured Query Language and it helps to make practice on
SQL commands which provides immediate results. SQL is a language of database, it includes
database creation, deletion, fetching rows and modifying rows etc.
SQL is an ANSI (American National Standards Institute) standard but there are many different
versions of the SQL language.
What is SQL?
SQL is Structured Query Language, which is a computer language for storing, manipulating and
retrieving data stored in relational database.
SQL is the standard language for Relation Database System. All relational database management
systems like MySQL, MS Access, Oracle, Sybase, Informix, postgres and SQL Server use SQL as
standard database language.
Also, they are using different dialects, such as:
Why SQL?
Allows users to access data in relational database management systems.
Allows users to define the data in database and manipulate that data.
Allows to embed within other languages using SQL modules, libraries & pre-compilers.
History:
1970 -- Dr. Edgar F. "Ted" Codd of IBM is known as the father of relational databases. He
described a relational model for databases.
1978 -- IBM worked to develop Codd's ideas and released a product named System/R.
1986 -- IBM developed the first prototype of relational database and standardized by ANSI.
The first relational database was released by Relational Software and its later becoming
Oracle.
SQL Process:
When you are executing an SQL command for any RDBMS, the system determines the best way to
carry out your request and SQL engine figures out how to interpret the task.
There are various components included in the process. These components are Query Dispatcher,
Optimization Engines, Classic Query Engine and SQL Query Engine, etc. Classic query engine handles
all non-SQL queries but SQL query engine won't handle logical files.
Following is a simple diagram showing SQL Architecture:
SQL Commands:
The
standard
SQL
databases
are
DELETE
These
be
groups
commands
classified
based
on
nature:
DDL - Data
Definition
Language:
Command
Description
CREATE
ALTER
DROP
Description
SELECT
INSERT
Creates a record
UPDATE
Modifies records
DELETE
Deletes records
Description
GRANT
REVOKE
and
into
their
What is RDBMS?
RDBMS stands for Relational Database Management System. RDBMS is the basis for SQL, and for all
modern database systems like MS SQL Server, IBM DB2, Oracle, MySQL, and Microsoft Access.
A Relational database management system (RDBMS) is a database management system (DBMS) that
is based on the relational model as introduced by E. F. Codd.
What is table?
The data in RDBMS is stored in database objects called tables. The table is a collection of related data
entries and it consists of columns and rows.
Remember, a table is the most common and simplest form of data storage in a relational database.
Following is the example of a CUSTOMERS table:
+----+----------+-----+-----------+----------+
| ID | NAME
| AGE | ADDRESS | SALARY
+----+----------+-----+-----------+----------+
| 1 | Ramesh
| 2 | Khilan
| 32 | Ahmedabad | 2000.00 |
| 25 | Delhi
| 3 | kaushik | 23 | Kota
| 4 | Chaitali | 25 | Mumbai
| 5 | Hardik
| 27 | Bhopal
| 6 | Komal
| 22 | MP
| 7 | Muffy
| 24 | Indore
| 1500.00 |
| 2000.00 |
| 6500.00 |
| 8500.00 |
| 4500.00 |
| 10000.00 |
+----+----------+-----+-----------+----------+
What is field?
Every table is broken up into smaller entities called fields. The fields in the CUSTOMERS table consist
of ID, NAME, AGE, ADDRESS and SALARY.
A field is a column in a table that is designed to maintain specific information about every record in
the table.
What is column?
A column is a vertical entity in a table that contains all information associated with a specific field in a
table.
For example, a column in the CUSTOMERS table is ADDRESS, which represents location description
and would consist of the following:
+-----------+
| ADDRESS |
+-----------+
| Ahmedabad |
| Delhi
| Kota
| Mumbai
| Bhopal
| MP
| Indore
|
|
|
+----+------+
zero value or a field that contains spaces. A field with a NULL value is one that has been left blank
during record creation.
SQL Constraints:
Constraints are the rules enforced on data columns on table. These are used to limit the type of data
that can go into a table. This ensures the accuracy and reliability of the data in the database.
Constraints could be column level or table level. Column level constraints are applied only to one
column where as table level constraints are applied to the whole table.
Following are commonly used constraints available in SQL:
NOT NULL Constraint: Ensures that a column cannot have NULL value.
DEFAULT Constraint: Provides a default value for a column when none is specified.
CHECK Constraint: The CHECK constraint ensures that all values in a column satisfy certain
conditions.
INDEX: Use to create and retrieve data from the database very quickly.
Data Integrity:
The following categories of the data integrity exist with each RDBMS:
Domain Integrity: Enforces valid entries for a given column by restricting the type, the format,
or the range of values.
Referential integrity: Rows cannot be deleted, which are used by other records.
User-Defined Integrity: Enforces some specific business rules that do not fall into entity,
domain or referential integrity.
Database Normalization
Database normalization is the process of efficiently organizing data in a database. There are two
reasons of the normalization process:
Eliminating redundant data, for example, storing the same data in more than one tables.
Both of these are worthy goals as they reduce the amount of space a database consumes and ensure
that data is logically stored. Normalization consists of a series of guidelines that help guide you in
creating a good database structure.
Normalization guidelines are divided into normal forms; think of form as the format or the way a
database structure is laid out. The aim of normal forms is to organize the database structure so that
it complies with the rules of first normal form, then second normal form, and finally third normal
form.
It's your choice to take it further and go to fourth normal form, fifth normal form, and so on, but
generally speaking, third normal form is enough.
There are many popular RDBMS available to work with. This tutorial gives a
brief overview of few most popular RDBMS. This would help you to compare
their basic features.
MySQL
MySQL is an open source SQL database, which is developed by Swedish
company MySQL AB. MySQL is pronounced "my ess-que-ell," in contrast
with SQL, pronounced "sequel."
MySQL is supporting many different platforms including Microsoft Windows,
the major Linux distributions, UNIX, and Mac OS X.
MySQL has free and paid versions, depending on its usage (noncommercial/commercial) and features. MySQL comes with a very fast,
multi-threaded, multi-user, and robust SQL database server.
History:
Windows version was released on 8 January 1998 for Windows 95 and NT.
Version 3.23: beta from June 2000, production release January 2001.
Version 4.0: beta from August 2002, production release March 2003 (unions).
Version 4.01: beta from August 2003, Jyoti adopts MySQL for database tracking.
Version 4.1: beta from June 2004, production release October 2004.
Version 5.0: beta from March 2005, production release October 2005.
Features:
High Performance.
High Availability.
Management Ease.
MS SQL Server
MS SQL Server is a Relational Database Management System developed by
Microsoft Inc. Its primary query languages are:
T-SQL.
ANSI SQL.
History:
1989 - Microsoft, Sybase, and Aston-Tate release SQL Server 1.0 for OS/2.
1990 - SQL Server 1.1 is released with support for Windows 3.0 clients.
2001 - Microsoft releases XML for SQL Server Web Release 1 (download).
2002 - Microsoft releases SQLXML 2.0 (renamed from XML for SQL Server).
Features:
High Performance.
High Availability.
Database mirroring.
Database snapshots.
CLR integration.
Service Broker.
DDL triggers.
Ranking functions.
XML integration.
TRY...CATCH.
Database Mail.
ORACLE
It is a very large and multi-user database management system. Oracle is a
relational database management system developed by 'Oracle Corporation'.
Oracle works to efficiently manage its resource, a database of information,
among the multiple clients requesting and sending data in the network.
It is an excellent database server choice for client/server computing. Oracle
supports all major operating systems for both clients and servers, including
MSDOS, NetWare, UnixWare, OS/2 and most UNIX flavors.
History:
Oracle began in 1977 and celebrating its 32 wonderful years in the industry
(from 1977 to 2009).
1977 - Larry Ellison, Bob Miner and Ed Oates founded Software Development
Laboratories to undertake development work.
1979 - Version 2.0 of Oracle was released and it became first commercial
relational database and first SQL database. The company changed its name to
Relational Software Inc. (RSI).
1983 - Oracle released version 3.0, rewritten in C language and ran on multiple
platforms.
1984 - Oracle version 4.0 was released. It contained features like concurrency
control - multi-version read consistency, etc.
1985 - Oracle version 4.0 was released. It contained features like concurrency
control - multi-version read consistency, etc.
2007 - Oracle has released Oracle11g. The new version focused on better
partitioning, easy migration etc.
Features:
Concurrency
Read Consistency
Locking Mechanisms
Quiesce Database
Portability
Self-managing database
SQL*Plus
ASM
Scheduler
Resource Manager
Data Warehousing
Materialized views
Bitmap indexes
Table compression
Parallel Execution
Analytic SQL
Data mining
Partitioning
MS ACCESS
This is one of the most popular Microsoft products. Microsoft Access is an
entry-level database management software. MS Access database is not only
an inexpensive but also powerful database for small-scale projects.
MS Access uses the Jet database engine, which utilizes a specific SQL
language dialect (sometimes referred to as Jet SQL).
MS Access comes with the professional edition of MS Office package. MS
Access has easy-to-use intuitive graphical interface.
1993 - Access 1.1 released to improve compatibility with inclusion the Access
Basic programming language.
2007 - Access 2007, a new database format was introduced ACCDB which
supports complex data types such as multi valued and attachment fields.
Features:
Users can create tables, queries, forms and reports and connect them together
with macros.
The import and export of data to many formats including Excel, Outlook, ASCII,
dBase, Paradox, FoxPro, SQL Server, Oracle, ODBC, etc.
There is also the Jet Database format (MDB or ACCDB in Access 2007), which
can contain the application and data in one file. This makes it very convenient to
distribute the entire application to another user, who can run it in disconnected
environments.
Microsoft Access offers parameterized queries. These queries and Access tables
can be referenced from other programs like VB6 and .NET through DAO or ADO.
The desktop editions of Microsoft SQL Server can be used with Access as an
alternative to the Jet Database Engine.