Tuesday, 28 August 2007

Static Testing & Dynamic Testing

Static Testing :
The Verification activities fall into the category of Static Testing. During static testing, you have a checklist to check whether the work you are doing is going as per the set standards of the organization. These standards can be for Coding, Integrating and Deployment. Review's, Inspection's and Walkthrough's are static testing methodologies.

Dynamic Testing :
Dynamic Testing involves working with the software, giving input values and checking if the output is as expected. These are the Validation activities. Unit Tests, Integration Tests, System Tests and Acceptance Tests are few of the Dynamic Testing methodologies.

Q: What is the difference between static and dynamic testing?

Difference number 1: Static testing is about prevention, dynamic testing is about cure.

Difference number 2: The static tools offer greater marginal benefits.

Difference number 3: Static testing is many times more cost-effective than dynamic testing.

Difference number 4: Static testing beats dynamic testing by a wide margin.

Difference number 5: Static testing is more effective!

Difference number 6: Static testing gives you comprehensive diagnostics for your code.

Difference number 7: Static testing achieves 100% statement coverage in a relatively short time, while dynamic testing often often achieves less than 50% statement coverage, because dynamic testing finds bugs only in parts of the code that are actually executed.

Difference number 8: Dynamic testing usually takes longer than static testing. Dynamic testing may involve running several test cases, each of which may take longer than compilation.

Difference number 9: Dynamic testing finds fewer bugs than static testing.

Difference number 10: Static testing can be done before compilation, while dynamic testing can take place only after compilation and linking.

Difference number 11: Static testing can find all of the followings that dynamic testing cannot find: syntax errors, code that is hard to maintain, code that is hard to test, code that does not conform to coding standards, and ANSI violations.

Different Types of Testing

DIFF TYPES OF TESTING DEFINITIONS

*Black box testing - not based on any knowledge of internal design or code. Tests are based on requirements and functionality.

White box testing - based on knowledge of the internal logic of an application's code. Tests are based on coverage of code statements, branches, paths, conditions.

Unit testing - the most 'micro' scale of testing; to test particular functions or code modules. Typically done by the programmer and not by testers, as it requires detailed knowledge of the internal program design and code. Not always easily done unless the application has a well-designed architecture with tight code; may require developing test driver modules or test harnesses.

Incremental integration testing - continuous testing of an application as new functionality is added; requires that various aspects of an application's functionality be independent enough to work separately before all parts of the program are completed, or that test drivers be developed as needed; done by programmers or by testers.

Integration testing - testing of combined parts of an application to determine if they function together correctly. The 'parts' can be code modules, individual applications, client and server applications on a network, etc. This type of testing is especially relevant to client/server and distributed systems.

Functional testing - black-box type testing geared to functional requirements of an application; this type of testing should be done by testers. This doesn't mean that the programmers shouldn't check that their code works before releasing it .

System testing - black-box type testing that is based on overall requirements specifications; covers all combined parts of a system.

End-to-end testing - similar to system testing; the 'macro' end of the test scale; involves testing of a complete application environment in a situation that mimics real-world use, such as interacting with a database, using network communications, or interacting with other hardware, applications, or systems if appropriate.

Sanity testing or smoke testing - typically an initial testing effort to determine if a new software version is performing well enough to accept it for a major testing effort. For example, if the new software is crashing systems every 5 minutes, bogging down systems to a crawl, or corrupting databases, the software may not be in a 'sane' enough condition to warrant further testing in its current state.

Regression testing - re-testing after fixes or modifications of the software or its environment. It can be difficult to determine how much re-testing is needed, especially near the end of the development cycle. Automated testing tools can be especially useful for this type of testing.

Acceptance testing - final testing based on specifications of the end-user or customer, or based on use by end-users/customers over some limited period of time.

Load testing - testing an application under heavy loads, such as testing of a web site under a range of loads to determine at what point the system's response time degrades or fails.

Stress testing - term often used interchangeably with 'load' and 'performance' testing. Also used to describe such tests as system functional testing while under unusually heavy loads, heavy repetition of certain actions or inputs, input of large numerical values, large complex queries to a database system, etc.

Performance testing - term often used interchangeably with 'stress' and 'load' testing. Ideally 'performance' testing (and any other 'type' of testing) is defined in requirements documentation or QA or Test Plans.

Usability testing - testing for 'user-friendliness'. Clearly this is subjective, and will depend on the targeted end-user or customer. User interviews, surveys, video recording of user sessions, and other techniques can be used. Programmers and testers are usually not appropriate as usability testers.

Install/uninstall testing - testing of full, partial, or upgrade install/uninstall processes.

Recovery testing - testing how well a system recovers from crashes, hardware failures, or other catastrophic problems.

Failover testing - typically used interchangeably with 'recovery testing'

Security testing - testing how well the system protects against unauthorized internal or external access, willful damage, etc; may require sophisticated testing techniques.

Compatability testing - testing how well software performs in a particular hardware/software/operating system/network/etc. environment.

Exploratory testing - often taken to mean a creative, informal software test that is not based on formal test plans or test cases; testers may be learning the software as they test it.

