chapter 9 sql อ. ยืนยง กันทะเนตร...

51
CHAPTER 9 SQL อ.อออออ อออออออออ ออออออออออออออออออออออออออ อออออออ ออออออออออออออออ 1

Upload: justin-eaton

Post on 18-Jan-2016

236 views

Category:

Documents


3 download

TRANSCRIPT

Page 1: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

CHAPTER 9SQL

อ. ยื�นยืง กั�นทะเนตรคณะเทคโนโลยื�สารสนเทศและกัารส��อสาร

มหาวิ�ทยืาล�ยืพะเยืา

1

Page 2: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

Content

• Introduction to SQL• SQL Syntax• SQL SELECT Statement• SQL SELECT DISTINCT Statement• SQL WHERE Clause• SQL AND & OR Operators• SQL ORDER BY Keyword• SQL INSERT INTO, UPDATE, DELETE Statement

2

Page 3: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

Content

• SQL LIKE, IN, BETWEEN Operator• SQL Joins, INNER JOIN Keyword• SQL SQL LEFT JOIN, RIGHT JOIN Keyword • SQL UNION Operator• SQL CREATE DATABASE, CREATE TABLE Statement• SQL Constraints• SQL DROP• SQL ALTER TABLE Statement• SQL Data Types 3

Page 4: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

Introduction to SQLWhat is SQL?• SQL stands for Structured Query Language• SQL lets you access and manipulate databases• SQL is an ANSI (American National Standards Institute) standard

4

What Can SQL do?• SQL can execute queries against a database• SQL can retrieve data from a database• SQL can insert records in a database• SQL can update records in a database• SQL can delete records from a database• SQL can create new databases• SQL can create new tables in a database• SQL can create stored procedures in a database• SQL can create views in a database• SQL can set permissions on tables, procedures, and views

Page 5: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

Introduction to SQL (cont.)Using SQL in Your Web SiteTo build a web site that shows data from a database, you will need:• An RDBMS database program (i.e. MS Access, SQL Server,

MySQL)• To use a server-side scripting language, like PHP or ASP• To use SQL to get the data you want• To use HTML / CSS

5

RDBMS• RDBMS stands for Relational Database Management System.• RDBMS is the basis for SQL, and for all modern database

systems such as MS SQL Server, IBM DB2, Oracle, MySQL, and Microsoft Access.

Page 6: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL SyntaxSQL StatementsExample

SELECT * FROM Customers;

6

Keep in Mind That...SQL is NOT case sensitive: select is the same as SELECT• In this tutorial we will write all SQL keywords in upper-

case.

Page 7: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Syntax (cont.)Some of The Most Important SQL Commands• SELECT - extracts data from a database• UPDATE - updates data in a database• DELETE - deletes data from a database• INSERT INTO - inserts new data into a database• CREATE DATABASE - creates a new database• ALTER DATABASE - modifies a database• CREATE TABLE - creates a new table• ALTER TABLE - modifies a table• DROP TABLE - deletes a table• CREATE INDEX - creates an index (search key)• DROP INDEX - deletes an index

7

Page 8: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL SELECT StatementThe SQL SELECT StatementThe SELECT statement is used to select data from a database.

SQL SELECT SyntaxSELECT column_name,column_nameFROM table_name;

andSELECT * FROM table_name;

ExampleSELECT CustomerName,City FROM Customers;

ORSELECT * FROM Customers;

8

Page 9: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL SELECT DISTINCT StatementThe SQL SELECT DISTINCT StatementIn a table, a column may contain many duplicate values; and sometimes you only want to list the different (distinct) values.

SQL SELECT DISTINCT SyntaxSELECT DISTINCT column_name,column_nameFROM table_name;

ExampleSELECT DISTINCT City FROM Customers;

9

Page 10: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL WHERE ClauseThe SQL WHERE Clause The WHERE clause is used to extract only those records that fulfill a specified criterion.

SQL WHERE SyntaxSELECT column_name,column_nameFROM table_nameWHERE column_name operator value;

