• Tidak ada hasil yang ditemukan

RDBMS concepts and MS SQL Server

N/A
N/A
Protected

Academic year: 2023

Membagikan "RDBMS concepts and MS SQL Server"

Copied!
69
0
0

Teks penuh

(1)

MS SQL SERVER MS SQL SERVER

Mukesh A Pund Scientist

NISCAIR, New Delhi

(2)

DBMS/RDBMS Concepts

DBMS/RDBMS Concepts

(3)

Introduction to DBMS & RDBMS Introduction to DBMS & RDBMS

Purpose of Database Systems

View of Data

Data Models

Data Definition Language

Data Manipulation Language

Database Administrator

Database Users

Overall System Structure

(4)

Database Management System (DBMS) Database Management System (DBMS)

Database: Collection of interrelated data

Set of programs to access the data

DBMS contains information about a particular enterprise

DBMS provides an environment that is both convenient and efficient to use.

Database Applications:

Banking: all transactions

Library: Acquisition, Circulation, OPAC, Stock Verification, Serial control, Digital Library, Bibliographic databases, Union Catalogue etc.

Airlines: reservations, schedules

Universities: registration, grades

Sales: customers, products, purchases

Manufacturing: production, inventory, orders, supply chain

(5)

Purpose of Database System Purpose of Database System

In the early days, database applications were built on top of file systems

Drawbacks of using file systems to store data:

Data redundancy and inconsistency

Multiple file formats, duplication of information in different files

Difficulty in accessing data

Need to write a new program to carry out each new task

Data isolation — multiple files and formats

Integrity problems

Integrity constraints (e.g. account balance > 0) become part of program code

Hard to add new constraints or change existing ones

(6)

Purpose of Database Systems (Cont.) Purpose of Database Systems (Cont.)

Drawbacks of using file systems (cont.)

Atomicity of updates

Failures may leave database in an inconsistent state with partial updates carried out

E.g. transfer of funds from one account to another should either complete or not happen at all

Concurrent access by multiple users

Concurrent accessed needed for performance

Uncontrolled concurrent accesses can lead to inconsistencies

E.g. two people reading a balance and updating it at the same time

Security problems

(7)

Levels of Abstraction Levels of Abstraction

Physical level describes how a record (e.g., Member) is stored.

Logical level: describes data stored in database, and the relationships among the data.

type member = record

memno: Integer name : string;

street : string;

city : string;

end;

View level: application programs hide details of data types.

Views can also hide information (e.g., salary) for security purposes.

(8)

View of Data View of Data

An architecture for a database system

(9)

Instances and Schemas Instances and Schemas

Similar to types and variables in programming languages

Schema – the logical structure of the database

e.g., the database consists of information about a set of library members, holdings, publishers and the relationship between them)

Analogous to type information of a variable in a program

Physical schema: database design at the physical level (explains how it is stored in computer! )

Logical schema: database design at the logical level ( explains what need to be stored !)

Instance – the actual content of the database at a particular point in time

Analogous to the value of a variable

Physical Data Independence – the ability to modify the physical schema without changing the logical schema

Applications depend on the logical schema

In general, the interfaces between the various levels and components should be well defined so that changes in some parts do not seriously influence others.

(10)

Data Models Data Models

A collection of tools for describing

data

data relationships

data semantics

data constraints

Entity-Relationship model

Relational model

Other models:

object-oriented model

semi-structured data models

Older models: network model and hierarchical model

(11)

Entity Relationship (ER) Diagram Entity Relationship (ER) Diagram

Entity Relationship Diagram is a technique for analysis and

logical modeling of system’s data requirements. It uses notations for representing these.

Entity

Attribute

Relationship

Data object in the system uniquely

identifiable by identifier. Has attributes that defines it

Describes an entity Relates two entities

Uniquely identifiable by identifier

(12)

Entity Relationship (ER) Diagram Entity Relationship (ER) Diagram

Entity: An entity is an object, place,person or activity about which an enterprise records data

E.g. Book, Member, Publisher etc.

Attribute: An attribute is the characteristic of an existing entity.

