This is my group presentation about "SQL Injection".
And This is "Assignment 2 part 3 of 3".
[Week 18]
Database Systems
Database System Subject Learning on 3rd of Computer Engineering KMUTNB
วันเสาร์ที่ 14 พฤษภาคม พ.ศ. 2559
[A2 part 3 of 3] SQL Injection
[A2 part 2 of 3] Database Log file & Recovery
This is my group presentation about "Database Log file & Recovery".
And This is "Assignment 2 part 2 of 3".
[week 16]
And This is "Assignment 2 part 2 of 3".
[week 16]
ป้ายกำกับ:
A2
,
Database Log file & Recovery
,
Week 16
[A2 part 1 of 3] Security of Database
This is my group presentation about "Security of Database".
And This is "Assignment 2 part 1 of 3".
[Week 15]
And This is "Assignment 2 part 1 of 3".
[Week 15]
ป้ายกำกับ:
A2
,
Database
,
Database Security
,
Security
,
Security of Database
,
week 15
What's PostgreSQL? and Introduces
This is my group presentation about "PostgreSQL".
and This's a Link to "What's PostgreSQL? and Introduces" published by my partner group.
http://db5620072.blogspot.com/2016/04/postgresql.html
ps. I am Group 7 right now (From Group 5) and then I will use new database (University Enterprise Database).
and This's a Link to "What's PostgreSQL? and Introduces" published by my partner group.
http://db5620072.blogspot.com/2016/04/postgresql.html
ps. I am Group 7 right now (From Group 5) and then I will use new database (University Enterprise Database).
วันอังคารที่ 29 มีนาคม พ.ศ. 2559
A1 : ER Diagram
Assignment 1 : ER Diagram
We have an Assignment I that's about the ER Diagram of "Book Store".
So you can click this directly to see our work.
วันอังคารที่ 9 กุมภาพันธ์ พ.ศ. 2559
Relational Algebra Operation
Relational Algebra Operation สานสัมพันธ์ Algebra
วันนี้เราจะมาพูดถึงความสัมพันธ์ของ "อาเจ๊(บ้า)" กันดีกว่า
ขอกล่าวก่อนว่า "อาเจ๊" ที่ผมจะใช้ในบทความอันนี้ ขอแทนคำว่า Algebra เพื่อความ Cool นะครับ อิ้อิ้
Cover Content เนื้อหาภายใน Content นี้
- Part 1: TR - The Relations ความ3000 (สามพัน)
- Part 2: TQ - The Questions ถามมา-ตอบไป
Part 1: TR - The Relations ความ3000 (สามพัน)
ซึ่งความสัมพันธ์จะมีอยู่ทั้งหมด 6 รูปแบบ ที่จะมาแนะนำกันให้รับทราบในวันนี้นะครับ
- Select (σ) *
- Project (∏) *
- Rename (ρ) *
- Cartesian Product (X) **
- Union (U) **
- Difference (-) **
หมายเหตุ: * แทนการใช้งานโดยมี Operator 1 ตัว, ** แทนการใช้งานโดยมี Operator 2 ตัว
1. Select (σ) เป็น unary relational operation หรือกล่าวได้ว่า ใช้ Operator 1 ตัวนั้นเอง และ Syntax ของมันก็คือ σ p (t) โดยที่ p เป็น Condition และ t เป็น table โดยหลักการของ select แล้ว เราจะใช้สำหรับการ "เลือก" ข้อมูลจากในตาราง ซึ่งในการเลือกเราก็มีเงื่อนไขกำหนดไว้ด้วย
ตัวอย่างการใช้งาน
ตัวอย่างการใช้งาน
σSTD_NAME = “James” (STUDENT)
จากข้างต้นจะเป็นการเลือกข้อมูลที่มีเงื่อนไข STD_NAME ตรงกับ "James" จากในตาราง STUDENT ซึ่งผลลัพธ์ที่ได้ก็จะเป็นดั่งรูป
σdept_id = 20 AND salary>=10000 (EMPLOYEE)
จากข้างต้นจะเป็นการ Query 2 เงื่อนไข โดยเงื่อนไขแรกคือค่า dept_id จะต้องเท่ากับ 20 และ ค่า salary จะต้องมากกว่าหรือเท่ากับ 10000 ซึ่งทั้งหมดนี้เราจะเลือกออกมาจากตาราง EMPLOYEE ทั้งหมด ผลลัพธ์จะได้ว่า
2. Project (∏) เป็น unary relational operation หรือกล่าวได้ว่า ใช้ Operator 1 ตัวเช่นเดียวกัน และ Syntax ของมันก็คือ ∏a1, a2, a3 (t) ซึ่ง a1, a2, a3 เป็น Column ในตาราง และ t เป็นชื่อของตาราง หลักการใช้ Project นั้นคือจะเป็นการเลือก Column บางส่วน(หรือทั้งหมด)จากตาราง แล้วนำมาแสดง (ทำหน้าที่เหมือน SELECT ใน SQL)
ตัวอย่างการใช้งาน
∏std_name, address, course (STUDENT)
จากข้างต้น เราจะทำการเลือก Column std_name, address, course จาก table STUDENT และผลลัพธ์ที่ได้ก็จะแสดงแค่ส่วนที่เลือก ซึ่งจะไม่แสดงส่วนอื่นๆเลย ดังรูป
3. Rename (ρ) เป็น unary relational operation หรือกล่าวได้ว่า ใช้ Operator 1 ตัวเช่นเดียวกัน และ Syntax ของมันก็คือ ρ R(E) ซึ่ง R เป็นชื่อเดิมของ Table ที่ต้องการจะเปลี่ยนชื่อ และ E เป็นชื่อใหม่ของ Table ที่ต้องการ หลักการใช้ Rename นั้นคือการเปลี่ยนชื่อ ตามคำแปลในพจนานุกรมเลยครับ มาดูตัวอย่างการใช้เลยครับ
ตัวอย่างการใช้งาน
ρ STUDENT (STD_TABLE)
กล่าวคือจะเป็นการเปลี่ยนชื่อ STUDENT table เป็นชื่อ STD_TABLE แทน ดังรูป
ซึ่งเราสามารถเปลี่ยนชื่อ Column ได้ด้วยนะ หากแต่ต้องเป็น Syntax แบบนี้ ρ STD_ID, STD_NAME, STD_ADDRESS(STUDENT) โดยที่ STD_ID บลาๆ เป็นชื่อ Column ไล่ตามลำดับในตาราง และ STUDENT ก็คือตารางที่เราต้องการจะเปลี่ยนนั่นเอง
4. Cartesian product (X) เป็น binary relational operation หรือกล่าวได้ว่า ใช้ Operator 2 ตัว และ Syntax ของมันก็คือ R X S โดยที่ R และ S เป็นตารางซึ่งผลที่ได้ก็จะได้ผลลัพธ์แบบ ผลคูณ Cartesian ในอาเจ๊เช่นเดียวกัน
ตัวอย่างการใช้งาน
EMPLOYEE X DEPT
โดยคำอธิบายก็คือ นำเอา Table ที่ชื่อ EMPLOYEE และ DEPT มาหาผลคูณ Cartesian กันได้ผลลัพธ์ดังรูป
5. Union (U) เป็น binary relational operation หรือกล่าวได้ว่า ใช้ Operator 2 ตัว และ Syntax ของมันก็คือ R U S โดยที่ R และ S เป็นตารางซึ่งผลที่ได้ก็จะได้ผลลัพธ์แบบการ Union กันในอาเจ๊เช่นเดียวกัน
ตัวอย่างการใช้งาน
DESIGN_EMPLOYEE U TESTING_EMPLOYEE
โดยคำอธิบายก็คือ นำเอา Table ที่ชื่อ DESIGN_EMPLOYEE และ TESTING_EMPLOYEE มาทำการ Union กันได้ผลลัพธ์ดังรูป
6. Difference (-) เป็น binary relational operation หรือกล่าวได้ว่า ใช้ Operator 2 ตัว และ Syntax ของมันก็คือ R – S โดยที่ R และ S เป็นตารางซึ่งผลที่ได้ก็จะได้ผลลัพธ์แบบการ Difference กันในอาเจ๊เช่นเดียวกัน
ตัวอย่างการใช้งาน
DESIGN_EMPLOYEE −TESTING_EMPLOYEE
โดยคำอธิบายก็คือ นำเอา Table ที่ชื่อ DESIGN_EMPLOYEE และ TESTING_EMPLOYEE มาทำการ Difference กันได้ผลลัพธ์ดังรูป
แถมมมมม
หากใครยังพอมีบุญเก่าเรื่อง Intersection ยังพอจำกันได้ ในที่นี้ก็มีเหมือนกันนะครับ แต่ว่าไม่ได้เป็น Primary สักเท่าไหร่เพราะเราสามารถแตก R ∩ S --> R-(R-S) ได้นั่นเองครับ
Part 2: TQ - The Questions ถามมา-ตอบไป
Q: What is an inner join? outer join?
A: อยากให้มอง Inner Join เป็นในลักษณะของ Intersection ข้อมูลกันระหว่างตาราง A และ ตาราง B ส่วน Outer Join จะแบ่งออกได้เป็น 3 รูปแบบ คือ Left Outer Join (A - B), Right Outer Join (B - A), Full Outer Join (A U B) โดยที่ A และ B เป็น Set ตารางของข้อมูลนะครับ และที่สำคัญของคำว่า Join เลยก็คือ การเอาส่วนของ Column ของตารางทั้งหมดมารวมกัน เป็นตารางเดียวกันครับ
ตัวอย่าง Left Outer Join
ตัวอย่าง Right Outer Join
ตัวอย่าง Full Outer Join
ซึ่งถ้าใครสนใจจะอ่านเพิ่มเติม (มีโค้ดตัวอย่าง) สามารถเข้าไปชมต่อได้ที่ SQLHINTS.COM
------------------------
Q: What is a division operation in SQL?
A: การ Division หรือการหารใน SQL ก็เป็นเช่นเดียวกันกับการหารในอาเจ๊นั่นแหละ และยังคล้ายกันกับ Inner Join ด้วยแต่ความต่างอยู่ที่ Column ของตารางไม่ได้รวมกันเหมือน Join แต่จะยึดตาราง "ตัวหาร" เป็นตารางหลักนะครับ
ตัวอย่าง Division Operation
ที่มารูปภาพ: www.tutorialcup.com
Thanks ขอขอบคุณ:
1. Joins by sqlhints
2. Relation Query Languages by tutorialcup
ป้ายกำกับ:
Relational Algebra Operation
,
SQL
,
Week 4
วันจันทร์ที่ 1 กุมภาพันธ์ พ.ศ. 2559
SQL Constraints
Do you know The Constraints ?? รู้จัก Constraints กันหรือเปล่า
so then what's the "constraints" ?? แล้ว อะไรคือ Constraints ล่ะ
Constraints คือ ข้อจำกัด หรือ ข้อบังคับ หรือ เงื่อนไข ของการเก็บข้อมูลนั่นเอง ถ้าเราได้ลองมองดูดีๆแล้วจะพบว่า ถ้าในการเก็บข้อมูลของเรา ไม่มีการกำหนดสิ่งเหล่านี้ไว้...จะเกิดปัญหาต่อ DB ของเราในอนาคตภายภาคหน้าหรือเปล่า เช่น หาคีย์ไม่เจอ ค่าอะไรก็ไม่รู้ บลาๆๆ
แต่ไม่ต้องกังวลอะไรทั้งนั้น เพราะวันนี้เราจะมาเรียนรู้กันในเรื่องนี้ไปด้วยกัน อันดับแรก ไปดู Cover Content ก่อนเลยดีกว่าคร้าบ
Cover Content เนื้อหาภายใน Content นี้
- Part 1: Constraints = Limitation ??
- Part 2: Tiny things of my selected DBMS เกร็ดเล็กน้อยยยย
Part 1: Constraints = Limitation ??
ส่วนแรกเลยก่อนที่จะพิสูจน์สมการดังกล่าวข้างต้น จะอธิบายก่อนว่า Constraints มีอะไรบ้าง ซึ่งก็จะมีดังนี้- NOT NULL - column cannot store NULL value
- UNIQUE - each row for a column must have a unique value
- PRIMARY KEY - column have a unique identity
- FOREIGN KEY - the referential integrity of the data in one table to match values in another table
- CHECK - the value in a column meets a specific condition
- DEFAULT - specifies a default value for a column
นี่เลยครับ Syntax คร่าวๆให้มองภาพออก
CREATE TABLE table_name ( column_name1 data_type(size) constraint_name, column_name2 data_type(size) constraint_name, column_name3 data_type(size) constraint_name, .... );
สังเกตตรง Constraints Name นะครับตรงนั้นแหละที่เราจะไปดูกันต่อไป ส่วนวิธีการใช้งานสิ่งเหล่านี้ ก็จะนำเสนอดังต่อไปนี้ครับ
NOT NULL เป็นการกำหนดให้ data จะต้องไม่เก็บเป็น NULL นะครับ
CHECK คือการตรวจสอบเงื่อนไขก่อน ซึ่งก่อนที่จะเก็บข้อมูลลงใน database ก็ต้องผ่านเงื่อนไขนี้เท่านั้น
DEFAULT เป็นการกำหนดค่าดั้งเดิมให้กับค่า Column นั้นๆ หากไม่ได้กำหนดตอน Add Data
CREATE TABLE Persons ( ID int NOT NULL, Name varchar(20) NOT NULL, Surname varchar(20), Gender varchar(1) DEFAULT 'M', CHECK (ID>0) );
เมื่อลองรันดู ผลลัพธ์จะได้
อธิบาย: ในที่นี้เราจะสร้าง Table ชื่อว่า Persons มาใหม่มีข้อมูลเป็น
- ID: INT ใช้เงื่อนไข CHECK > 0 และ NOT NULL
- Name: VARCHAR ขนาด 20 ตัวอักษร และ NOT NULL
- Surname: VARCHAR ขนาด 20 ตัวอักษร
- Gender: VARCHAR ขนาด 1 ตัวอักษร โดยกำหนด DEFAULT คือ M (Male)
ลำดับต่อไปจะลองทดสอบกันดู
กรณีแรก ID=NULL, Name="first", Surname="one", Gender="F"
insert into persons(Name,Surname,Gender) value ('first','one','F');
ผลลัพธ์ คือส่วนของ Constraint NOT NULL ครับผม
กรณีสอง ID=-2, Name="second", Surname="two", Gender="F"
insert into persons(ID,Name,Surname,Gender) value (-2,'second','two','F');
ผลลัพธ์ คือส่วนของ Constraint CHECK ครับผม
หมายเหตุ: ทาง MySQL ได้อธิบายว่า "The CHECK
clause is parsed but ignored by all storage engines." นะครับผม โดยสามารถหาอ่านได้ใน CREATE_TABLE Doc
กรณีสาม ID=3, Name="third", Surname="three", Gender=NULL
insert into persons(ID,Name,Surname) value (3,'third','three');
ผลลัพธ์ คือส่วนของ Constraint DEFAULT ครับผม
ส่วนต่อไปจะเป็นการแนะนำ Constraints UNIQUE, PRIMARY KEY นะครับ
โดยจะขอกล่าวถึง UNIQUE ก่อนว่าส่วนนี้ จะเป็นการบ่งบอกว่า ข้อมูลในแต่ละ entry นั้นมีความ Unique ของตัวเอง หรือมองได้ง่ายๆว่า ไม่มีใครซ้ำนั้นเองครับ ส่วนของ PRIMARY KEY จะเป็นเหมือน key ที่เป็นหลัก กล่าวคือ มีค่าเป็น NULL ไม่ได้นั้นเอง (ได้ Constraint ของ NOT NULL ด้วยเป็นไงๆๆ)
เพื่อเป็นการไม่เสียเวลา เรามาลองกันเลยดีกว่าครับ โดยอันดับแรกให้ทำการสร้าง Table ใหม่ โดยเราจะกำหนด Primary Key และ Unique Column ด้วยนะครับ
create table members(member_id varchar(3) primary key, name varchar(20),phone_number varchar(10) unique); insert into members(member_id,name,phone_number) value ('001','Alice','0834567890'); insert into members(member_id,name,phone_number) value ('002','Bob','0809876543');
และทำการใส่ data ไปสัก 2 entry ผลลัพธ์จะได้ดังรูป
เมื่อเราพยายามลองขัดขืน ในการยัด data ด้วยการขัดต่อ Constraints ด้วย Code นี้
insert into members(member_id,name,phone_number) value ('001','Cathy','0855555555'); insert into members(member_id,name,phone_number) value ('004','Douge','0809876543');
ก็จะได้ผลดังนี้ครับ
อธิบาย: ใน Code จะถูกประกอบด้วย PRIMARY KEY และ UNIQUE นะครับ ถ้าเราพยายามยัด data เข้าไป จะเกิด ERROR เป็น Duplicate Entry นะครับ ซึ่งผลก็จะเป็นของ Constraint PRIMARY KEY กับ Constraint UNIQUE ตามลำดับ
จากนั้นเราลองไปดู FOREIGN KEY กันต่อเลย โดย Foreign Key จะเป็นตัวอ้างอิง Relation หรือความสัมพันธ์ระหว่าง 2 ความสัมพันธ์น่ะครับ เป็น Reference ระหว่าง Key นั้นเองงงงง มาลองดูกัน
อันดับแรกให้สร้างตารางขึ้นมาใหม่ และทำการ Add ข้อมูลเพิ่มเข้าไปในตารางเดิม (members)
create table membersdetail(id varchar(3), age int, height int, weight int,foreign key(id) references members(member_id)); insert into members(member_id,name,phone_number) value ('003','Cathy','0819871472'); insert into members(member_id,name,phone_number) value ('004','Douge','0895172253');
ผลการทดลอง
และลอง Add ข้อมูลในตารางใหม่ (membersdetail) เข้าไป
insert into membersdetail(id,age,height,weight) value ('002',19,168,62); insert into membersdetail(id,age,height,weight) value ('005',24,175,68);
ผลลัพธ์
อธิบาย: สาเหตุที่ ข้อมูล entry แรก ใส่เข้าไปได้เพราะมีการ Reference หรืออ้างอิง id ของตารางใหม่ ที่มีค่าอยู่ใน member_id กล่าวคือ ถ้าในตารางแรก (members) มี id ที่ 3 อยู่เมื่อเราจะ Add entry เข้าไปในตารางใหม่ (membersdetail) จำเป็นต้องใช้ id ที่มีอยู่ใน id ของตารางแรก ซึ่งในที่นี้คือ 3 เช่นเดียวกัน หากแต่ว่าถ้าเรา Add entry เข้าไปใหม่ แต่ id ไม่มีอยู่ในตารางแรก ก็จะไม่สามารถ Add ค่าเข้าไปได้ (หรือการ Update) จึงเป็นที่มาของ Constraint FOREIGN KEY ครับผม
Part 2: Tiny things of my selected DBMS เกร็ดเล็กน้อยยยย
ส่วน part นี้นะครับ จะเป็นการบอกอะไรเล็กๆน้อยๆ เกี่ยวกับ DBMS ที่ผมเลือกใช้ กับ 3 คำถามที่จะถามและตอบในโพสต์นี้ ซึ่งในที่นี้ DBMS ที่ผมเลือกใช้ก็คือ MySQL นะครับ มาดูกันครับว่าจะมีอะไรบ้าง1) Q: What's constraints of MySQL? ใน MySQL นั้นมี Constraints อะไรบ้าง??
A: มีเหมือนข้างต้นที่กล่าวเอาไว้ และนอกจาก Constraints ที่กล่าวมาข้างต้นแล้วนั้น ยังมี Constraints เพิ่มขึ้นมาอีก นั่นก็คือ ENUM และ SET
โดย ENUM จะเป็นเหมือนตัวเลือก เช่น 'High', 'Medium', 'Low' ซึ่งในการ Add entry จะสามารถเลือก ได้เพียงแค่ 3 ค่านี้เท่านั้น
และ SET ก็คล้ายๆกับ ENUM แต่เราสามารถเลือกได้เป็นแบบ Set เลยนั้นเอง เช่น 'S1, S2, S5'
2) Q: How specify them? เราจะกำหนดมันอย่างไร
A: จากข้างต้น เรามีการกำหนด Constraints ต่างๆไปแล้ว เหลือแต่ ENUM และ SET ซึ่งจะเป็นดังนี้
ENUM specify:
CREATE TABLE Shops(Id INTEGER, Name VARCHAR(55), Quality ENUM('High', 'Average', 'Low'));
SET specify:
CREATE TABLE Students(Id INTEGER, Name VARCHAR(55), Certificates SET('A1', 'A2', 'B1', 'C1'));
3) Q: Give an Example? ลองยกตัวอย่างให้ดูหน่อย
A: สำหรับ ENUM
mysql> INSERT INTO Shops VALUES(1, 'Boneys', 'High'); mysql> INSERT INTO Shops VALUES(2, 'AC River', 'Average'); mysql> INSERT INTO Shops VALUES(3, 'AT 34', '**'); mysql> SELECT * FROM Shops; +------+----------+-----------+ | Id | Name | Quality | +------+----------+-----------+ | 1 | Boneys | High | | 2 | AC River| Average | | 3 | AT 34 | | +------+----------+-----------+
และสำหรับ SET จะได้
mysql> INSERT INTO Students VALUES(1, 'Paul', 'A1,B1'); mysql> INSERT INTO Students VALUES(2, 'Jane', 'A1,B1,A2'); mysql> INSERT INTO Students VALUES(3, 'Mark', 'A1,A2,D1,D2'); mysql> SELECT * FROM Students; +------+--------+--------------+ | Id | Name | Certificates | +------+--------+--------------+ | 1 | Paul | A1,B1 | | 2 | Jane | A1,A2,B1 | | 3 | Mark | A1,A2 | +------+--------+--------------+
ขอขอบคุณ Thanks:
1) MySQL Constraints
2) W3Schools.com
3) Hilite
4) CREATE_TABLE MySQL Document
สมัครสมาชิก:
บทความ
(
Atom
)