Ad-hoc testing - similar to exploratory testing, but often taken to mean that the testers have significant understanding of the software before testing it.

Context-driven testing - testing driven by an understanding of the environment, culture, and intended use of software. For example, the testing approach for life-critical medical equipment software would be completely different than that for a low-cost computer game.

User acceptance testing - determining if software is satisfactory to an end-user or customer.

Comparison testing - comparing software weaknesses and strengths to competing products.

Alpha testing - testing of an application when development is nearing completion; minor design changes may still be made as a result of such testing. Typically done by end-users or others, not by programmers or testers.

Beta testing - testing when development and testing are essentially completed and final bugs and problems need to be found before final release. Typically done by end-users or others, not by programmers or testers.

Mutation testing - a method for determining if a set of test data or test cases is useful, by deliberately introducing various code changes ('bugs') and retesting with the original test data/cases to determine if the 'bugs' are detected.

Soak Test :-
Soak testing is running a system at high levels of load for prolonged periods of time. A soak test would normally execute several times more transactions in an entire day (or night) than would be expected in a busy day, to identify any performance problems that appear after a large number of transactions have been executed.
Web Testing :-
GUI Testing
Broken Link Testing
Performance Testing


Configuration Testing :-

Testing to determine how well the product works with a broad range of hardware/peripheral equipment configurations as well as on different operating systems and software.

Client Server Testing:-
The testing of Client / Server software occurs at three different levels: Client application testing isolation, Client software and associated Server application testing in concert and Complete Client / Server system testing including Network operation & Performance testing.

Compatibility Testing :-
Testing used to determine whether other system software components such as browsers, utilities, and competing software will conflict with the software being tested.

SQL

SQL : Structured Query Language.
It is a language that provides an interface to relational database systems.
SQL was developed by IBM in the 1970s for use in System R.
SQL is a de facto standard, as well as an ISO and ANSI standard..
It is a special-purpose, nonprocedural language that supports the definition, manipulation, and control of data in relational database management systems.

SQL Introduction - Introduction to SQL

SQL allows users to access data in relational database management systems, such as Oracle,Informix,Sybase, Microsoft SQL Server, Access etc.

SQL allows users to manipulate and define the data in a database.

SQL is an ANSI standard computer language

Strucured Query Language

SQL may frequently pronounced “sequel” but the alternate pronunciation “S.Q.L.” is also used. As the name implies, SQL is a computer language that you use to interact with a database. In fact, SQL works with a specific type of database, called a relational database.

SQL is more than a query tool, although that was its original purpose, and retrieving data is still one of its most important functions. SQL is used to control all of the functions of DBMS which provides for its users, including:

Data Definition Language. In DDL user define the structure and organization of the stored data and relationships among the stored data items.

Data Retrieval Language. An application program to retrieve stored data from the database and use it.

Data Manipulation Language. DML allows a user or an application program to update the database by adding new data, removing old data, and modifying previously stored data.

Data Control Language. DCL can be used to restrict a user’s ability to retrieve, add, and modify data, protecting stored data against unauthorized access.

Data sharing. Is used to coordinate data sharing by concurrent users, ensuring that they do not interfere with one another.

Data intigrity. It defines integrity constraints in the database, protecting it from corruption due to inconsistent updates or system failures.

SQL Queries

Query is a loose term that refers to a widely available set of SQL commands called clauses. Each clause or command performs some sort of function against the database. For instance, the create clause creates tables in databse and the select clause selects rows that have been inserted into your tables.

Construction of Query begins with one of the following clauses:
Add
Drop
Create
Insert
Select
Update
Replace
Delete


SQL Query Syntax
The syntax of a query is loose, meaning you are free to place line breaks and spacing where you please without injuring the code.Few instances require parentheses, including the insert statement listed below. Parentheses will also be covered during our Functions lesson. Be sure to end all query statements with a semicolon (;).

SQL Code:
SELECT * FROM table_name;

SQL Select Statement - Select command is use to select data from the tables

Select Command
Select command is use to select data from the tables located in a database.If we need to SELECT information FROM a table.

The most basic SQL structure:

SELECT "column_name" FROM "table_name"

To illustrate the above example, assume that we have the following table Name "Store_Information" :

store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

To select all the stores in this table

SELECT store_name FROM Store_Information

Output

Store_name
Los Angeles
San Diego
Los Angeles
Boston


Distinct Keyword:

The SELECT keyword allows us to take all information from a column (or columns) on a table. Of course, there is probability of redundancies. What if we only want to select each DISTINCT element? This is easy to accomplish in SQL. All we need to do is to add DISTINCT after SELECT. The syntax is as follows:


SELECT DISTINCT "column_name" FROM "table_name"

For example, to select all distinct stores in Table "Store_Information".

SELECT DISTINCT store_name FROM Store_Information

Output

Store_name
Los Angeles
San Diego
Boston

SQL WHERE Clause - To conditionally select the data from a table

The WHERE Clause

--------------------------------------------------------------------------------

WHERE Syntax

To conditionally select the data from a table the WHERE clause is used . eg.if we want to retrieve stores with sales above $1,000. To do this, we use the WHERE keyword. The syntax is as follows:


SELECT "column_name"
FROM "table_name"
WHERE "condition"

For example, to select all stores with sales above $1,000 in Table Store_Information.

store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005


SQL command

SELECT store_name
FROM Store_Information
WHERE Sales > 1000

Notes: SQL uses single quotes around string values (most database systems will also accept double quotes). Numeric values not be enclosed in quotes.


Output

store_name
Los Angeles


--------------------------------------------------------------------------------

The following operators can be used with where clause:

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


Note:In some versions of SQL the <> operator is equivalent to != operator

SQL Insert Statement -
The insert clause has one function; to insert data into a table.




Insert Command
The insert clause has one function; to insert data into a table. Insert populates each table column with a value. Rows are inserted one right after another into the coresponding column.



--------------------------------------------------------------------------------

SQL Code:

INSERT INTO employees (Lastname,Firstname,Title)
VALUES(Johnson,David,crew);

Output

Lastname Firstname Title
Johnson David crew


--------------------------------------------------------------------------------

SQL - Insert defaults and nulls

We mentioned setting up default or null values for table columns. Simply placing the word default or null, in place of a value is the solution.


SQL Code:

INSERT INTO employees (Lastname,Firstname,Title)
VALUES('Hively','Jessica',DEFAULT);
or
INSERT INTO employees (Lastname,Firstname,Title)
VALUES('Hively','Jessica',NULL);



--------------------------------------------------------------------------------

SQL - Inserting multilpe values

Here's an example of how to insert more than one record at a time. Many web developers will use the single example above along with HTML forms to continually insert and update their SQL tables.


SQL Code:

INSERT INTO employees VALUES
(DEFAULT,'Hicks','Freddy','crew'),
(DEFAULT,'Harris','Joel','crew'),
(DEFAULT,'Davis','Julie','manager');


--------------------------------------------------------------------------------

SQL - Insert into multiple tables

This concept isn't widely supported by open source database programs, however they do offer alternative methods to achieve the same goal. The idea is to insert similar record values into 2 or more tables with one statement. Using the example from above, we want to place Julie's information into our manager table as well as the general employee table.


SQL Code:

INSERT ALL INTO employees (Lastname,Firstname,Title)
VALUES('Davis','Julie','manager')
INTO manager (training,salary)
VALUES ('yadayada','22500');

SQL Update Statement
- This command updates the column values of a table.

Update Command

This command updates the column values of a table.Update requires a conditional statement for selecting the row which is to be updated.


Syntax:

UPDATE employees
SET Lastname = 'Fletcher' WHERE Firstname = 'David';


Output

Lastname Firstname Title
Fletcher David crew


--------------------------------------------------------------------------------

Updating Multiple Rows

With the use of operators and expressions, update allows for the manipulation of several rows at once.



Syntax:

UPDATE employees
SET Title = UPPER(Title);


Output

ID Lastname Firstname Title
1 Fletcher David CREW
2 Hively Jessica CREW
9 Hicks Freddy CREW
10 Harris Joel CREW
11 Davis Julie MANAGER


Note:-By using UPPER expression we changed our Title field to all capital letters.
------------------------------------------------------------------------------
SQL Delete Statement
- Delete command removes Entire rows from a table.

SQL DELETE Statement

Delete command removes Entire rows from a table.

Syntax:

DELETE FROM employees WHERE id='4';


--------------------------------------------------------------------------------


For Deleting Multiple Rows

Delete may use with SQL operators as well as subqueries to delete any or all rows that apply to our conditional.

Syntax

DELETE * FROM employees;

Note:The above example delete each row from employees table

--------------------------------------------------------------------------------

SQL Truncate statement

Truncate removes all the rows from the table and cannot be Rollbacked, while delete removes all or specific rows from table and can be rollbacked. Truncate is used for HUGE databases & Delete will work efficiently on small database table.

Syntax:

TRUNCATE TABLE employees;

SQL Order By Clause - Order By Command The order by statement allows for table column range. WHERE keyword might be used to conditionally select data from a table.

Order By Command


The order by statement allows for table column range. It allows for ascending or descending lists of column values, permitting SQL to reorder your table rows for the purpose of viewing.

Syntax:

SELECT * FROM employees ORDER BY Lastname;

Output:-

Lastname Firstname Title
Davis Julie manager
Harris Joel crew
Hicks Freddy crew
Hively Jessica crew
Johnson David crew

The above example arrange our rows of data alphabetically by lastname.


--------------------------------------------------------------------------------


Ordering by two different columns

First we alphabatize our job titles and again we order by lastname.

Syntax:

SELECT * FROM employees ORDER BY Title,Lastname;

Output:-

Lastname Firstname Title
Harris Joel crew
Hicks Freddy crew
Hively Jessica crew
Johnson David crew
Davis Julie manager
---------------------------------------------------------------------------
SQL AND OR Operator
- WHERE keyword might be used to conditionally select data from a table.

SQL And Or Operator

WHERE keyword might be used to conditionally select data from a table. This condition can be a simple condition or it can be a compound condition.Compound conditions are made up of multiple simple conditions connected by AND/OR. There is no limit to the number of conditions that can be present in a single SQL statement.

