CÔNG CỤ
MODULES
THAM KHẢO
Cách chia List thành các phần bằng nhau trong Python Cách xóa một khóa (key) ra khỏi dictionary trong Python Hướng dẫn chuyển đổi file Google Colab sang Markdown trong Python Bài tập Python: Lập trình cơ sở dữ liệu trong Python Kết nối cơ sở dữ liệu MySQL Python Hướng dẫn kết nối Python PostgreSQL bằng Psycopg2 Hướng dẫn kết nối SQLite sử dụng sqlite3 trong Python Bài tập Python : Pandas trong Python Phạm vi số float của Python Cách lên lịch chạy script Python bằng GitHub Actions Cách tạo hằng số trong Python Các nền tảng lưu trữ tốt nhất cho ứng dụng và script Python 6 Tip viết vòng lặp For hiệu quả hơn trong Python Cách đảo ngược Chuỗi String trong Python Cách gỡ lỗi ứng dụng Python trong Docker Container bằng VS Code 10 tip One Liner bạn cần biết trong Python Cách áp dụng ngưỡng hình ảnh trong Python với NumPy Tìm hiểu về các phép toán Groupby trong Pandas Lập trình Socket trong Python Mô-đun base64 trong Python Cách giới hạn float values trong Python Tìm hiểu Mô-đun statistics Trong Python File Organizing trong Python Đổi tên File trong Python Tìm hiểu về Deque trong Python Mô-đun Calendar trong Python Tìm hiểu về Enum trong Python Sử dụng pprint trong Python Làm việc với cấu trúc Dữ liệu Stack trong Python Thư viện functools trong Python Tip sử dụng hàm round() với tham số âm trong Python Hàm print có thể nhận thêm các tham số bổ sung trong Python Tip tìm chuỗi dài nhất bằng hàm max() trong Python Cách lặp qua nhiều list với hàm zip() trong Python Tìm hiểu về MLOps trong Python Docker và Kubernetes với MLOps trong Python Kết hợp DevOps với MLOps trong Python Xử lý độ chính xác các hàm floor, ceil, round, trunc, format trong Python tối ưu quy trình MLOps Với Python Sự khác biệt giữa byte objects và string trong Python Top 4 thư viện phổ biến nhất của NLP trong Python Cách sử dụng ThreadPoolExecutor trong Python Phân tích dữ liệu Blockchain với Python Hướng dẫn triển khai Smart Contracts với Python Blockchain APIs với Python Làm việc với file ZIP trong Python Sự khác biệt giữa toán tử == và is trong Python Chuyển đổi kiểu dữ liệu trong Python Cách làm việc với file tarball/tar trong Python Sự khác biệt giữa iterator và iterable trong Python Sự khác biệt giữa set() và frozenset() trong Python Làm việc với các biến môi trường trong Python Một tác vụ phổ biến khi làm việc với danh sách trong Python Định dạng chuỗi Strings trong Python Sử dụng Poetry để quản lý dependencies trong Python Sự khác biệt giữa sort() và sorted() trong Python Từ khóa yield trong Python Lớp dữ liệu (Data Classes) trong Python với decorator @dataclass Cách truy cập và thiết lập biến môi trường trong Python Hướng dẫn toàn diện về module datetime trong Python Hướng dẫn xây dựng Command-Line Interface (CLI) bằng Quo trong Python Quản lý sinh viên Python & MySQL
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Ứng dụng quản lý sinh viên với MySQL và Python cơ bản

Trong bài này mình sẽ làm một bài tập, đó là xây dựng ứng dụng quản lý sinh viên với MySQL và Python cơ bản, qua đó bạn sẽ biết cách xử lý truy vấn CSDL MySQL bằng Python.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Trước khi đọc bài này thì bạn phải xem bài xử lý MySQL trong Python nhé, trong bài đó mình đã hướng dẫn các thao tác như: Select, Insert, Update, Delete bằng Python rất chi tiết.