E.g. Accession number, title, author is attributes of the ‘book’

entity.

Relationship: An association among the entities.

(13)

Example of ER Diagram Example of ER Diagram

A book is issued to a Member can be graphically represented by ER Diagram as:

accno

author publisher Issuedate

name

JoiningDate

Book IssuedTo Member

title accno memno Memno

(14)

The Relational Model The Relational Model

This model allows data to be represented in a simple row- column format

Each attribute (data field) is considered as a column and each record is considered as a row of the table.

It can represent one to one as well as many to many relationship of the entities

(15)

Example of Relational Model Example of Relational Model

Accn

o Title Author Publisher-

code 1 Operating

system Milan Milenkovi c

2

2 Networking

Essentials James

Chellis 1 3 Structured

COBOL Stern 2

4 Software

Engg Roger S

Presman 3

Publis her- Code

Title

1 BPB Publications ,New Delhi

2 McGraw Hills 3 PHI, New Delhi

Book Publisher

(16)

A Sample Relational Database

A Sample Relational Database

(17)

Relational DBMS (RDBMS) Relational DBMS (RDBMS)

A Relational Database Management System is an information system that represents information as rows in a collection of tables

Each table processing is a set of one or more columns.

Relation, attributes, domains and relational operators are the basic elements of RDBMS

RDBMS has following features:

The ability to create multiple relations and enter data into it.

An interactive Query Language

Retrieval of information stored in more than one table

(18)

Examples of RDBMS Examples of RDBMS

Proprietary RDBMS

Informix

Sybase

MS SQL Server

Visual FoxPro

MS Access

Oracle

DB2

Open Source RDBMS

MySQL

Postgresql

(19)

Data Definition Language (DDL) Data Definition Language (DDL)

Specification notation for defining the database schema

E.g.

Create database library

create table book (

accno numeric(7), title char(50)

author char(30))

Drop table book

DDL compiler generates a set of tables stored in a data dictionary

Data dictionary contains metadata (i.e., data about data)

database schema

Data storage and definition language

language in which the storage structure and access methods used by the database system are specified

Usually an extension of the data definition language

(20)

Data Manipulation Language (DML) Data Manipulation Language (DML)

Language for accessing and manipulating the data organized by the appropriate data model

DML also known as query language

Two classes of languages

Procedural – user specifies what data is required and how to get those data

Nonprocedural – user specifies what data is required without specifying how to get those data

SQL is the most widely used query language

(21)

SQL SQL

This is a language used only for retrieving information only

The syntax (grammar) of SQL is mostly common in different vendors of SQL like SQL server, PL SQL

Easy to understand, least experienced users can issue commands to retrieve information

However lacks commands for developing software

SQL: widely used non-procedural language

E.g. find the titles of the book written by Henry Korth select book.title

from book

where book.author = ‘Henry Korth’

Application programs generally access databases through one of

Language extensions to allow embedded SQL

Application program interface (e.g. ODBC/JDBC) which allow SQL queries to be sent to a database

(22)

Database Users Database Users

Users are differentiated by the way they expect to interact with the system

Application programmers – interact with system through DML calls

Sophisticated users – form requests in a database query language

Specialized users – write specialized database applications that do not fit into the traditional data processing framework

Naïve users – invoke one of the permanent application programs that have been written previously

E.g. people accessing database over the web, bank tellers, clerical staff

(23)

Database Administrator Database Administrator

Coordinates all the activities of the database system; the database administrator has a good understanding of the enterprise’s information resources and needs.

Database administrator's duties include:

Schema definition

Storage structure and access method definition

Schema and physical organization modification

Granting user authority to access the database

Specifying integrity constraints

Acting as liaison with users

Monitoring performance and responding to changes in requirements

(24)

Application Architectures Application Architectures

Two-tier architecture: E.g. client programs using ODBC/JDBC to communicate with a database

(25)

What to learn in coming sessions?

What to learn in coming sessions?

Mainly Structured Query Language (SQL)

DDL

Data types

Creation of databases, tables, views etc

Modification of table structures