ExampleSELECT * FROM CustomersWHERE Country='Mexico';

10

Page 11: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL WHERE Clause (cont.)Operators in The WHERE Clause

11

Operator Description= Equal

<> Not equal. Note: In some versions of SQL this operator may be written as !=

> Greater than< Less than

>= Greater than or equal<= Less than or equal

BETWEEN Between an inclusive rangeLIKE Search for a patternIN To specify multiple possible values for a column

Page 12: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL AND & OR OperatorsThe SQL AND & OR Operators

The AND operator displays a record if both the first condition AND the second condition are true.

The OR operator displays a record if either the first condition OR the second condition is true.

12

AND Operator ExampleExample

SELECT * FROM CustomersWHERE Country='Germany'AND City='Berlin';

OR Operator ExampleExample

SELECT * FROM CustomersWHERE Country='Germany'OR City='Berlin';

Combining AND & ORSELECT * FROM CustomersWHERE Country='Germany'AND (City='Berlin' OR City='München');

Page 13: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL ORDER BY KeywordThe SQL ORDER BY KeywordThe ORDER BY keyword sorts the records in ascending order by default. To sort the records in a descending order, you can use the DESC keyword.

SQL ORDER BY SyntaxSELECT column_name, column_nameFROM table_nameORDER BY

column_name ASC|DESC, column_name ASC|DESC;

13

Page 14: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL ORDER BY Keyword (cont.)ORDER BY ExampleExample• SELECT * FROM Customers

ORDER BY Country;

14

ORDER BY DESC ExampleExample• SELECT * FROM Customers

ORDER BY Country DESC;

ORDER BY Several Columns ExampleExample• SELECT * FROM Customers

ORDER BY Country ASC, CustomerName DESC;

Page 15: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL INSERT INTO StatementThe SQL INSERT INTO StatementThe INSERT INTO statement is used to insert new records in a table.

SQL INSERT INTO SyntaxINSERT INTO table_nameVALUES (value1,value2,...);

ORINSERT INTO table_name (column1,column2,...)VALUES (value1,value2,...);

15

ExampleINSERT INTO Customers (CustomerName, ContactName, Address,

City, PostalCode, Country) VALUES ('Cardinal','Tom B. Erichsen','Skagen 21',

'Stavanger','4006','Norway');

Page 16: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL UPDATE StatementThe SQL UPDATE StatementThe UPDATE statement is used to update existing records in a table.

SQL UPDATE SyntaxUPDATE table_nameSET column1=value1,column2=value2,...WHERE some_column=some_value;

16

ExampleUPDATE CustomersSET ContactName='Alfred Schmidt', City='Hamburg'WHERE CustomerName='Alfreds Futterkiste';

Page 17: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL DELETE StatementThe SQL DELETE StatementThe DELETE statement is used to delete rows in a table.

SQL DELETE SyntaxDELETE FROM table_nameWHERE some_column=some_value;

ORDELETE * FROM table_name; //delete all

17

ExampleDELETE FROM CustomersWHERE CustomerName='Alfreds Futterkiste' AND

ContactName='Maria Anders';

Page 18: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL LIKE OperatorThe SQL LIKE OperatorThe LIKE operator is used to search for a specified pattern in a column.

SQL LIKE SyntaxSELECT column_name(s)FROM table_nameWHERE column_name LIKE pattern;

18

Page 19: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL LIKE Operator (cont.)SQL LIKE Operator ExamplesExample 1

SELECT * FROM CustomersWHERE City LIKE 's%';

19

SQL LIKE Operator ExamplesExample 2

SELECT * FROM CustomersWHERE City LIKE '%s';

SQL LIKE Operator ExamplesExample 3

SELECT * FROM CustomersWHERE Country LIKE

'%land%';

SQL LIKE Operator ExamplesExample 4

SELECT * FROM CustomersWHERE Country NOT LIKE

'%land%';