Đương nhiên, bạn cũng phải biết một chút về MySQL thì mới làm được ứng dụng này. Hãy tham khảo series MySQL căn bản nếu bạn chưa biết gì về nó nhé.

1. Tạo CSDL quản lý sinh viên

Trước tiên cần chuẩn bị một số dữ liệu để chúng ta thực hành trên đó. Mình sẽ tạo một cơ sở dữ liệu tên là QLSV, sau đó tạo một table tên là STUDENTS nhé.

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

CREATE DATABASE QLSV;
USE QLSV;
CREATE TABLE STUDENTS(
	ID INT(11) PRIMARY KEY NOT NULL AUTO_INCREMENT,
	FULLNAME VARCHAR(255) NOT NULL
);

Tiếp theo hãy chạy lệnh sau để thêm một vai dòng dữ liệu nhé.

INSERT INTO students(`fullname`)
VALUES 
	('Nguyen Van Cuong'),
	('Dang Van Chuong'),
	('Pham Quoc Khanh')

2. Xây dựng module quản lý sinh viên bằng Python

Ta sẽ tạo một module tên là Students và code các hành động như: Hiển thị danh sách, thêm, xóa và sửa sinh viên.

from mysql.connector import MySQLConnection, Error

class Students:

    conn = None

    def __init__(self):
        """Hàm khởi tạo constructor"""
        self.connect()

    def __del__(self):
        """Hàm hủy destructor"""
        if self.conn != None:
            self.conn.close()

    def connect(self):
        """ Kết nối MySQL bằng module MySQLConnection """
        db_config = {
            'host': 'localhost',
            'database': 'qlsv',
            'user': 'root',
            'password': ''
        }

        conn = None

        try:
            conn = MySQLConnection(**db_config)
            if conn.is_connected() == False:
                raise Error

        except Error as error:
            print(error)

        self.conn = conn

    def show(self):
        """Hàm hiển thị danh sách sinh viên"""
        try:
            cursor = self.conn.cursor()
            cursor.execute("SELECT * FROM students")
            row = cursor.fetchone()

            while row is not None:
                print(row)
                row = cursor.fetchone()

        except Error as e:
            print(e)

        finally:
            cursor.close()

    def insert(self, fullname):
        """Hàm thêm sinh viên"""
        query = "INSERT INTO students(fullname) VALUES(%s)"
        args = (fullname,)

        try:
            cursor = self.conn.cursor()
            cursor.execute(query, args)

            if cursor.lastrowid:
                print('Insert thành công!')
            else:
                print('Insert thất bại!')

            self.conn.commit()
            self.show()

        except Error as error:
            print(error)

        finally:
            cursor.close()


    def update(self, id, name):
        """Hàm update sinh viên"""
        query = """ UPDATE students
                    SET fullname = %s
                    WHERE id = %s """
        data = (name, id)

        try:
            cursor = self.conn.cursor()
            cursor.execute(query, data)
            self.conn.commit()
            self.show()

        except Error as error:
            print(error)

        finally:
            cursor.close()

    def delete(self, id):
        """Hàm xóa sinh viên"""
        query = "DELETE FROM students WHERE id = %s"
        try:
            cursor = self.conn.cursor()
            cursor.execute(query, (id,))
            self.conn.commit()
            self.show()

        except Error as error:
            print(error)

        finally:
            cursor.close()

3. Chương trình chính chạy module quản lý sinh viên Python

Công việc bây giờ thì khá đơn giản, bạn chỉ cần gọi đến module mà ta đã làm ở phần 2.

# HỌC PYTHON TẠI FREETUTS.NET
# CHƯƠNG TRÌNH QUẢN LÝ SINH VIÊN BẰNG MYSQL & PYTHON
# AUTHOR: CƯỜNG NGUYỄN

import students as st