Syntax of Compound condition
SELECT "column_name"
FROM "table_name"
WHERE "simple condition"
{[AND|OR] "simple condition"}+

Note:-The {}+ means that the expression inside the bracket will occur one or many times.AND and OR can be used interchangeably. In addition,to indicate the order of the condition we may use the parenthesis sign ().

e.g. we may wish to select all store_name with sales greater than $1,000 or all stores with sales less than $500 but greater than $275 in Table Store_Information,

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

For selecting the store_name following Query:

SELECT store_name FROM Store_Information WHERE Sales > 1000 OR (Sales < 500 AND Sales > 275)

Output

store_name
Los Angeles

San Francisco
-----------------------------------------------------
SQL in operator
- A special kind of operator which uses with where clauses.

SQL In Operator

In is a special kind of operator which uses with where clauses. In the where expression only one value is allowed to be sent through the query. With help of in operator you can send multiple values in the where clause.

The syntax of IN keyword is as follows:

Syntax

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

Let's you wish to select all records for the Los Angeles and the San Diego stores in Table Store_Information,

The Values inside parenthesis can be one or more, with each values separated by comma. Values can be characters or numerical. If there is only one value inside the parenthesis, then command is equivalent to :-

WHERE "column_name" = 'value1'

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

Command

SELECT * FROM Store_Information WHERE store_name IN ('Los Angeles', 'San Diego')

Output

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
-----------------------------------------------------------------------------
SQL Between
- The BETWEEN keyword allows for selecting a values in range.

SQL - Between

The BETWEEN keyword allows for selecting a values in range. The syntax for the BETWEEN clause is given below

--------------------------------------------------------------------------------


Syntax:

SELECT "column_name"
FROM "table_name"
WHERE "column_name" BETWEEN 'value1' AND 'value2'

It select all rows whose column has a value between 'value1' and 'value2'.

For example,to select all sales information between January 6, 2005, and January 10, 2005, in Table Store_Information

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

Syntax

SELECT *
FROM Store_Information
WHERE Date BETWEEN 'Jan-06-2005' AND 'Jan-10-2005'

Note:Date may be stored in different formats in different databases.
Output

Store_name Sales Date
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005
-----------------------------------------------------------------------
SQL Aliases
- Aliases for table and column.

SQL Alias

Most frequently two types of aliases are used:-
Column Alias
Table Alias.


--------------------------------------------------------------------------------

Column Name Alias Syntax:-

SELECT column AS column_alias FROM table


--------------------------------------------------------------------------------

Table Name Alias

Syntax :-

SELECT column FROM table AS table_alias


--------------------------------------------------------------------------------

Example:

Column aliases exist to organizing output.In the previous example, whenever there is total sales, it is listed as SUM(sales). While this is understandable, we can have many cases where the column heading can be complicated (especially if it involves several arithmetic operations). Using a column alias its make the output much more readable.

Second is the table alias.This is accomplished by putting an alias directly after the table name in the FROM clause. This is convenient when you want to obtain information from two separate tables ('perform joins'). The advantage of using a table alias when doing joins is readily apparent when we talk about joins.

Both types of aliases are placed directly after the item they alias for, separate by a white space. We again use our table, Store_Information,

Syntax

SELECT A1.store_name Store, SUM(A1.Sales) "Total Sales"
FROM Store_Information A1
GROUP BY A1.store_name

Output

Store Total Sales
Los Angeles $1800
San Diego $250
Boston $700


Notice that difference in the result that the column titles are now different. That is the result of using the column alias. Notice that instead of the somewhat cryptic "Sum(Sales)", we now have "Total Sales", which is much more understandable, as the column header. The advantage of using a table alias is not visible in this example. However, they will become evident in the Join Section
------------------------------------------------------------------
SQL Join
- Combines columns of one table to that of another.

SQL Join

To create a single table the join clause combines columns of one table to that of another. Join matches up a column with one table to a column in another. A join query does not alter table, but temporarily combines data from each table to be viewed as a single table.Mainly three types of join statements:-

Inner/Equi Join
Left Join
Right Join


--------------------------------------------------------------------------------

Inner Join :-
An inner join returns all matching rows.For example given below

Table:-Store_Information

Store_name Sales Date
Los Angeles $1500 Jan-05-1999
San Diego $250 Jan-07-1999
Los Angeles $300 Jan-08-1999
Boston $700 Jan-08-1999


Table:-Geography

Region_name Store_name
East Boston
East New York
West Los Angeles
West San Diego

Let us we want to find out sales by region. For geting the sales information by region, we have to combine the information from the two tables.Examining the two tables, we find that they are linked via the common field, "store_name". First present the SQL Query and then explain the use:


SELECT A1.region_name REGION, SUM(A2.Sales) SALES
FROM Geography A1, Store_Information A2
WHERE A1.store_name = A2.store_name
GROUP BY A1.region_name

Output:-

REGION SALES
East $700
West $2050

The first two lines tell SQL to select two fields, the first one is the field "region_name" from table Geography (aliased as REGION), and the second one is the sum of the field "Sales" from table Store_Information (aliased as SALES). Notice how the table aliases are used here: Geography is aliased as A1, and Store_Information is aliased as A2. Without the aliasing, the first line would become