Deletion of databases, tables, views etc

DML

Insertion of data into tables

Applying constraints

Retrieval of information from single and multiple tables (Joins)

Modification of data

Ordering of data

Security of database

(26)
(27)

Structured Query Language (SQL) Structured Query Language (SQL)

Mukesh A Pund Scientist, NISCAIR

(28)

What is SQL?

What is SQL?

SQL stands for Structured Query Language

SQL allows you to access a database

SQL is an ANSI standard computer language

SQL can execute queries against a database

SQL can retrieve data from a database

SQL can insert new records in a database

SQL can delete records from a database

SQL can update records in a database

SQL is easy to learn

(29)

SQL is a Standard - BUT....

SQL is a Standard - BUT....

SQL is an ANSI (American National Standards Institute)

standard computer language for accessing and manipulating database systems. SQL statements are used to retrieve and update data in a database. SQL works with database programs like MS Access, DB2, Informix, MS SQL Server, Oracle, Sybase, etc.

Unfortunately, there are many different versions of the SQL

language, but to be in compliance with the ANSI standard, they must support the same major keywords in a similar manner

(such as SELECT, UPDATE, DELETE, INSERT, WHERE, and others).

Note: Most of the SQL database programs also have their own proprietary extensions in addition to the SQL standard!

(30)

SQL Database Tables SQL Database Tables

A database most often contains one or more tables. Each table is identified by a name (e.g. “Book" or “Member"). Tables contain records (rows) with data.

(31)

Creation of database Creation of database

CREATE DATABASE database_name Eg. CREATE DATABASE library

(32)

Example of tables Example of tables

Below is an example of “Book”

table Book

Accno Title Author Price isbn

101 Social Processes S. Sharma 300.00 81-266-2078-1 102 Fundamentals of IT P. Dubey 600.00 71-265-2077-2 103 Management

Information System Lauden & Lauden 700.00 72-265-2076-3 104 Artificial Intelligence D W Patterson 800.00 73-265-2075-4 105 Software Enginnering Roger S Presman 1000.50 70-265-2074-5

(33)

Example of tables Example of tables

Below is an example of

“Members” table

Members

Memno Name Maxbooks Maxdays

M01 Gian Singh 4 15

M02 A S Rao 4 15

M03 S Malik 2 15

M04 S Dua 2 15

(34)

Creation of tables (without constraints) Creation of tables (without constraints)

To create a table in a database:

CREATE TABLE table_name(column_name1 data_type, column_name2 data_type,...)

Example:

CREATE TABLE book (accno numeric(5), title varchar(50),author varchar(30),publisher varchar(50))

(35)

Various data types in MS SQL Server Various data types in MS SQL Server

Data type Description Example

integer(size) int(size)

Hold integers only. The maximum number of digits

are specified in parenthesis. accno

decimal(size,d) numeric(size,d)

Hold numbers with fractions. The maximum number of digits are specified in "size". The maximum number of digits to the right of the decimal is specified in "d".

Price of book

char(size) Holds a fixed length string (can contain letters, numbers, and special characters).

The fixed size is specified in parenthesis.

ISBN Number

varchar(size) Holds a variable length string (can contain letters, numbers, and special characters).

The maximum size is specified in parenthesis

Title, author name etc

Datetime (yyyymmdd)

Holds a date Date of joinig,

issue date etc

(36)

Data Integrity with constraints Data Integrity with constraints

Data Integrity

 Refers to the consistency and accuracy of the data that is stored in a database

Constraints

 Constraints offers a way to have SQL server enforces the integrity of the database automatically

 Constraints defines rules regarding the values allowed in columns and are the standard mechanism for enforcing integrity

(37)

Classes of constraints Classes of constraints

Not Null – specifies that the column does not accept null values

Check – enforces to accept only the specified values / values in range in a set of column

Primary Key – Identify a column or a set of column whose values uniquely identify a row in table

Foreign Key – Identify the relationship between the tables

(38)

Creation of tables (with constraints) Creation of tables (with constraints)

Constraint: not null

