Thứ Hai, 24 tháng 7, 2023

Database mẫu để học SQL Server

Để tiện cho việc học thì ta cần một database mẫu, và tất cả những thao tác sau này đều dựa trên database này, tên của nó là BikeStores (cửa hàng xe đạp).

Trước tiên bạn hãy xem qua cấu trúc danh sách các table đã nhé.

Mục lục

  • 1. Cấu trúc database BikeStores
  • 2. Giải thích về các tables
    • table sales.stores
    • Table sales.staffs
    • Table production.categories
    • Table production.brands
    • Table production.products
    • Table sales.customers
    • Table sales.orders
    • Table sales.order_items
    • Table production.stocks

1. Cấu trúc database BikeStores

Hình ảnh dưới đâu là cấu trúc database BikeStores.

SQL Server Sample Database png

Bài viết này được đăng tại [free tuts .net]

Được chia làm hai nhóm như sau:

  • Nhóm bán hàng gồm (schema tên là sales): Customers, Staffs, Orders, Stores, Order_items
  • Nhóm sản phẩm gồm (schema tên là production): Categories, Products, Stocks, Brands.

Một số chú ý về mô hình:

  • Dấu sao (*) thể hiện cho khóa chính
  • Các kí hiệu về mối liên hệ được thể hiện qua các đường kéo giữa các bảng. Mình sẽ không giải thích phần này nhé, nó là phần kiến thức căn bản.

2. Giải thích về các tables

Nếu bạn chưa hiểu cấu trúc ở trên thì hãy tham khảo phần giải thích sau.

table sales.stores

Đây là bảng chứa thông tin của cửa hàng, mỗi cửa hàng có tên, thông tin liên hệ như phone, email, và địa chỉ gồm: street, city, state, zip code. Khóa chính của bảng này là store_id.

1
2
3
4
5
6
7
8
9
10
CREATE TABLE sales.stores (
 store_id INT IDENTITY (1, 1) PRIMARY KEY,
 store_name VARCHAR (255) NOT NULL,
 phone VARCHAR (25),
 email VARCHAR (255),
 street VARCHAR (255),
 city VARCHAR (255),
 state VARCHAR (10),
 zip_code VARCHAR (5)
);

Table sales.staffs

Đây là bảng chứa thông tin nhân viên của cửa hàng, gồm các thông tin như first name, last name và các thông tin khác như email, phone.

Mỗi nhân viên sẽ làm việc tại một cửa hàng và mối liên hệ của nó chính là khóa ngoại staffs.store_id trỏ đến stores.store_id.

Mỗi nhân viên sẽ được quản lý bởi một trưởng nhóm, vì trưởng nhóm cũng là nhân viên nên sẽ có một khóa ngoại manager_id trỏ đến chính staff_id của bảng này.

Nếu một nhân viên bị đuổi và không làm việc tại một cửa hàng nào cả thì sẽ thiết lập active = 0.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
CREATE TABLE sales.staffs (
 staff_id INT IDENTITY (1, 1) PRIMARY KEY,
 first_name VARCHAR (50) NOT NULL,
 last_name VARCHAR (50) NOT NULL,
 email VARCHAR (255) NOT NULL UNIQUE,
 phone VARCHAR (25),
 active tinyint NOT NULL,
 store_id INT NOT NULL,
 manager_id INT,
 FOREIGN KEY (store_id)
        REFERENCES sales.stores (store_id)
        ON DELETE CASCADE ON UPDATE CASCADE,
 FOREIGN KEY (manager_id)
        REFERENCES sales.staffs (staff_id)
        ON DELETE NO ACTION ON UPDATE NO ACTION
);

Table production.categories

Đâu là bảng chứa chuyên mục sản phẩm, ví dụ xe đạp địa hình, xe đạp người lớn, xe đạp trẻ em, ...

1
2
3
4
CREATE TABLE production.categories (
 category_id INT IDENTITY (1, 1) PRIMARY KEY,
 category_name VARCHAR (255) NOT NULL
);

Table production.brands

Đây là bảng chứa thương hiệu của sản phẩm, tức là thông tin về công ty sản xuất xe đạp.

1
2
3
4
CREATE TABLE production.brands (
 brand_id INT IDENTITY (1, 1) PRIMARY KEY,
 brand_name VARCHAR (255) NOT NULL
);

Table production.products