SELECT Geography.region_name REGION, SUM(Store_Information.Sales) SALES

which is much more bulky. In essence, table aliases make the entire SQL statement easier to understand, especially when multiple tables are included.

Next, we turn our attention to line 3, the WHERE statement. This is where the condition of the join is specified. In this case, we want to make sure that the content in "store_name" in table Geography matches that in table Store_Information, and the way to do it is to set them equal. This WHERE statement is essential in making sure you get the correct output. Without the correct WHERE statement, a Cartesian Join will result. Cartesian joins will result in the query returning every possible combination of the two (or whatever the number of tables in the FROM statement) tables. In this case, a Cartesian join would result in a total of 4 x 4 = 16 rows being returned.



--------------------------------------------------------------------------------

SQL - Left Join
A Left join returns all rows of the left of the conditional even if there is no right column to match.

--------------------------------------------------------------------------------
SQL - Right Join
A right join will display rows on the right side of the conditional that may or may not have a match.
--
SQL Outer Join - A type of join.

SQL Outer Join

Previously, we had looked at inner join, where we select rows common to the participating tables to a join. One case is that if we are interested in selecting elements in a table regardless of whether they are present in the second table? We will now need to use the SQL OUTER JOIN command.

--------------------------------------------------------------------------------

Example:
The syntax for performing an outer join in SQL is database-dependent. For example, in Oracle, we will place an "(+)" in the WHERE clause on the other side of the table for which we want to include all the rows.

Let's we have the following two tables,

Table:-Store_Information

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

Table:-Geography

Region_name Store_name
East Boston
East New York
West Los Angeles
West San Diego

If we want to find out sales by region. We see that table Geography includes information on regions and stores, and table Store_Information contains sales information for each store. To get the sales information by region, we have to combine the information from the two tables. Examining the two tables, we find that they are linked via the common field, "store_name".

SELECT A1.store_name, SUM(A2.Sales) SALES
FROM Geography A1, Store_Information A2
WHERE A1.store_name = A2.store_name (+)
GROUP BY A1.store_name

Output:-

Store_name SALES
Boston $700
New York
Los Angeles $1800
San Diego $250

Note: When there is no match on the second table NULL is returned . In this case, "New York" does not appear in the table Store_Information, thus its corresponding "SALES" column is NULL.

SQL Union
- Combine the results of two queries together.

SQL Union

SQL UNION combine the results of two queries together. In this respect, UNION is similar to JOIN in that they are both used to related information from multiple tables. One restriction of UNION is that all corresponding columns need to be of the same data type and UNION only select distinct values.


--------------------------------------------------------------------------------
Syntax:

[SQL Statement 1]
UNION
[SQL Statement 2]


Table Store_Information

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005


Table Internet_Sales

Date Sales
Jan-07-2005 $250
Jan-10-2005 $535
Jan-11-2005 $320
Jan-12-2005 $750

If we want to find out all the dates where there is a sales transaction.We use the following SQL statement:


SELECT Date FROM Store_Information
UNION
SELECT Date FROM Internet_Sales


Output:

Date
Jan-05-2005
Jan-07-2005
Jan-08-2005
Jan-10-2005
Jan-11-2005
Jan-12-2005


--------------------------------------------------------------------------------
SQL UNION ALL
The SQL UNION ALL command is also to combine the results of two queries together. The difference between UNION ALL and UNION is that, UNION ALL selects all values while UNION only selects distinct values.

Syntax :

SELECT Date FROM Store_Information
UNION ALL
SELECT Date FROM Internet_Sales

Output :

Date
Jan-05-2005
Jan-07-2005
Jan-08-2005
Jan-08-2005
Jan-07-2005
Jan-10-2005
Jan-11-2005
Jan-12-2005

-------------------------------------------------------------
SQL Subqueries
- Queries placed within an existing SQL statement.

SQL Subqueries

Subqueries are queries placed within an existing SQL statement. MySQL offers a very limited support for subqueries, however Oracle and DB2 fully support them. They may exist in any of the following types of SQL statements.

--------------------------------------------------------------------------------

Syntax:

SELECT "column_name1"
FROM "table_name1"
WHERE "column_name2" [Comparison Operator]
(SELECT "column_name3"
FROM "table_name2"
WHERE [Condition])


--------------------------------------------------------------------------------

Example:

Table: Store_Information

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005


Table: Internet_Sales

Date Sales
Jan-07-2005 $250
Jan-10-2005 $535
Jan-11-2005 $320
Jan-12-2005 $750

If we want to use a subquery to find the sales of all stores in the West region. Then we use the following SQL statement:


SELECT SUM(Sales) FROM Store_Information
WHERE Store_name IN
(SELECT store_name FROM Geography
WHERE region_name = 'West')

Output:

SUM(Sales)
2050


Here instead of joining the two tables directly and then adding up only the sales amount for stores in the West region, we use subquery to find out which stores are in the West region and then add the sales amount for these stores.
---------------------------------------------------------------------
SQL Date Function
- All SQL platform has its own version of date functions.