CREATE TABLE table_name(column_name1 data_type not null, column_name2 data_type,...)

Example:

CREATE TABLE book (accno numeric(5) not null, title varchar(50),author varchar(30),publisher varchar(50))

(39)

Creation of tables (with constraints) Creation of tables (with constraints)

Constraint: primary key

CREATE TABLE table_name(column_name1 data_type primary key, column_name2 data_type,...)

Example1:

CREATE TABLE book (accno numeric(5) primary key, title

varchar(50),author varchar(50),price numeric(7,2),isbn char(13))

Example 2

CREATE TABLE members (memno char(5) primary key, name varchar(50),maxbooks numeric (2),maxdays numeric(3))

(40)

Creation of tables (with constraints) Creation of tables (with constraints)

Constraint: foreign key

CREATE TABLE table_name(column_name1 data_type FOREIGN KEY REFERENCES reference_table ,

column_name2 data_type,...) Eg.

CREATE TABLE issue

(accno numeric(5) FOREIGN KEY REFERENCES book, memno char(5) FOREIGN KEY REFERENCES members, issudt datetime, rtndt datetime)

(41)

Inserting data into tables Inserting data into tables

INSERT INTO table_name VALUES (value1, value2,....) OR

INSERT INTO table_name

(column_name1, column_name2,...) VALUES (value1, value2,....)

Example1:

INSERT INTO book values (101,’Social Processes’,’S. Sharma’,300,’81- 266-2078-1’)

Example2:

Insert into members values (‘M01’,’Gian Singh’,4,15)

Example3:

Insert into issue values (101,’M01’,’04/05/2007’,’04/20/2007’)

Example4: (For values in specified column) INSERT INTO members

(memno, name) VALUES (‘m06’,’Mukesh Pund’)

(42)

Modifying structure of tables Modifying structure of tables

Adding column

ALTER TABLE table_name ADD column_name datatype

Ex. 1

Alter table book add publisher varchar(50)

(43)

Modifying structure of tables Modifying structure of tables

Deleting column

ALTER TABLE table_name drop column_name

Ex. 1

Alter table book drop publisher

(44)

Specifying conditions with Where Clause Specifying conditions with Where Clause

WHERE clause is used to specify conditions in ALTER, UPDATE, SELECT etc.

Example:

UPDATE book

SET booktype=‘S’

WHERE accno=101

Here value “S” is being stored in booktype attribute in record with accno 101

(45)

Comparison Operators Comparison Operators

Following operators are used while specifying conditions

Operator Description

> Greater than

< Less than

>= Greater than or equal to

<= Less than or equal to

= Equal to

<> Not equal to

BETWEEN Between an inclusive range

IN If you know the exact value you

want to return for at least one of the columns

(46)

Modifying Data in tables Modifying Data in tables

UPDATE clause is used to modify and delete data in the tables

UPDATE table_name

SET column_name=new_value [, column_name=new_value]

WHERE column_name=some_value

Example:

UPDATE book SET booktype=‘S’

WHERE accno=101

(47)

Modifying Data in tables Modifying Data in tables

Deleting data from table:

DELETE FROM table_name

(Note: Deletes the entire table!!) OR

DELETE FROM table_name WHERE condition

Example1:

delete from book WHERE accno=101

(48)

The SQL SELECT Statement

The SELECT statement is used to select data from a table. The tabular result is stored in a result table (called the result-set).

SELECT column_name(s) FROM table_name

Retrieval of data

Retrieval of data

(49)

SQL SELECT Example SQL SELECT Example

To select the content of columns named “Title" and “Author",

from the database table called “Book", use a SELECT statement like this

SELECT author, title FROM book

To select all columns from the "Persons" table, use a * symbol instead of column names, like this:

SELECT * FROM book

(50)

The SELECT DISTINCT Statement The SELECT DISTINCT Statement

The DISTINCT keyword is used to return only distinct (different) values.

With SQL, all we need to do is to add a DISTINCT keyword to the SELECT statement:

SELECT DISTINCT column_name(s) FROM table_name