Đây là bảng quan trọng nhất, chứa danh sách của sản phẩm.

Mỗi sản phẩm sẽ có một nhà sản xuất (brand_id), đây là khóa ngoại trỏ đến bảng brands.

Mỗi sản phẩm sẽ thuộc một chuyên mục nào đó (category_id), đây là khóa ngoại trỏ đến bảng categories.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
CREATE TABLE production.products (
 product_id INT IDENTITY (1, 1) PRIMARY KEY,
 product_name VARCHAR (255) NOT NULL,
 brand_id INT NOT NULL,
 category_id INT NOT NULL,
 model_year SMALLINT NOT NULL,
 list_price DECIMAL (10, 2) NOT NULL,
 FOREIGN KEY (category_id)
        REFERENCES production.categories (category_id)
        ON DELETE CASCADE ON UPDATE CASCADE,
 FOREIGN KEY (brand_id)
        REFERENCES sales.brands (brand_id)
        ON DELETE CASCADE ON UPDATE CASCADE
);

Table sales.customers

Bảng thông tin khách hàng, gồm các thông tin như: first name, last name, phone, email, street, city, state and zip code.

1
2
3
4
5
6
7
8
9
10
11
CREATE TABLE sales.customers (
 customer_id INT IDENTITY (1, 1) PRIMARY KEY,
 first_name VARCHAR (255) NOT NULL,
 last_name VARCHAR (255) NOT NULL,
 phone VARCHAR (25),
 email VARCHAR (255) NOT NULL,
 street VARCHAR (255),
 city VARCHAR (50),
 state VARCHAR (25),
 zip_code VARCHAR (5)
);

Table sales.orders

Bảng chứa các đơn hàng của khách hàng, gồm các thông tin của khách hàng và thông tin sản phẩm cần mua.

Mỗi đơn hàng sẽ có ba khóa ngoại đó là:

  • customer_id: khoa ngoại trỏ đến bảng customers
  • store_id: khóa ngoại trỏ đến bảng stores
  • staff_id: khóa ngoại trỏ đến bảng staffs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
CREATE TABLE sales.orders (
 order_id INT IDENTITY (1, 1) PRIMARY KEY,
 customer_id INT,
 order_status tinyint NOT NULL,
 -- Order status: 1 = Pending; 2 = Processing; 3 = Rejected; 4 = Completed
 order_date DATE NOT NULL,
 required_date DATE NOT NULL,
 shipped_date DATE,
 store_id INT NOT NULL,
 staff_id INT NOT NULL,
 FOREIGN KEY (customer_id)
        REFERENCES sales.customers (customer_id)
        ON DELETE CASCADE ON UPDATE CASCADE,
 FOREIGN KEY (store_id)
        REFERENCES sales.stores (store_id)
        ON DELETE CASCADE ON UPDATE CASCADE,
 FOREIGN KEY (staff_id)
        REFERENCES sales.staffs (staff_id)
        ON DELETE NO ACTION ON UPDATE NO ACTION
);

Table sales.order_items

Đây là bảng chứa thông tin quan trọng của từng sản phẩm trong của đơn hàng như số lượng, đơn giá một đơn hàng như: số lưuọng, giá bán.

Tại sao cần bảng này? Vì thực tế giá cả có thể thay đổi theo thời gian, hôm nay bán 200k, mai bán 300k là chuyện bình thường, vì vậy ta phải lưu giá lại để sau này biết là sản phẩm này đã bán ra bao nhiêu.

Nó có hai khóa chính đó là :

  • order_id: khóa ngoại trỏ đến bảng orders
  • product_id: khóa ngoại trỏ đến bảng products

Khóa chính gồm hai trường (order_id, item_id).

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
CREATE TABLE sales.order_items(
 order_id INT,
 item_id INT,
 product_id INT NOT NULL,
 quantity INT NOT NULL,
 list_price DECIMAL (10, 2) NOT NULL,
 discount DECIMAL (4, 2) NOT NULL DEFAULT 0,
 PRIMARY KEY (order_id, item_id),
 FOREIGN KEY (order_id)
        REFERENCES sales.orders (order_id)
        ON DELETE CASCADE ON UPDATE CASCADE,
 FOREIGN KEY (product_id)
        REFERENCES production.products (product_id)
        ON DELETE CASCADE ON UPDATE CASCADE
);

Table production.stocks