SQL Dates

All SQL platform has its own version of date functions.

--------------------------------------------------------------------------------

SQL - Timestamp
A timestamp servers as the catch all for dates and times. Retrieving a timestamp is very simple and the result can be manipulated in nearly every way possible.

Syntax:

Select Current_Timestamp;

Return a Timestamp:

2005-06-22 11:33:11.840


--------------------------------------------------------------------------------
SQL Date Functions
By using any of the following date functions it is possible to breakdown timestamps into their individual pieces.

SQL Function Code:

SELECT MONTH(CURRENT_TIMESTAMP);- Return a Month(6)

SELECT DAY(CURRENT_TIMESTAMP);-Return a Day:(22)

SELECT DATE(CURRENT_TIMESTAMP); - returns a date (2004-06-22)

SELECT TIME(CURRENT_TIMESTAMP); - returns the time (10:33:11.840)

SELECT DAYOFWEEK(CURRENT_TIMESTAMP); - returns a numeric value (1-7)

SELECT DAYOFMONTH(CURRENT_TIMESTAMP); - returns a day of month (1-31)

SELECT DAYOFYEAR(CURRENT_TIMESTAMP); - returns the day of the year (1-365)

SELECT MONTHNAME(CURRENT_TIMESTAMP); - returns the month name (January - December)

SELECT DAYNAME(CURRENT_TIMESTAMP); - returns the name of the day (Sunday - Saturday)

SELECT WEEK(CURRENT_TIMESTAMP); - returns number of the week (1-53)
--------------------------------------------------------------

SQL Create Statement
- Create statement in SQL

Create Table Statement :
Tables are the structure where data is stored in the database. In most cases, there is no way for the database vendor to know ahead of time what your data storage needs are, then tables in the database makes itself. Many database tools allow you to create tables automatically,but always tables are the container of all the data, it is important to include the CREATE TABLE syntax in this tutorial.

Tables are divided into rows and columns. Each row represents one piece of data, and each column represent a component of piece of data.Example, if we have a table for recording customer information, then the columns may include information such as First Name, Last Name, birth Date, Address, City, Country, and so on. As a result, when we specify a table, we include the column headers and the data types for that particular column.

Data comes in a variety of forms. It could be an integer (such as 1), a real number (such as 0.55), a date/time expression (such as '2000-JAN-25 03:22:22'),a string (such as 'sql'), or even in binary format. When we specify a table, we need to specify the data type associated with each column (i.e., we will specify that 'First Name' is of type char(40) - meaning it is a string with 40 characters). One thing to note is that different relational databases allow for different data types.


Syntax

CREATE TABLE "table_name"
("column 1" "data_type_for_column_1",
"column 2" "data_type_for_column_2",
... )

Example

CREATE TABLE customer
(First_Name char(50),
Last_Name char(50),
Address char(50),
City char(50),
Country char(25),
Birth_Date date)



--------------------------------------------------------------------------------

Create Index Statement
Index are used to retrieve data from tables by quicker way. Let's use an example it is much quicker for us to go to the index section at the end of the book, locate which pages contain information that we want and then go to these pages directly. Going to the index first saves us time and is by far a more efficient method for locating the information we need.

This principle applies for retrieving data from a database table. Without an index, the database system reads through the entire table (this process is called a 'table scan') to locate the desired information. With the proper index the database system can then first go through the index to find out where to retrieve the data, and then go to these locations directly to get the needed data. This is much faster.

Therefore, it is often desirable to create indexes on tables. An index can cover one or more columns.

Syntax

CREATE INDEX "INDEX_NAME" ON "TABLE_NAME" (COLUMN_NAME)

Example

CREATE INDEX IDX_CUSTOMER_LAST_NAME on CUSTOMER (Last_Name)


--------------------------------------------------------------------------------

Primary Key
A primary key is used to uniquely identify each row in a table. It can either be part of the actual record itself , or it can be an artificial field (one that has nothing to do with the actual record). A primary key consist of one or more fields on a table. When multiple fields are used as a primary key then it is called composite key.

Primary keys can be specified either when the table is created or by changing the existing table structure with alter command.

CREATE TABLE Customer (SID integer, Last_Name varchar(30), First_Name varchar(30), PRIMARY KEY (SID));

ALTER TABLE Customer ADD PRIMARY KEY (SID);
--------------------------------------------------------------------------------

Foreign Key
A foreign key is a field that points to the primary key of another table. The purpose of the foreign key is to ensure referential integrity means only values that are supposed to appear in the database are permitted.

For example, say we have two tables, a CUSTOMER table that includes all customer data, and an ORDERS table that includes all customer orders. The constraint here is that all orders must be associated with a customer that is already in the CUSTOMER table. In this case, we will place a foreign key on the ORDERS table and have it relate to the primary key of the CUSTOMER table. By this way, we can ensure that all orders in the ORDERS table are related to a customer in the CUSTOMER table. In other words, the ORDERS table cannot contain information on a customer that is not in the CUSTOMER table.

Both Table is given below:-

Table CUSTOMERS

column name characteristic
SID Primary Key
Last_Name
First_Name