Ex: display all unique titles which are available in library SELECT DISTINCT title FROM book

(51)

SELECT statement with WHERE clause SELECT statement with WHERE clause

To conditionally select data from a table, a WHERE clause can be added to the SELECT statement.

SELECT column FROM table WHERE column operator value

(52)

SELECT statement with WHERE clause SELECT statement with WHERE clause

The operators that can be used with WHERE clause:

Operator Description

> Greater than

< Less than

>= Greater than or equal to

<= Less than or equal to

= Equal to

<> Not equal to

BETWEEN Between an inclusive range

IN If you know the exact value

(53)

SELECT statement with WHERE clause SELECT statement with WHERE clause

Example1 : Display all the book with accession number greater than 400

SELECT * FROM book WHERE accno >400

Example2: Display all the books written by “Roger S Presman”

SELECT title FROM book

WHERE author =‘Roger S Presman’

For numeric value don’t put quotes for other values put quotes

(54)

The LIKE Condition The LIKE Condition

The LIKE condition is used to specify a search for a pattern in a column.

SELECT column FROM table WHERE column LIKE pattern

A "%" sign can be used to define wildcards (missing zero or more letters in the pattern) both before and after the pattern.

A “_” sign can be used to define wildcards (missing one letter in the pattern) both before and after the pattern.

Example1: Display all the members whose name start will letter “P”

SELECT * FROM member WHERE name LIKE ‘P%’

Example2: Display all the book titles containing “computer” word SELECT title FROM book

(55)

The IN condition The IN condition

IN

The IN operator may be used if you know the exact value you want to return for at least one of the columns.

SELECT column_name FROM table_name WHERE column_name IN (value1,value2,..)

Example: Display all the books written by “Roger S Presman” or

“D W Patterson”

SELECT title, author FROM book WHERE author IN (‘Roger S Presman’,’ D W Patterson)

(56)

The BETWEEN condition The BETWEEN condition

BETWEEN ... AND

The BETWEEN ... AND operator selects a range of data between two values.

These values can be numbers, text, or dates.

It selects fields between the test values, including the first test value and excluding the last test value

SELECT column_name FROM table_name WHERE column_name BETWEEN value1 AND value2

Example: display accession and title of the books in which accession number is between 101 to 105

SELECT accno,title FROM book WHERE accno BETWEEN 101 AND 105

(57)

Where clause with multiple conditions Where clause with multiple conditions

AND & OR

AND and OR join two or more conditions in a WHERE clause.

The AND operator displays a row if ALL conditions listed are true. The OR operator displays a row if ANY of the conditions listed are true.

Example1: Display all the books of “computer discipline”

published by “Mc Graw Hills”

SELECT * FROM book

WHERE booktype=“C” AND publisher=“Mc Graw Hills”

Example2: Display all the books published by “Mc Graw Hills”

or is of “Computer Discipline”

SELECT * FROM book

WHERE booktype=“C” OR publisher=“Mc Graw Hills”

(58)

Working with Functions Working with Functions

SQL has a lot of built-in functions for counting and calculations.

Types of Functions:

Aggregate Functions

Scalar functions

Aggregate functions

Aggregate functions operate against a collection of values, but return a single value.

Note: If used among many other expressions in the item list of a SELECT statement, the SELECT must have a GROUP BY clause!!

(59)

Some Aggregate Functions in SQL Server Some Aggregate Functions in SQL Server

AVG(column) Returns the average value of a column

COUNT(column) Returns the number of rows (without a NULL value) of a column

COUNT(*) Returns the number of selected rows

COUNT(DISTINCT co lumn)

Returns the number of distinct results

MAX(column) Returns the highest value of a column

MIN(column) Returns the lowest value of a column

SUM(column) Returns the total sum of a column

(60)

Some Scalar Functions in SQL Server Some Scalar Functions in SQL Server

Scalar functions operate against a single value, and return a single value based on the input value

Function Name Description

UPPER(c) Converts a field to upper case LOWER(c) Converts a field to lower case

SUBSTRING(c,start,end) Extract characters from a text field LEN(c) Returns the length of a text field