Bảng thông tin về hàng tồn kho của sản phẩm, vì vậy nó có khóa ngoại là product_id trỏ đến bảng products.

1
2
3
4
5
6
7
8
9
10
11
12
CREATE TABLE production.stocks (
 store_id INT,
 product_id INT,
 quantity INT,
 PRIMARY KEY (store_id, product_id),
 FOREIGN KEY (store_id)
        REFERENCES sales.stores (store_id)
        ON DELETE CASCADE ON UPDATE CASCADE,
 FOREIGN KEY (product_id)
        REFERENCES production.products (product_id)
        ON DELETE CASCADE ON UPDATE CASCADE
);

Đáng lẽ sẽ hướng dẫn các bạn cách load database mẫu tại đây luôn, tuy nhiên vì nội dung hơi dài nên sẽ dành nó ở một bài khác.

Trước khi kết thúc thì bạn hãy download file database mẫu về máy đã nhé. Link Tải database SQL Server mẫu

=============================
* KHOÁ HỌC ORACLE DATABASE A-Z ENTERPRISE trực tiếp từ tôi giúp bạn bước đầu trở thành những chuyên gia DBA, đủ kinh nghiệm đi thi chứng chỉ OA/OCP, đặc biệt là rất nhiều kinh nghiệm, bí kíp thực chiến trên các hệ thống Core tại VN chỉ sau 1 khoá học.
* CÁCH ĐĂNG KÝ: Gõ (.) hoặc để lại số điện thoại hoặc inbox https://m.me/tranvanbinh.vn hoặc Hotline/Zalo 090.29.12.888
* Chi tiết tham khảo:
https://bit.ly/oaz_w
=============================
KẾT NỐI VỚI CHUYÊN GIA TRẦN VĂN BÌNH:
📧 Mail: binhoracle@gmail.com
☎️ Mobile/Zalo: 0902912888
👨 Facebook: https://www.facebook.com/BinhOracleMaster
👨 Inbox Messenger: https://m.me/101036604657441 (profile)
👨 Fanpage: https://www.facebook.com/tranvanbinh.vn
👨 Inbox Fanpage: https://m.me/tranvanbinh.vn
👨👩 Group FB: https://www.facebook.com/groups/DBAVietNam
👨 Website: https://www.tranvanbinh.vn
👨 Blogger: https://tranvanbinhmaster.blogspot.com
🎬 Youtube: https://www.youtube.com/@binhguru
👨 Tiktok: https://www.tiktok.com/@binhguru
👨 Linkin: https://www.linkedin.com/in/binhoracle
👨 Twitter: https://twitter.com/binhguru
👨 Podcast: https://www.podbean.com/pu/pbblog-eskre-5f82d6
👨 Địa chỉ: Tòa nhà Sun Square - 21 Lê Đức Thọ - Phường Mỹ Đình 1 - Quận Nam Từ Liêm - TP.Hà Nội

=============================
oracle tutorial, học oracle database, Tự học Oracle, Tài liệu Oracle 12c tiếng Việt, Hướng dẫn sử dụng Oracle Database, Oracle SQL cơ bản, Oracle SQL là gì, Khóa học Oracle Hà Nội, Học chứng chỉ Oracle ở đầu, Khóa học Oracle online,sql tutorial, khóa học pl/sql tutorial, học dba, học dba ở việt nam, khóa học dba, khóa học dba sql, tài liệu học dba oracle, Khóa học Oracle online, học oracle sql, học oracle ở đâu tphcm, học oracle bắt đầu từ đâu, học oracle ở hà nội, oracle database tutorial, oracle database 12c, oracle database là gì, oracle database 11g, oracle download, oracle database 19c, oracle dba tutorial, oracle tunning, sql tunning , oracle 12c, oracle multitenant, Container Databases (CDB), Pluggable Databases (PDB), oracle cloud, oracle security, oracle fga, audit_trail,oracle RAC, ASM, oracle dataguard, oracle goldengate, mview, oracle exadata, oracle oca, oracle ocp, oracle ocm , oracle weblogic, postgresql tutorial, mysql tutorial, mariadb tutorial, ms sql server tutorial, nosql, mongodb tutorial, oci, cloud, middleware tutorial, hoc solaris tutorial, hoc linux tutorial, hoc aix tutorial, unix tutorial, securecrt, xshell, mobaxterm, putty

ĐỌC NHIỀU

Trần Văn Bình - Oracle Database Master