Table ORDERS

column name characteristic
Order_ID Primary Key
Order_Date
Customer_SID Foreign Key
Amount

In the above example, the Customer_SID column in the ORDERS table is a foreign key pointing to the SID column in the CUSTOMER table.
Syntax

CREATE TABLE ORDERS
(Order_ID integer,
Order_Date date,
Customer_SID integer,
Amount double,
Primary Key (Order_ID),
Foreign Key (Customer_SID) references CUSTOMER(SID));
------------------------------------------------------------------------------
SQL Drop Statement
- Delete an existing index in a table with the DROP INDEX statement.

SQL Drop Index, Table and Database

--------------------------------------------------------------------------------

Drop Index

You can delete an existing index in a table with the DROP INDEX statement.

Syntax: Microsoft Access

DROP INDEX index_name ON table_name

Syntax: MS SQL Server

DROP INDEX table_name.index_name

Syntax: IBM DB2 and Oracle

DROP INDEX index_name

Syntax: MySQL

ALTER TABLE table_name DROP INDEX index_name


--------------------------------------------------------------------------------

Delete a Table or Database
To delete a table (the table structure, attributes, and indexes will also be deleted):

DROP TABLE table_name

To delete a database:

DROP DATABASE database_name
------------------------------------------------------------
SQL Alter
- Change the structure of the table.

SQL Alter Table

Once a table is created in the database, there are many condition where we have to change the structure of the table.
Add a column
Drop a column
Change a column name
Change the data type for a column
changing the primary key specification

Syntax

ALTER TABLE "table_name" [alter specification]

Let's use above syntax with "customer" table

Column Name Data Type
First_Name char(50)
Last_Name char(50)
Address char(50)
City char(50)
Country char(25)
Birth_Date date

If we want to add a column called "Gender" to this table. Syntax given below:

ALTER table customer add Gender char(1)

If we want to rename "Address" to "Addr".Syntax given below:

ALTER table customer change Address Addr char(50)

If we want to change the data type for "Addr" to char(30).Syntax given below:

ALTER table customer modify Addr char(30)

If we want to drop the column "Gender".Syntax given below:

ALTER table customer drop Gender
--------------------------------------------------------------------------------

SQL Function
- A function is a special type of command that return a single value.

SQL Functions
A function is a special type of command that return a single value.

--------------------------------------------------------------------------------

Types of Functions
The basic types of functions are:-

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

Scalar functions
It operate against a single value, and return a single value based on the input value.Functions like CURRENT_TIME for example, do not require any arguments.

Syntax:

SELECT function(column) FROM table

Aggregate Functions
It return a single value based upon a set of other values. If used among many other expressions in the item list of a SELECT statement, the SELECT must have a GROUP BY clause. No GROUP BY clause is required if the aggregate function is the only value retrieved by the SELECT statement

Supported aggregate functions are:

Function Usage
AVG(expression) Computes the average value of a column by the expression
COUNT(expression) Counts the rows defined by the expression
COUNT(*) Counts all rows in the specified table or view
MIN(expression) Finds the minimum value in a column by the expression
MAX(expression) Finds the maximum value in a column by the expression
SUM(expression) Computes the sum of column values by the expression

Example:
SELECT COUNT(*) FROM customers;


--------------------------------------------------------------------------------
Scalar Functions
Different categories of Scalar Function are:-
Built-in Function
Date & Time Function
Numeric Function
String Function

Some Scalar Functions are:-

Function Description
UCASE(c) Converts a field to upper case
LCASE(c) Converts a field to lower case
MID(c,start[,end]) Extract characters from a text field
LEN(c) Returns the length of a text field
INSTR(c,char) 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 right part of a text field requested
ROUND(c,decimals) Rounds a numeric field to the number of decimals specified
MOD(x,y) Returns the remainder of a division operation
NOW() Returns the current system date
FORMAT(c,format) Changes the way a field is displayed
DATEDIFF(d,date1,date2) Used to perform date calculations

SQL Group By Statement
- The aggregate of all column values.

Group By clause
When Aggregate functions (like SUM) called it return the aggregate of all column values.It was impossible to find the sum for each individual group of column values so Group By clause used.

--------------------------------------------------------------------------------

Syntax:

SELECT "column_name1", SUM("column_name2") FROM "table_name" GROUP BY "column_name1"

Let's following table "Store_Information"

Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

To find total sales for each store:-

SELECT store_name, SUM(Sales)
FROM Store_Information
GROUP BY store_name

Output

Store_name SUM(Sales)
Los Angeles $1800
San Diego $250
Boston $700

The GROUP BY keyword is used when selecting multiple columns from tables and at least one arithmetic operator appears in the SELECT statement.


--------------------------------------------------------------------------------
Having Clause
To limit the output based on the corresponding sum (or any other aggregate functions). For example, we might want to see only the stores with sales over $1,500. Instead of using the WHERE clause in the SQL statement, though, we need to use the HAVING clause, which is reserved for aggregate functions. The HAVING clause is placed near the end of the SQL statement. SQL statement with the HAVING clause may or may not include the GROUP BY clause.

Syntax: Having Clause

