Structured Query Language: Hans-Petter Halvorsen
Structured Query Language: Hans-Petter Halvorsen
blog
https://www.halvorsen.blog
Table of Contents
1 Introduction to SQL ........................................................................................................... 6
5 UPDATE ........................................................................................................................... 33
4 Table of Contents
6 DELETE ............................................................................................................................. 35
7 SELECT ............................................................................................................................. 37
9 Views ............................................................................................................................... 56
11 Functions ...................................................................................................................... 66
12 Triggers ......................................................................................................................... 72
14 References .................................................................................................................... 78
1 Introduction to SQL
SQL (Structured Query Language) is a database computer language designed for managing
data in relational database management systems (RDBMS).
SQL, is a standardized computer language that was originally developed by IBM for querying,
altering and defining relational databases, using declarative statements.
SQL is pronounced /ˌɛs kjuː ˈɛl/ (letter by letter) or /ˈsiːkwəl/ (as a word).
What can SQL do?
7 Introduction to SQL
Even if SQL is a standard, many of the database systems that exist today implement their
own version of the SQL language. In this document, we will use the Microsoft SQL Server as
an example.
There are lots of different database systems, or DBMS – Database Management Systems,
such as:
In this Tutorial, we will focus on Microsoft SQL Server. SQL Server uses T-SQL (Transact-SQL).
T-SQL is Microsoft's proprietary extension to SQL. T-SQL is very similar to standard SQL, but
in addition it supports some extra functionality, built-in functions, etc.
The acronym CRUD refers to all of the major functions that need to be implemented in a
relational database application to consider it complete. Each letter in the acronym can be
mapped to a standard SQL statement:
We have different editions of SQL Server, where SQL Server Express is free to download and
use.
SQL Server uses T-SQL (Transact-SQL). T-SQL is Microsoft's proprietary extension to SQL. T-
SQL is very similar to standard SQL, but in addition it supports some extra functionality, built-
in functions, etc. T-SQL expands on the SQL standard to include procedural programming,
local variables, various support functions for string processing, date processing,
mathematics, etc.
SQL Server consists of a Database Engine and a Management Studio (and lots of other stuff
which we will not mention here). The Database engine has no graphical interface - it is just a
service running in the background of your computer (preferable on the server). The
Management Studio is graphical tool for configuring and viewing the information in the
database. It can be installed on the server or on the client (or both).
10 Introduction to SQL Server
A central feature of SQL Server Management Studio is the Object Explorer, which allows the
user to browse, select, and act upon any of the objects within the server. It can be used to
visually observe and analyze query plans and optimize the database performance, among
others. SQL Server Management Studio can also be used to create a new database, alter any
existing database schema by adding or modifying tables and indexes, or analyze
performance. It includes the query windows which provide a GUI based interface to write
and execute queries.
When creating SQL commands and queries, the “Query Editor” (select “New Query” from
the Toolbar) is used (shown in the figure above).
With SQL and the “Query Editor” we can do almost everything with code, but sometimes it is
also a good idea to use the different Designer tools in SQL to help us do the work without
coding (so much).
There are lots of settings you may set regarding your database, but the only information you
must fill in is the name of your database:
You may also use the SQL language to create a new database, but sometimes it is easier to
just use the built-in features in the Management Studio.
2.1.2 Queries
In order to make a new SQL query, select the “New Query” button from the Toolbar.
Here we can write any kind of queries that is supported by the SQL language.
3 CREATE TABLE
Before you start implementing your tables in the database, you should always spend some
time design your tables properly using a design tool like, e.g., ERwin, Toad Data Modeler,
PowerDesigner, Visio, etc. This is called Database Modeling.
The CREATE TABLE statement is used to create a table in a database.
Syntax:
The data type specifies what type of data the column can hold.
13
14 CREATE TABLE
You have special data types for numbers, text dates, etc.
Examples:
Example:
We want to create a table called “CUSTOMER” which has the following columns and data
types:
Best practice:
• Tables: Use upper case and singular form in table names – not plural, e.g.,
“STUDENT” (not students)
• Columns: Use Pascal notation, e.g., “StudentId”
• Primary Key:
o If the table name is “COURSE”, name the Primary Key column “CourseId”, etc.
o “Always” use Integer and Identity(1,1) for Primary Keys. Use UNIQUE
constraint for other columns that needs to be unique, e.g. RoomNumber
• Specify Required Columns (NOT NULL) – i.e., which columns that need to have data
or not
• Standardize on few/these Data Types: int, float, varchar(x), datetime, bit
• Use English for table and column names
• Avoid abbreviations! (Use RoomNumber – not RoomNo, RoomNr, ...)
With this tool we can transfer the database model as tables into different database systems,
such as e.g., SQL Server. CA ERwin Data Modeler Community Edition is free with a 25 objects
limit. It has support for Oracle, SQL Server, MySQL, ODBC and Sybase.
Below we see the same tables inside the design tool in SQL Server.
Instead of creating a script you may as well easily use the designer for creating tables.
Step2: Next, the table designer pops up where you can add columns, data types, etc.
In this designer we may also specify Column Names, Data Types, etc.
Constraints can be specified when a table is created (with the CREATE TABLE statement) or
after the table is created (with the ALTER TABLE statement).
• PRIMARY KEY
• NOT NULL
• UNIQUE
• FOREIGN KEY
• CHECK
• DEFAULT
• IDENTITY
Primary keys must contain unique values. It is normal to just use running numbers, like 1, 2,
3, 4, 5, … as values in Primary Key column. It is a good idea to let the system handle this for
you by specifying that the Primary Key should be set to identity(1,1). IDENTITY(1,1) means
the first value will be 1 and then it will increment by 1.
Each table should have a primary key, and each table can have only ONE primary key.
As you see we use the “Primary Key” keyword to specify that a column should be the
Primary Key.
If you use the Designer tools in SQL Server, you can easily set the primary Key in a table just
by right-click and select “Set primary Key”.
The primary Key column will then have a small key in front to illustrate that this column is
a Primary Key.
Example:
We will create a CREATE TABLE script for these tables:
SCHOOL:
CLASS:
The FOREIGN KEY constraint is used to prevent actions that would destroy links between
tables.
The FOREIGN KEY constraint also prevents that invalid data from being inserted into the
foreign key column, because it has to be one of the values contained in the table it points to.
If you want to use the designer, right-click on the column that you want to be the Foreign
Key and select “Relationships…”:
The following window pops up (Foreign Key Relationships):
Click on the “Add” button and then click on the small “…” button. Then the following window
pops up (Tables and Columns):
Here you specify the primary Key Column in the Primary Key table and the Foreign Key
Column in the Foreign Key table.
The NOT NULL constraint enforces a field to always contain a value. This means that you
cannot insert a new record, or update a record without adding a value to this field.
We see that “CustomerNumber”, “LastName” and “FirstName” is set to “NOT NULL”, this
means these columns needs to contain data. While “AreaCode”, “Address” and “Phone” may
be left empty, i.e, they don’t need to be filled out.
In the Table Designer you can easily set which columns that should allow NULL or not:
3.3.4 UNIQUE
The UNIQUE constraint uniquely identifies each record in a database table. The UNIQUE and
PRIMARY KEY constraints both provide a guarantee for uniqueness for a column or set of
columns.
Note! You can have many UNIQUE constraints per table, but only one PRIMARY KEY
constraint per table.
We see that the “CustomerNumber” is set to UNIQUE, meaning each customer must have a
unique Customer Number. Example:
Setting UNIQUE in the Designer Tools:
If you want to use the designer, right-click on the column that you want to be UNIQUE and
select “Indexes/Keys…”:
Then click “Add” and then set the “Is Unique” property to “Yes”:
3.3.5 CHECK
The CHECK constraint is used to limit the value range that can be placed in a column.
If you define a CHECK constraint on a single column it allows only certain values for this
column.
If you define a CHECK constraint on a table it can limit the values in certain columns based
on values in other columns in the row.
Example:
In this case, when we try to insert a Customer Number less than zero we will get an error
message.
If you want to use the designer, right-click on the column where you want to set the
constraints and select “Check Constraints…”:
Then click “Add” and then click “…” in order to open the Expression window:
In the Expression window you can type in the expression you want to use:
3.3.6 DEFAULT
The DEFAULT constraint is used to insert a default value into a column.
The default value will be added to all new records, if no other value is specified.
Example:
Example:
As shown below, we use the IDENTITY() for this. IDENTITY(1,1) means the first value will be 1
and then it will increment by 1.
We can use the designer tools to specify that a Primary Key should be an identity column
that is automatically generated by the system when we insert data in to the table.
Click on the column in the designer and go into the Column Properties window:
To delete a column in a table, use the following syntax (notice that some database systems
don't allow deleting a column):
To change the data type of a column in a table, use the following syntax:
If we use CREATE TABLE and the table already exists in the table we will get an error
message, so if we combine CREATE TABLE and ALTER TABLE we can create robust database
scripts that gives no errors, as the example shown below:
if not exists (select * from dbo.sysobjects where id = object_id(N'[CUSTOMER]') and
OBJECTPROPERTY(id, N'IsUserTable') = 1)
CREATE TABLE CUSTOMER
(
CustomerId int PRIMARY KEY,
CustomerNumber int NOT NULL UNIQUE,
LastName varchar(50) NOT NULL,
FirstName varchar(50) NOT NULL,
AreaCode int NULL,
Address varchar(50) NULL,
Phone varchar(50) NULL,
)
GO
Else
ALTER TABLE CUSTOMER ADD CustomerNumber int
GO
...
4 INSERT INTO
The INSERT INTO statement is used to insert a new row in a table.
The first form doesn't specify the column names where the data will be inserted, only their
values:
Example:
The second form specifies both the column names and the values to be inserted:
Example:
Example:
Note! You need at least to include all columns that cannot be NULL.
31
32 INSERT INTO
i.e., we need to include at least “CustomerNumber”, “LastName” and “FirstName”.
“CustomerId” is set to “identity(1,1)” and therefore values for this column are generated by
the system.
When you have created the tables, you can easily insert data into them using the designer
tools. Right-click on the specific table and select “Edit Top 200 Rows”:
Then you can enter data in a table format, similar to, e.g., MS Excel:
5 UPDATE
The UPDATE statement is used to update existing records in a table.
UPDATE table_name
SET column1=value, column2=value2,...
WHERE some_column=some_value
Note! Notice the WHERE clause in the UPDATE syntax. The WHERE clause specifies which
record or records that should be updated. If you omit the WHERE clause, all records will be
updated!
Example:
Before update:
After update:
→ So make sure to include the WHERE clause when using the UPDATE command!
33
34 UPDATE
The same way you insert data you can also update the data. Right-click on the specific table
and select “Edit Top 200 Rows”:
Then you can change your data:
6 DELETE
The DELETE statement is used to delete rows in a table.
Syntax:
Note! Notice the WHERE clause in the DELETE syntax. The WHERE clause specifies which
record or records that should be deleted. If you omit the WHERE clause, all records will be
deleted!
Example:
Before delete:
After delete:
It is possible to delete all rows in a table without deleting the table. This means that the
table structure, attributes, and indexes will be intact:
Note! Make sure to do this only when you really mean it! You cannot UNDO this statement!
You delete data in the designer by right-click on the row and select “Delete”:
35
36 DELETE
7 SELECT
The SELECT statement is probably the most used SQL command. The SELECT statement is
used for retrieving rows from the database and enables the selection of one or many rows or
columns from one or many tables in the database.
The CUSTOMER table contains the following data:
Example:
This simple example gets all the data in the table CUSTOMER. The symbol “*” is used when
you want to get all the columns in the table.
37
38 SELECT
If you only want a few columns, you may specify the names of the columns you want to
retrieve, example:
The full syntax of the SELECT statement is complex, but the main clauses can be summarized
as:
SELECT
[ ALL | DISTINCT ]
[TOP ( expression ) [PERCENT] [ WITH TIES ] ]
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 ] ]
It seems complex, but we will take the different parts step by step in the next sections.
The following will appear:
A Select query is automatically created for you which you can edit if you want to.
Example:
If you use the “order by” keyword, the default order is ascending (“asc”). If you want the
order to be opposite, i.e., descending, then you need to use the “desc” keyword.
The DISTINCT keyword can be used to return only distinct (different) values.
Example:
select <column_names>
from <table_name>
where <column_name> operator value
Example:
Note! SQL uses single quotes around text values, as shown in the example above.
7.3.1 Operators
With the WHERE clause, the following operators can be used:
Operator Description
= Equal
<> Not equal
> Greater than
< Less than
>= Greater than or equal
<= Less than or equal
BETWEEN Between an inclusive range
LIKE Search for a pattern
IN If you know the exact value you want to return for at least one of the
columns
Examples:
Syntax:
SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern
Example:
Note! The "%" sign can be used to define wildcards (missing letters in the pattern) both
before and after the pattern.
You may also combine with the NOT keyword, example:
7.3.3 IN Operator
The IN operator allows you to specify multiple values in a WHERE clause.
Syntax:
SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2,...)
Syntax:
SELECT column_name(s)
FROM table_name
WHERE column_name
BETWEEN value1 AND value2
7.4 Wildcards
SQL wildcards can substitute for one or more characters when searching for data in a
database.
Note! SQL wildcards must be used with the SQL LIKE operator.
Wildcard Description
% A substitute for zero or more characters
_ A substitute for exactly one character
[charlist] Any single character in charlist
[^charlist] Any single character not in charlist
or
[!charlist]
Examples:
The OR operator displays a record if either the first condition or the second condition is true.
Examples:
You can also combine AND and OR (use parenthesis to form complex expressions).
Example:
The TOP clause can be very useful on large tables with thousands of records. Returning a
large number of records can impact on performance.
Syntax:
Examples:
This is very useful for large tables with thousands of records
7.7 Alias
You can give a table or a column another name by using an alias. This can be a good thing to
do if you have very long or complex table names or column names.
SELECT column_name(s)
FROM table_name
AS alias_name
7.8 Joins
SQL joins are used to query data from two or more tables, based on a relationship between
certain columns in these tables.
• JOIN: Return rows when there is at least one match in both tables
• LEFT JOIN: Return all rows from the left table, even if there are no matches in the
right table
• RIGHT JOIN: Return all rows from the right table, even if there are no matches in the
left table
• FULL JOIN: Return rows when there is a match in one of the tables
Example:
Given 2 tables:
• SCHOOL
• CLASS
We want to get the following information using a query:
SchoolName ClassName
… …
… …
In order to get information from more than one table we need to use the JOIN. The JOIN is
used to join the primary key in one table with the foreign key in another table.
select
SCHOOL.SchoolName,
CLASS.ClassName
from
SCHOOL
INNER JOIN CLASS ON SCHOOL.SchoolId = CLASS.SchoolId
8 SQL Scripts
A SQL script is a collection of SQL statements that you can execute in one operation. You can
use any kind of SQL commands, such as insert, select, delete, update, etc. In addition you
can define and use variables, and you may also use program flow like If-Else, etc. You may
also add comments to make the script easier to read and understand.
• Single-line comment
• Multiple-line comment
Syntax:
-- text_of_comment
Syntax:
/*
text_of_comment
text_of_comment
*/
48
49 SQL Scripts
8.2 Variables
The ability to using variables in SQL is a powerful feature. You need to use the keyword
DECLARE when you want to define the variables. Local variables must have the the symbol
“@” as a prefix. You also need to specify a data type for your variable (int, varchar(x), etc.).
declare
@myvariable1 data_type,
@myvariable2 data_type,
…
When you want to assign values to the variable, you must use either a SET or a SELECT
statement.
Example:
set @myvariable=4
If you want to see the value for a variable, you can e.g., use the PRINT command like this:
set @myvariable=4
print @myvariable
You can assign a value to the variable from a select statement like this:
You can also use a variable in the WHERE clause LIKE, e.g., this:
8.3.1 @@IDENTITY
After an INSERT, SELECT INTO, or bulk copy statement is completed, @@IDENTITY contains
the last identity value that is generated by the statement. If the statement did not affect any
tables with identity columns, @@IDENTITY returns NULL. If multiple rows are inserted,
generating multiple identity values, @@IDENTITY returns the last identity value generated.
Example:
We want to insert a new School into the SCHOOL table and we want to insert 2 new Courses
in the COURSE table that belong to the School we insert. To find the “SchoolId” we can use
the @@IDENTITY variable:
-- Insert Courses for the specific School above in the COURSE table
insert into COURSE(SchoolId,CourseName) values (@SchoolId, 'MIT-
101')
insert into COURSE(SchoolId,CourseName) values (@SchoolId, 'MIT-
201')
8.4.1 IF – ELSE
The IF-ELSE is very useful. Below we see an example:
BEGIN…END:
If more than one line of code is to be executed within an IF sentence you need to use
BEGIN…END.
Example:
8.4.2 WHILE
We can also use WHILE, which is known from other programming languages.
Example:
and the following query:
end
As you can see the code inside the WHILE loop is executed as long as “AreaCode” for
CustomerId=1 is less than 20. For each iteration is the “AreaCode” for that customer
incremented with 1.
8.4.3 CASE
The CASE statement evaluates a list of conditions and returns one of multiple possible result
expressions.
Example:
We have a “GRADE” table that contains the grades for each student in different courses:
In the “GRADE” table is the grades stored as numbers, but since the students get grades with
the letters A..F (A=5, B=4, C=3, D=2, E=1, F=0), we want to convert the values in the table
into letters using a CASE statement:
select
GradeId,
StudentId,
CourseId,
case Grade
when 5 then 'A'
when 4 then 'B'
when 3 then 'C'
when 2 then 'D'
when 1 then 'E'
when 0 then 'F'
else '-'
end as Grade
from
GRADE
8.4.4 CURSOR
In advances scripts, CURSORs may be very useful. A CURSOR works like an advanced WHILE
loop which we use to iterate through the records in one or more tables.
CURSORS are used mainly in stored procedures, triggers, and SQL scripts.
Example:
We will create a CURSOR that iterate through all the records in the CUSTOMER table and
check if the Phone number consists of 8 digits, if not the script will replace the invalid Phone
number with the text “Phone number is not valid”.
DECLARE
@CustomerId int,
@phone varchar(50)
OPEN db_cursor
FETCH NEXT FROM db_cursor INTO @CustomerId
WHILE @@FETCH_STATUS = 0
BEGIN
if LEN(@phone) < 8
CLOSE db_cursor
DEALLOCATE db_cursor
• Declare SQL variables to contain the data returned by the cursor. Declare one
variable for each result set column.
• Associate a SQL cursor with a SELECT statement using the DECLARE CURSOR
statement. The DECLARE CURSOR statement also defines the characteristics of the
cursor, such as the cursor name and whether the cursor is read-only or forward-only.
• Use the OPEN statement to execute the SELECT statement and populate the cursor.
• Use the FETCH INTO statement to fetch individual rows and have the data for each
column moved into a specified variable. Other SQL statements can then reference
those variables to access the fetched data values.
• When you are finished with the cursor, use the CLOSE statement. Closing a cursor
frees some resources, such as the cursor's result set and its locks on the current row.
The DEALLOCATE statement completely frees all resources allocated to the cursor,
including the cursor name.
9 Views
Views are virtual table for easier access to data stored in multiple tables.
Syntax for creating a View:
... but it might be easier to do it in the graphical view designer that are built into SQL
Management Studio.
56
57 Views
Example:
We use the SCHOOL and CLASS tables as an example for our View. We want to create a View
that lists all the existing schools and the belonging classes.
We create the VIEW using the CREATE VIEW command:
SELECT
SCHOOL.SchoolName,
CLASS.ClassName
FROM
SCHOOL
INNER JOIN CLASS ON SCHOOL.SchoolId = CLASS.SchoolId
Note! In order to get information from more than one table, we need to link the tables
together using a JOIN.
Step 1: Right-click on the View node and select “New View…”:
Step 2: Add necessary tables:
Step 3: Add Columns, etc.
Structured Query Language (SQL)
60 Views
10 Stored Procedures
A Stored Procedure is a precompiled collection of SQL statements. In a stored procedure you
can use if sentence, declare variables, etc.
Syntax for creating a Stored Procedure:
Note! You need to use the symbol “@” before variable names.
EXECUTE <ProcedureName(…)>
Example:
61
62 Stored Procedures
We use the SCHOOL and CLASS tables as an example for our Stored Procedure. We want to
create a Stored Procedure that lists all the existing schools and the belonging classes.
We create the Stored Procedure as follows:
select
SCHOOL.SchoolName,
CLASS.ClassName
from
SCHOOL
inner join CLASS on SCHOOL.SchoolId = CLASS.SchoolId
order by SchoolName, ClassName
When we have created the Stored Procedure we can run (or execute) the Stored procedure
using the execute command like this:
execute GetAllSchoolClasses
Example:
We use the same tables in this example (SCHOOL and CLASS) but now we want to list all
classes for a specific school.
select
SCHOOL.SchoolName,
CLASS.ClassName
from
SCHOOL
inner join CLASS on SCHOOL.SchoolId = CLASS.SchoolId
where SchoolName=@SchoolName
order by ClassName
or:
When we try to create a Stored Procedure that already exists we get the following error
message:
There is already an object named 'GetSpecificSchoolClasses' in the database.
Then we first need to delete (or DROP) the old Stored Procedure before we can recreate it
again.
A better solution is to add code for this in our script, like this:
select
SCHOOL.SchoolName,
CLASS.ClassName
from
SCHOOL
inner join CLASS on SCHOOL.SchoolId = CLASS.SchoolId
where SchoolName=@SchoolName
order by ClassName
So we use CREATE PROCEDURE to create a Stored Procedure and we use DROP PROCEDURE
to delete a Stored Procedure.
SET NOCOUNT ON stops the message that shows the count of the number of rows affected
by a Transact-SQL statement or stored procedure from being returned as part of the result
set.
SET NOCOUNT ON prevents the sending of DONE_IN_PROC messages to the client for each
statement in a stored procedure. For stored procedures that contain several statements that
do not return much actual data, or for procedures that contain Transact-SQL loops, setting
SET NOCOUNT to ON can provide a significant performance boost, because network traffic is
greatly reduced.
Example:
AS
SET NOCOUNT ON
This Stored Procedure updates a table in the database and in this case you don’t normally
need feedback, sp setting SET NOCOUNT ON at the top in the stored procedure is a good
idea. it is also good practice to SET NOCOUNT OFF at the bottom of the stored procedure.
11 Functions
With SQL and SQL Server you can use lots of built-in functions or you may create your own
functions. Here we will learn to use some of the most used built-in functions and in addition
we will create our own function.
66
67 Functions
• CHAR
• CHARINDEX
• REPLACE
• SUBSTRING
• LEN
• REVERSE
• LEFT
• RIGHT
• LOWER
• UPPER
• LTRIM
• RTRIM
• DATEPART
• GETDATE
• DATEADD
• DATEDIFF
• DAY
• MONTH
• YEAR
• ISDATE
• COUNT
• MIN, MAX
• COS, SIN, TAN
• SQRT
• STDEV
• MEAN
• AVG
11.1.4 AVG()
The AVG() function returns the average value of a numeric column.
Syntax:
Example:
We want to find the average grade for a specific student:
11.1.5 COUNT()
The COUNT() function returns the number of rows that matches a specified criteria.
The COUNT(column_name) function returns the number of values (NULL values will not be
counted) of the specified column:
select COUNT(*) as NumbersofCustomers from CUSTOMER
The GROUP BY statement is used in conjunction with the aggregate functions to group the
result-set by one or more columns.
Syntax
Example:
If we try the following:
Syntax:
First we use the GROUP BY statement:
User-defined functions in SQL are declared using the CREATE FUNCTION statement.
When we have created the function, we can use the function the same way we use built-in
functions.
12 Triggers
A database trigger is code that is automatically executed in response to certain events on a
particular table in a database.
Syntax for creating a Trigger:
The Trigger will automatically be executed when data is inserted, updated or deleted in the
table as specified in the Trigger header.
Inside triggers we can use two special tables: the DELETED table and the INSERTED tables.
SQL Server automatically creates and manages these tables. You can use these temporary,
72
73 Triggers
memory-resident tables to test the effects of certain data modifications. You cannot modify
the data in these tables.
The DELETED table stores copies of the affected rows during DELETE and UPDATE
statements. During the execution of a DELETE or UPDATE statement, rows are deleted from
the trigger table and transferred to the DELETED table.
The INSERTED table stores copies of the affected rows during INSERT and UPDATE
statements. During an insert or update transaction, new rows are added to both the
INSERTED table and the trigger table. The rows in the INSERTED table are copies of the new
rows in the trigger table.
Example:
We will create a TRIGGER that will check if the Phone number is valid when we insert or
update data in the CUSTOMER table. The validation check will be very simple, i.e., we will
check if the Phone number is less than 8 digits (which is normal length in Norway). If the
Phone number is less than 8 digits, the following message “Phone Number is not valid” be
written in place of the wrong number in the Phone column.
DECLARE
@CustomerId int,
@Phone varchar(50),
@Message varchar(50)
set nocount on
GO
VALUES
('1003', 'Obama', 'Barak', 51, 'Nevada', '4444')
As you can see, the TRIGGER works as expected.
13 Communication from
other Applications
A Database is a structured way to store lots of information. The information is stored in
different tables. “Everything” today is stored in databases.
Examples:
• Bank/Account systems
• Information in Web pages such as Facebook, Wikipedia, YouTube
• … lots of other examples
This means we need to be able to communicate with the database from other applications
and programming languages in order to insert, update or retrieve data from the database.
13.1 ODBC
ODBC (Open Database Connectivity) is a standardized interface (API) for accessing the
database from a client. You can use this standard to communicate with databases from
different vendors, such as Oracle, SQL Server, etc. The designers of ODBC aimed to make it
independent of programming languages, database systems, and operating systems.
75
76 Communication from other Applications
14 References
My Blog: https://www.halvorsen.blog
w3shools.com - http://www.w3schools.com/sql
78
Hans-Petter Halvorsen
Copyright © 2017
https://www.halvorsen.blog