Page 20: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL IN OperatorThe IN OperatorThe IN operator allows you to specify multiple values in a WHERE clause.

SQL IN SyntaxSELECT column_name(s)FROM table_nameWHERE column_name IN (value1,value2,...);

ExampleSELECT * FROM CustomersWHERE City IN ('Paris','London');

20

Page 21: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL BETWEEN OperatorThe SQL BETWEEN OperatorThe BETWEEN operator selects values within a range. The values can be numbers, text, or dates.

SQL BETWEEN SyntaxSELECT column_name(s)FROM table_nameWHERE column_name BETWEEN value1 AND value2;

21

BETWEEN Operator ExampleExample• SELECT * FROM Products

WHERE Price BETWEEN 10 AND 20;

NOT BETWEEN Operator ExampleExample• SELECT * FROM Products

WHERE Price NOT BETWEEN 10 AND 20;

Page 22: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL JoinsSQL joins are used to combine rows from two or more tables.

orders table

customers table

22

OrderID CustomerID OrderDate

1 2 2015-06-01

2 2 2015-06-02

3 3 2015-06-4

CustomerID CustomerName Country1 Tom Hang US2 James Camaron TH

3 Peter Jackson CH

Page 23: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL JoinsExample

SELECT Orders.OrderID, Customers.CustomerName, Orders.OrderDate

FROM OrdersINNER JOIN CustomersON Orders.CustomerID = Customers.CustomerID;

23

OrderID CustomerName OrderDate10308 Ana Trujillo 9/18/199610365 Antonio Moreno Taquería 11/27/199610383 Around the Horn 12/16/199610355 Around the Horn 11/15/199610278 Berglunds snabbköp 8/12/1996

Page 24: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL INNER JOIN Keyword

24

SQL INNER JOIN SyntaxSELECT column_name(s)FROM table1INNER JOIN table2ON table1.column_name=table2.column_name;

Page 25: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL INNER JOIN Keyword (cont.)

25

SQL INNER JOIN ExampleThe following SQL statement will return all customers with orders:Example

SELECT Customers.CustomerName, Orders.OrderIDFROM CustomersINNER JOIN OrdersON Customers.CustomerID=Orders.CustomerIDORDER BY Customers.CustomerName;

Page 26: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL LEFT JOIN Keyword

26

SQL LEFT JOIN SyntaxSELECT column_name(s)FROM table1LEFT JOIN table2ON table1.column_name=table2.column_name;

Page 27: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL LEFT JOIN Keyword (cont.)

27

SQL LEFT JOIN ExampleThe following SQL statement will return all customers, and any orders they might have:Example

SELECT Customers.CustomerName, Orders.OrderIDFROM CustomersLEFT JOIN OrdersON Customers.CustomerID=Orders.CustomerIDORDER BY Customers.CustomerName;

Page 28: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL RIGHT JOIN Keyword

28

SQL RIGHT JOIN SyntaxSELECT column_name(s)FROM table1LEFT JOIN table2ON table1.column_name=table2.column_name;

Page 29: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL RIGHT JOIN Keyword (cont.)

29

SQL LEFT JOIN ExampleThe following SQL statement will return all employees, and any orders they have placed:Example

SELECT Orders.OrderID, Customers.CustomerNameFROM CustomersRIGHT JOIN OrdersON Customers.CustomerID=Orders.CustomerIDORDER BY Customers.CustomerName;

Page 30: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL UNION Operator

30

SQL UNION SyntaxSELECT column_name(s) FROM table1UNIONSELECT column_name(s) FROM table2;

SQL UNION ALL SyntaxSELECT column_name(s) FROM table1UNION ALLSELECT column_name(s) FROM table2;

Page 31: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL UNION Operator (cont.)

31

SQL UNION ExampleSELECT CustomerID FROM CustomersUNIONSELECT CustomerID FROM Orders

SQL UNION ALL Example

SELECT CustomerID FROM CustomersUNION ALLSELECT CustomerID FROM Orders