SELECT "column_name1", SUM("column_name2")
FROM "table_name"
GROUP BY "column_name1"
HAVING (arithmetic function condition)

In our example, table "Store_Information" we would type.

SELECT store_name, SUM(sales)
FROM Store_Information
GROUP BY store_name
HAVING SUM(sales) > 1500

Output

store_name SUM(Sales)
Los Angeles $1800


SQL Select Into
- Make a backup copy

Select into Statement
To create a make-table query means for making backup copies of tables and reports, or for archiving records.

Syntax

SELECT column_name(s) INTO newtable [IN externaldatabase] FROM source

Make a Backup Copy

The example given below makes a backup copy of the "Persons" table:

SELECT * INTO [Customers Backup] FROM Customers;

The IN clause may be used to copy tables into another database:

SELECT Suppliers.* INTO Suppliers IN 'Backup.mdb' FROM Suppliers;

If you only want to copy a few fields not copy whole Table, you can do so by listing them after the SELECT statement. The following query creates a Fiddlers table by extracting the names of fiddlers from a Musicians table:


SELECT Name INTO Fiddlers
FROM Musicians
WHERE Instrument = 'fiddle';

The fields which you copy into a new table need not come from just one table. You can copy from multiple tables as demonstrated in the next example which selects fields from the two tables Suppliers and Products to create a new table for Mexican Suppliers:


SELECT Suppliers.Name, Product, Products.UnitPrice
INTO [Mexican Suppliers]
FROM Suppliers INNER JOIN Products
ON Suppliers.ProductID = Products.ProductID
WHERE Suppliers.Country = 'Mexico';

The SELECT...INTO statement doesn't define a primary key for the new table, so you may want to do that manually.
-------------------------------------------------------------------------------------

SQL Create View
- Virtual table based on the result-set of a SELECT statement.

View?
A VIEW is a virtual table based on the result-set of a SELECT statement. A view contains rows and columns like a real table. The fields in a view consist fields from one or more real tables in the database.

Syntax:

Views may be considered as virtual tables. Generalize way a table has a set of definition, and it physically stores the data. A view also has a set of definitions, which is build on top of table(s) or other view(s), and it does not physically store the data.


CREATE VIEW "VIEW_NAME" AS "SQL Statement"

Example:

TABLE Customer
(First_Name char(50),
Last_Name char(50),
Address char(50),
City char(50),
Country char(25),
Birth_Date date)

and we want to create a view called V_Customer that contains only the First_Name, Last_Name, and Country columns from this table, we would type in,

CREATE VIEW V_Customer
AS SELECT First_Name, Last_Name, Country
FROM Customer

Now we have a view called V_Customer with the following structure:

View V_Customer
(First_Name char(50),
Last_Name char(50),
Country char(25))

--------------------------------------------------------------------------------

Apply View on Joins
To joins two or more tables view can be used. In this case, users only see one view rather than two tables, and the SQL statement users need to issue becomes much simpler. Let's say we have the following two tables:

Table:Store_Information
Store_name Sales Date
Los Angeles $1500 Jan-05-2005
San Diego $250 Jan-07-2005
Los Angeles $300 Jan-08-2005
Boston $700 Jan-08-2005

Table: Geography
region_name store_name
East Boston
East New York
West Los Angeles
West San Diego

If we want to build a view that has sales by region information. We would issue the following SQL statement:


CREATE VIEW V_REGION_SALES
AS SELECT A1.region_name REGION, SUM(A2.Sales) SALES
FROM Geography A1, Store_Information A2
WHERE A1.store_name = A2.store_name
GROUP BY A1.region_name

It gives a view called V_REGION_SALES, that has been defined to store sales by region records. If we want to find out the content of this view then following query:

SELECT * FROM V_REGION_SALES

Output:
REGION SALES
East $700
West $2050

--------------------------------------------------------------------------------
SQL Server - SQL server

SQL Servers - RDBMS

Modern SQL Servers used Relational Data Base Management System.


--------------------------------------------------------------------------------

DBMS - Database Management System
A DBMS is a computer program that can access data from a database.
The DBMS program enables you to modify,store and extract information from a database.
DBMS programs provides different functions for querying data, modifying data and reporting data.

--------------------------------------------------------------------------------

RDBMS - Relational Database Management System
A RDBMS is a Database Management System where the database is organized and accessed according to the relationships between data stored in table.

it was invented by IBM in the early 1970's.

RDBMS is the base of SQL for all modern database systems like Oracle, SQL Server, IBM DB2, Mesql, Sybase and Microsoft Access.


SELECT * FROM V_REGION_SALES

SQL Summary - Summary
SQL Summary
Now you have been introduced to the standard language of SQL . including the client/server systems, relational database and Web-based database systems, all of which are fundamental of understanding of SQL.

The database that will be used during your course of study was also introduced. The database, which you have seen has consisted of a few tables, which are related to one another, and the data that each table contains at this point. You should have acquired some concept of a modern database and overall background knowledge of the fundamentals of SQL.



This tutorial also taught the how to access and manipulat database systems.
You have learned how to execute queries,insert new records, retrieve data, delete records and update records in a database with SQL.


END