print("CHƯƠNG TRÌNH QUẢN LÝ SINH VIÊN")
action = 1

while action != 0:
    print("------------------------")
    print("|- Nhập 1: Danh sách ---")
    print("|- Nhập 2: Thêm      ---")
    print("|- Nhập 3: Xóa       ---")
    print("|- Nhập 4: Sửa       ---")
    print("|- Nhập 0: Thoát     ---")
    print("------------------------")

    action = int(input())
    s = st.Students()

    if action == 1:
        print('DANH SÁCH SINH VIÊN')
        s.show()
    elif action == 2:
        print('THÊM SINH VIÊN')
        print("Nhập Tên sinh viên: ", end='')
        name = input()
        s.insert(name)
    elif action == 3:
        print('XÓA SINH VIÊN')
        print("Nhập ID sinh viên cần xóa: ", end='')
        id = input()
        s.delete(id)
    elif action == 4:
        print('CẬP NHẬT SINH VIÊN')
        print("Nhập ID sinh viên cần cập nhật: ", end='')
        id = input()
        print("Nhập tên sinh viên mới: ", end="")
        name = input()
        s.update(id, name)
    else:
        break

Chạy chương trình lên thì bạn sẽ thấy giao diện như sau:

quan ly sinh vien luu db python JPG

Lời kết: Như vậy là mình đã hướng dẫn xong cách sử dụng Python để viết chương trình quản lý sinh viên có lưu trữ database MySQL. Chúc bạn thành công nhé.

Cùng chuyên mục:

Hướng dẫn xây dựng Command-Line Interface (CLI) bằng Quo trong Python

Hướng dẫn xây dựng Command-Line Interface (CLI) bằng Quo trong Python

Hướng dẫn toàn diện về module datetime trong Python

Hướng dẫn toàn diện về module datetime trong Python

Cách truy cập và thiết lập biến môi trường trong Python

Cách truy cập và thiết lập biến môi trường trong Python

Lớp dữ liệu (Data Classes) trong Python với decorator @dataclass

Lớp dữ liệu (Data Classes) trong Python với decorator @dataclass

Từ khóa yield trong Python

Từ khóa yield trong Python

Sự khác biệt giữa sort() và sorted() trong Python

Sự khác biệt giữa sort() và sorted() trong Python

Sử dụng Poetry để quản lý dependencies trong Python

Sử dụng Poetry để quản lý dependencies trong Python

Định dạng chuỗi Strings trong Python

Định dạng chuỗi Strings trong Python

Một tác vụ phổ biến khi làm việc với danh sách trong Python

Một tác vụ phổ biến khi làm việc với danh sách trong Python

Làm việc với các biến môi trường trong Python

Làm việc với các biến môi trường trong Python

Sự khác biệt giữa set() và frozenset() trong Python

Sự khác biệt giữa set() và frozenset() trong Python

Sự khác biệt giữa iterator và iterable trong Python

Sự khác biệt giữa iterator và iterable trong Python

Cách làm việc với file tarball/tar trong Python

Cách làm việc với file tarball/tar trong Python

Chuyển đổi kiểu dữ liệu trong Python

Chuyển đổi kiểu dữ liệu trong Python

Sự khác biệt giữa toán tử == và is trong Python

Sự khác biệt giữa toán tử == và is trong Python

Làm việc với file ZIP trong Python

Làm việc với file ZIP trong Python

Cách sử dụng ThreadPoolExecutor trong Python

Cách sử dụng ThreadPoolExecutor trong Python

Sự khác biệt giữa byte objects và string trong Python

Sự khác biệt giữa byte objects và string trong Python

Xử lý độ chính xác các hàm floor, ceil, round, trunc, format  trong Python

Xử lý độ chính xác các hàm floor, ceil, round, trunc, format trong Python

Cách lặp qua nhiều list với hàm zip() trong Python

Cách lặp qua nhiều list với hàm zip() trong Python

Top