Page 32: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL CREATE DATABASE Statement

32

SQL CREATE DATABASE SyntaxCREATE DATABASE dbname;

SQL CREATE DATABASE Example

CREATE DATABASE my_db;

Page 33: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL CREATE TABLE Statement

33

SQL CREATE TABLE SyntaxCREATE TABLE table_name(

column_name1 data_type(size),column_name2 data_type(size),column_name3 data_type(size),....

);

Page 34: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL CREATE TABLE Statement (cont.)

34

ExampleCREATE TABLE Persons(

PersonID int,LastName varchar(255),FirstName varchar(255),Address varchar(255),City varchar(255)

);

Page 35: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints

35

SQL CREATE TABLE + CONSTRAINT SyntaxCREATE TABLE table_name(column_name1 data_type(size) constraint_name,column_name2 data_type(size) constraint_name,column_name3 data_type(size) constraint_name,....);

Page 36: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

36

In SQL, we have the following constraints:• NOT NULL - Indicates that a column cannot store NULL value• UNIQUE - Ensures that each row for a column must have a unique value• PRIMARY KEY - A combination of a NOT NULL and UNIQUE. Ensures

that a column (or combination of two or more columns) have an unique identity which helps to find a particular record in a table more easily and quickly

• FOREIGN KEY - Ensure the referential integrity of the data in one table to match values in another table

• CHECK - Ensures that the value in a column meets a specific condition• DEFAULT - Specifies a default value when specified none for this column

Page 37: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

37

SQL UNIQUE Constraint on CREATE TABLEThe UNIQUE constraint uniquely identifies each record in a database table.MySQL:

CREATE TABLE Persons(

P_Id int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255),UNIQUE (P_Id)

);

Page 38: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

38

SQL NOT NULL ConstraintThe NOT NULL constraint enforces a column to NOT accept NULL values.

ExampleCREATE TABLE PersonsNotNull(

P_Id int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255)

)

Page 39: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

39

SQL UNIQUE Constraint on CREATE TABLEThe UNIQUE constraint uniquely identifies each record in a database table.MySQL:

CREATE TABLE Persons(

P_Id int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255),UNIQUE (P_Id)

);

Page 40: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

40

SQL PRIMARY KEY ConstraintThe PRIMARY KEY constraint uniquely identifies each record in a database table.MySQL:

CREATE TABLE Persons(

P_Id int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255),PRIMARY KEY(P_Id)

);

Page 41: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

41

SQL FOREIGN KEY ConstraintA FOREIGN KEY in one table points to a PRIMARY KEY in another table.

P_Id LastName FirstName Address City

1 Hansen Ola Timoteivn 10 Sandnes

2 Svendson Tove Borgvn 23 Sandnes

3 Pettersen Kari Storgt 20 Stavanger

O_Id OrderNo P_Id

1 77895 3

2 44678 3

3 22456 2

4 24562 1

Persons Table Orders Table

FOREIGN KEY

PRIMARY KEY

PRIMARY KEY

Page 42: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

42

SQL FOREIGN KEY Constraint on CREATE TABLEMySQL:

CREATE TABLE Orders(

O_Id int NOT NULL,OrderNo int NOT NULL,P_Id int,PRIMARY KEY (O_Id),FOREIGN KEY (P_Id) REFERENCES Persons(P_Id)

)

Page 43: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

43

SQL CHECK ConstraintMySQL:

CREATE TABLE Persons(

P_Id int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255),CHECK (P_Id>0)

)

Page 44: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Constraints (cont.)

44

SQL DEFAULT ConstraintMySQL:

CREATE TABLE Persons(

P_Id int NOT NULL,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255) DEFAULT 'Sandnes'

)

Page 45: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL DROP

45

The DROP TABLE StatementDROP TABLE table_name

The DROP DATABASE StatementDROP DATABASE database_name

Page 46: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL ALTER TABLE Statement

46

The ALTER TABLE StatementThe ALTER TABLE statement is used to add, delete, or modify