CHARINDEX(char,c) Returns the numeric position of a named character within a text field

LEFT(c,number_of_char) Return the left part of a text field requested RIGHT(c,number_of_char) Return the left part of a text field requested

(61)

Some Scalar Functions in SQL Server Some Scalar Functions in SQL Server

Function Name Description

DATEDIFF(d,start_date,end

_date) Start_date is subtracted from end_date Where

D: day/month/year/hour/minute/second Used to perform date calculations

Example: Display the days between return date and issue date of all books which were issued

SELECT memno, accno, datediff(day,issudt,rtndt) AS no _of_days FROM issue

(62)

Examples of Aggregate Functions Examples of Aggregate Functions

Example1: Display the total cost of holdings in library SELECT sum(price) from book

Example2: Display an average cost of books in your library SELECT avg(price) from book

Example3: Display total number of members in your library SELECT count(*) from members

Example4: Display number of unique titles of books in your library

SELECT count (distinct title) from book

Example4: Display highest cost of books in your library

(63)

GROUP BY and HAVING GROUP BY and HAVING

Aggregate functions (like SUM, COUNT) often need an added GROUP BY functionality

GROUP BY...

GROUP BY... was added to SQL because aggregate functions (like SUM) return the aggregate of all column values every time they are called, and without the GROUP BY function it was

impossible to find the sum for each individual group of column values.

SELECT column,SUM(column) FROM table GROUP BY column

Example: Display number of copies of each book

SELECT isbn, count(isbn) AS number_of_copies FROM book GROUP BY isbn

(64)

HAVING...

HAVING...

HAVING... was added to SQL because the WHERE keyword could not be used against aggregate functions (like SUM), and without HAVING... it would be impossible to test for result

conditions.

SELECT column,aggregate_function(column) FROM table GROUP BY column

HAVING condition

Example: Display isbn numbers of all books having two or more copies

SELECT isbn,count(isbn) AS number_of_books FROM book GROUP BY isbn

(65)

Sorting the result - ORDER BY Sorting the result - ORDER BY

The ORDER BY keyword is used to sort the result.

The default order is in ascending order of values

We can specify the keyword DESC if we want a descending order; the keyword ASC can be used to explicitly specify ascending order, even though it is the default

SELECT column_names FROM table [WHERE condition]

ORDER BY column_name

Example1: Display the title, accno in alphabetical order of title SELECT title,accno FROM book ORDER BY title

Example2: Display the title, accno in descending order of title SELECT title,accno FROM book ORDER BY title DESC

(66)

Now can you predict the outcome?

Now can you predict the outcome?

SELECT title,COUNT(isbn) AS numer_of_copies FROM book GROUP BY title,isbn HAVING COUNT(isbn)>=2 ORDER BY title

(67)

Retrieving Data From Multiple Tables Retrieving Data From Multiple Tables

To retrieve data from two or more tables we need to join them by specifying join condition

SELECT column1,column2.. FROM table1,table2 WHERE table1.column = table2.column

Example: Display the accno, title and name of the members who have issued books at any point of time

Ans: Here title is available in ‘book’ table, name of the member is available in ‘members’ table and issue information is available in

‘issue’ table. Therefore we need to join all these three table SELECT book.accno, book.title, members.name

FROM book,issue,members

WHERE book.accno=issue.accno AND issue.memno=members.memno

(68)

Retrieving Data From Multiple Tables Retrieving Data From Multiple Tables

NESTED QUERIES: - A complete SELECT query, called a nested query , can be specified within the WHERE-clause of another query, called the outer query

Many of the previous queries can be specified in an alternative form using nesting

IN and EXISTS can be used for nested query (query inside query)

In general, we can have several levels of nested queries

Example: Display the list of members who have not issued any book

(69)

Referensi

Dokumen terkait

also upload the measured temperature of the thermostat sensing devices to the cloud server, where the system will import data to be stored in a large-data database, and create a

• The following SQL statement creates a stored procedure that selects Customers from a particular City with a particular PostalCode from the "Customers" table: • Example • CREATE