columns in an existing table. Syntax

ALTER TABLE table_nameADD column_name datatype

ORALTER TABLE table_nameDROP COLUMN column_name

Page 47: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL AUTO INCREMENT Field

47

AUTO INCREMENT a FieldAuto-increment allows a unique number to be generated

when a new record is inserted into a table. Syntax

CREATE TABLE Persons(

ID int NOT NULL AUTO_INCREMENT,LastName varchar(255) NOT NULL,FirstName varchar(255),Address varchar(255),City varchar(255),PRIMARY KEY (ID)

)

Page 48: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Data Types

48

MySQL Data TypesText types:

Data type DescriptionCHAR(size) Holds a fixed length string (can contain letters, numbers, and special characters). VARCHAR(size) Holds a variable length string (can contain letters, numbers, and special characters). TINYTEXT Holds a string with a maximum length of 255 charactersTEXT Holds a string with a maximum length of 65,535 charactersBLOB For BLOBs (Binary Large OBjects). Holds up to 65,535 bytes of dataMEDIUMTEXT Holds a string with a maximum length of 16,777,215 charactersMEDIUMBLOB For BLOBs (Binary Large OBjects). Holds up to 16,777,215 bytes of dataLONGTEXT Holds a string with a maximum length of 4,294,967,295 charactersLONGBLOB For BLOBs (Binary Large OBjects). Holds up to 4,294,967,295 bytes of dataENUM(x,y,z,etc.) Let you enter a list of possible values. You can list up to 65535 values in an ENUM

list. SET Similar to ENUM except that SET may contain up to 64 list items and can store more

than one choice

Page 49: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Data Types (cont.)

49

MySQL Data TypesNumber types:

Data type DescriptionTINYINT(size) -128 to 127 normal. 0 to 255 UNSIGNED*. The maximum number of digits may be

specified in parenthesisSMALLINT(size) -32768 to 32767 normal. 0 to 65535 UNSIGNED*. The maximum number of digits

may be specified in parenthesisMEDIUMINT(size) -8388608 to 8388607 normal. 0 to 16777215 UNSIGNED*. The maximum number

of digits may be specified in parenthesisINT(size) -2147483648 to 2147483647 normal. 0 to 4294967295 UNSIGNED*. The maximum

number of digits may be specified in parenthesisBIGINT(size) -9223372036854775808 to 9223372036854775807 normal. 0 to

18446744073709551615 UNSIGNED*. The maximum number of digits may be specified in parenthesis

FLOAT(size,d) A small number with a floating decimal point. DOUBLE(size,d) A large number with a floating decimal point. DECIMAL(size,d) A DOUBLE stored as a string , allowing for a fixed decimal point.

Page 50: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

SQL Data Types (cont.)

50

MySQL Data TypesDate types:

Data type Description

DATE() A date. Format: YYYY-MM-DDNote: The supported range is from '1000-01-01' to '9999-12-31'

DATETIME() *A date and time combination. Format: YYYY-MM-DD HH:MI:SSNote: The supported range is from '1000-01-01 00:00:00' to '9999-12-31 23:59:59'

TIMESTAMP() *A timestamp. TIMESTAMP values are stored as the number of seconds since the Unix epoch ('1970-01-01 00:00:00' UTC). Format: YYYY-MM-DD HH:MI:SSNote: The supported range is from '1970-01-01 00:00:01' UTC to '2038-01-09 03:14:07' UTC

TIME() A time. Format: HH:MI:SSNote: The supported range is from '-838:59:59' to '838:59:59'

YEAR() A year in two-digit or four-digit format.Note: Values allowed in four-digit format: 1901 to 2155. Values allowed in two-digit format: 70 to 69, representing years from 1970 to 2069

Page 51: CHAPTER 9 SQL อ. ยืนยง กันทะเนตร คณะเทคโนโลยีสารสนเทศและการสื่อสาร มหาวิทยาลัยพะเยา

51

THE END