编程逻辑思维巩固案列演练

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 文章目录编程逻辑思维巩固案列演练1、项目介绍2.环境准备3.功能实现1.项目主流程和菜单提示2.数据库连接3.添加图书4.修改图书5.图书列表6.查询图书7.删除图书8.借阅图书9.归还图书python操作数据库图书管理小项目

文章目录

编程逻辑思维巩固案列演练

image.png

通过python的面向对象编程,实现一个文字版的图书管理系统

  • 本章节的目的,强化大家编程的逻辑思维能力
  • 知识点
  • 基本的sql增删改查
  • 面向对象的使用

1、项目介绍

  • 功能模块

image.png

  • 图书信息

image.png

2.环境准备

  • 数据存储方式:mysql
  • 创建表
create table books( 
    id int unsigned primary key auto_increment not null, 
    name varchar(20) default '', 
    position varchar(40) default '', 
    status enum('在库','出借') default '在库', 
    borrorwer varchar(20) default '' 
);
  • 插入数据
# 部分列插入语法:=> insert into 表名(列1,...) values(值1,...) 
insert into books(name,position) value('python入门到精通','A区2号架3层'); 
# 全列插入语法=> insert into 表名 values(...) 
insert into books value(0,'python入门到精通','A区2号架3层','在库','');
  • 修改数据
# 修改数据 
update 表名 set 列1=值1,列2=值2... where 条件
  • 删除数据语法
delete from 表名 where 条件;
  • 查询
select * from 表名;
  • python连接mysql数据库
# 安装pymysql 
pip install pymysql
  • 连接数据库
pymysql.connect(
    host='localhost', 
    user='root', 
    password="123456", 
    database='test', 
    port=3306, 
    cursorclass=pymysql.cursors.DictCursor)
  • 创建游标对象
  • 执行sql语句

3.功能实现

1.项目主流程和菜单提示

image.png

  • 1、运行程序,打印提示菜单
  • 2、根据输入不同的选项进行对应的操作

2.数据库连接

  • 通过pymysql连接数据库,封装执行查询语句和修改语句的方法。

3.添加图书

image.png


  • 1、用户依次输入书名、存放位置
  • 2、校验输入的书名和位置是否有值
  • 3、添加图书到数据库
  • 4、提示:
  • 继续添加输入1,回车退回到主菜单

4.修改图书

需求:修改图书只能修改书名和位置信息。

image.png

  • 1、用户输入修改的图书编号,判断id是否存在
  • 2、编号存在则打印改书本的全部信息,并提示用户输入新的书名,和新的位置。
  • 3、根据用户的输入,对图书进行修改
  • 4、提示:
  • 继续添加输入1,回车退回到主菜单

5.图书列表

image.png

  • 查询数据库中所有的图书,打印出来显示

6.查询图书

  • 1、输入书名,查询出与之匹配的图书信息,并打印
  • 2、提示:
  • 继续查询输入1,回车退回到主菜单

7.删除图书

  • 1、输入书籍编号,找到对应的书籍,从数据库中删除
  • 2、提示:
  • 继续删除输入1,回车退回到主菜单


8.借阅图书

  • 1、输入图书编号,查找到该书籍
  • 2、提示用户输入借阅人名字
  • 3、将书籍的状态改为出借,借阅人改为输入的名字
  • 4、提示:
  • 继续添加输入1,回车退回到主菜单

9.归还图书

  • 1、输入图书编号,查找到该书籍
  • 2、将书籍的状态改为在库,借阅人改为空
  • 3、提示:
  • 继续添加输入1,回车退回到主菜单


python操作数据库

pymysql_practice.py

import pymysql
#pymysql连接数据库
con = pymysql.connect( host='localhost',
                 user='root',
                 password="123456",
                 database='lenovo',
                 port=3306,
                 cursorclass=pymysql.cursors.DictCursor)
#创建一个游标对象
cur = con.cursor(cursor=pymysql.cursors.DictCursor) #以字典形式展示数据
#执行sql
sql = "select * from books"
res = cur.execute(sql)
print(res)
#获取查询的结果
result1 = cur.fetchall()
print(result1)
#执行增删改的sql
sql = 'insert into books(name,position) value("天龙八部","A区1号架1层");'
res2 = cur.execute(sql)
#提交事务
con.commit()
print(res2)
con.close()

图书管理小项目

BookManage.py

import pymysql
class DB:
    '''
    项目涉及到数据库的增删查改,咱们封装数据库对应的操作方法来处理
    查询的方法
    增删改的方法
    '''
    def __init__(self):
        # pymysql连接数据库
        self.con = pymysql.connect(host='localhost',
                              user='root',
                              password="123456",
                              database='lenovo',
                              port=3306,
                              cursorclass=pymysql.cursors.DictCursor)
        # 创建一个游标对象
        self.cur = self.con.cursor(cursor=pymysql.cursors.DictCursor)  # 以字典形式展示数据
    def query_sql(self,sql):
        '''
        查询sql方法
        :param sql: sql语句
        :return: 查询得到的结果
        '''
        self.cur.execute(sql)
        return self.cur.fetchall()
    def update_sql(self,sql):
        '''
        :param sql: sql语句
        :return:
        '''
        self.cur.execute(sql)
        self.con.commit()
    def close(self):
        """关闭游标,断开连接"""
        self.cur.close()
        self.con.close()
class Books(DB):
    def add_book(self):
        '''添加图书'''
        print("---------添加图书--------")
        name = input("请输入书名:")
        position = input("请输入图书存放的位置:")
        if name and position:
            sql = "insert into books(name,position) value('{}','{}')".format(name,position)
            self.update_sql(sql)
            print("添加成功!")
        else:
            print("添加失败,书名和位置均不能为空!!!")
        n = input("继续添加请输入1,回车返回主菜单")
        #判断用户输入的是否为1,为1则再次调用添加图书的方法
        if n == "1":
            self.add_book()
        else:
            pass
    def update_book(self):
        '''修改图书'''
        print("----------修改图书------------")
        id = input("请输入要修改图书的ID")
        #打印图书的信息
        res = self.query_sql(f'select * from books where id={id}')
        if res:
            print("当前图书的信息",res)
            # 进行修改
            name = input("请输入新的书名,不修改请输入回车:") or res[0]['name']
            position = input("请输入图书存放的位置,不修改请输入回车:") or res[0]['position']
            sql = f'update books set name = "{name}",position="{position}" where id="{id}"'
            self.update_sql(sql)
            print("修改成功!")
        else:
            print("您输入的书籍id不存在")
        n = input("继续修改请输入1,回车返回主菜单")
        if n == "1":
            self.update_book()
        else:
            pass
    def del_book(self):
        '''删除图书'''
        print("----------删除图书------------")
        id = input("请输入删除图书的id:")
        # 打印图书的信息
        res = self.query_sql(f'select * from books where id={id}')
        if res:
            print("您要删除的书籍信息如下:",res)
            is_delete = input("确认删除请输入1,否则请输入回车:")
            if is_delete == "1" and res[0]["status"]=="在库":
                sql = 'delete from books where id = {id}'
                self.update_sql(sql)
                print("删除成功")
            elif res[0]["status"]=="出借":
                print("本书已出借,无法删除!")
        else:
            print("您输入的书籍id不存在")
        #判断是否要继续删除
        n = input("继续删除请输入1,回车返回主菜单")
        if n == "1":
            self.del_book()
        else:
            pass
    def qurey_book(self):
        '''查询图书'''
        print("----------查询图书------------")
        name = input("请输入要查询的图书名:")
        if name:
            sql = f"select * from books where name = '{name}' "
            res = self.query_sql(sql)
            if res:
                for i in res:
                    print(i)
            else:
                print("图书馆暂无该书籍!")
        else:
            print("书名不能为空!")
        # 判断是否要继续查询
        n = input("继续查询请输入1,回车返回主菜单")
        if n == "1":
            self.qurey_book()
        else:
            pass
    def book_list(self):
        '''图书列表'''
        sql = "select * from books"
        res = self.query_sql(sql)
        print("****************图书列表***************")
        for i in res:
            print(f'编号:{i["id"]},书名:{i["name"]},位置:{i["position"]},'
                  f'转态:{i["status"]},借阅人:{i["borrorwer"]}')
        print("返回主菜单页面")
    def revert_book(self):
        '''归还图书'''
        print("----------删除图书------------")
        id = input("请输入要归还图书的ID:")
        sql = f'select * from books where id = {id}'
        res = self.query_sql(sql)
        if res:
            print("您要归还的图书信息如下:\n",res)
            #查看图书的状态,如果状态为出借,则不能借出
            if res[0]["status"] == "出借":
                status = "在库"
                lend_sql =  f'update books set status="{status}",borrorwer=" " where id="{id}"'
                self.update_sql(lend_sql)
                print("归还成功")
            else:
                print("本书并未出借!")
        else:
            print("请输入正确的图书编号!")
        # 判断是否要继续租借
        n = input("继续归还请输入1,回车返回主菜单")
        if n == "1":
            self.revert_book()
        else:
            pass
    def lend_book(self):
        '''租借图书'''
        print("----------租借图书------------")
        id = input("请输入要租借图书的ID:")
        sql = f'select * from books where id = {id}'
        res = self.query_sql(sql)
        if res:
            print("您要借阅的图书信息如下:\n",res)
            #查看图书的状态,如果状态为出借,则不能借出
            if res[0]["status"] == "出借":
                print("该图书已被借出!")
            else:
                print("本书可借出!")
                borrorwer = input("借书请输入您的名字:")
                status = "出借"
                lend_sql =  f'update books set status="{status}",borrorwer="{borrorwer}" where id="{id}"'
                self.update_sql(lend_sql)
                print("登记成功,借阅成功!")
        else:
            print("图书馆暂无该书籍!")
        # 判断是否要继续租借
        n = input("继续租借请输入1,回车返回主菜单")
        if n == "1":
            self.lend_book()
        else:
            pass
    def quit(self):
        '''退出'''
        self.close()
        print("程序退出!!!")
    def print_menu(self):
        '''打印菜单'''
        print("-----菜单---------")
        print("【1】︰添加图书\n"
              "【2】:修改图书\n"
              "【3】:删除图书\n"
              "【4】:查询图书\n"
              "【5】:图书列表\n"
              "【6】:出借图书\n"
              "【7】:归还图书\n"
              "【8】:退出")
    def main(self):
        print("---------------欢迎进入小仔图书管理系统---------------")
        while True:
            self.print_menu()
            number = input("请输入你的选项:")
            if number == '1':
                self.add_book()
            elif number == "2":
                self.update_book()
            elif number == "3":
                self.del_book()
            elif number == "4":
                self.qurey_book()
            elif number == "5":
                self.book_list()
            elif number == "6":
                self.lend_book()
            elif number == "7":
                self.revert_book()
            elif number == "8":
                self.quit()
                break
            else:
                print("您输入的选项有误!憨批!")
if __name__ == '__main__':
    book = Books()
    book.main()
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
设计模式 算法 程序员
程序员为何需要反复修改Bug?探寻代码编写中的挑战与现实
作为开发者,我们在日常开发过程中,往往会遇到反复修改bug的情况,而且不能一次性把代码写的完美无瑕,其实开发项目是一项复杂而富有挑战性的任务,即使经验丰富的程序员也难以在一次性编写完美无瑕地完成代码,我个人觉得一次性写好代码是不可能完成的事情。虽然在设计之初已经尽力思考全面,并在实际操作中力求精确,但程序员仍然需要花费大量时间和精力来调试和修复Bug。那么本文就来分享程序员需要反复修改Bug的原因,以及在开发中所面临的复杂性与挑战。
211 1
程序员为何需要反复修改Bug?探寻代码编写中的挑战与现实
|
3月前
|
程序员
探索编程之美:从逻辑到实践的旅程##
【10月更文挑战第12天】 在当今这个科技飞速发展的时代,编程已经成为了一种基础技能,它不仅是一种技术,更是一种艺术。本文将分享我的编程感悟,从最初的困惑到逐渐掌握编程的逻辑,再到将所学知识应用于实际项目,实现自我价值的提升。正如印度圣雄甘地所说:“你必须成为你希望在世界上看到的改变。”通过不懈努力和持续学习,我逐渐理解了编程的本质,并在实践中不断提升自己。 ##
36 0
编程之旅:从代码中寻找生活的启示
【9月更文挑战第19天】本文是一篇关于编程和生活哲理相结合的感悟文章。文章以通俗易懂的语言,深入浅出地探讨了编程与生活的相似性,旨在启发读者从编程的角度去思考生活,从而获得对生活的新认识。文章通过分享作者的个人经历,阐述了如何将编程中的逻辑思维、解决问题的方法应用到生活中,以及如何从编程的过程中找到生活的乐趣和意义。
|
7月前
|
算法 程序员
程序员必知:XGB算法梳理
程序员必知:XGB算法梳理
41 0
|
8月前
|
人工智能 算法 Java
程序设计的艺术:深入解析与实战演练
程序设计的艺术:深入解析与实战演练
69 4
|
8月前
|
设计模式 算法 程序员
代码之美:从混沌到秩序的编程之旅
【4月更文挑战第25天】在编程的世界里,每一行代码都像是构建宇宙的基石,它们汇聚成河,流淌出技术的海洋。本文将探索编程的艺术与实践,从初学者的困惑到专家的洞见,展现如何将复杂问题简化为优雅且高效的解决方案。我们将透过代码的镜头,体验从混沌到秩序的转变,并分享实现这一过程的关键技术感悟。
|
测试技术
软件测试好学吗 只要选对了学习方式,就并不难学
我们都知道,如今互联网IT行业,在国内可是非常吃香的,尤其是近些年随着软件的普及,人们对软件的要求也是越来越高,因此国内各大互联网企业,也开始大量招聘软件测试人员,但由于这个岗位在我国的发展时间并不长,人员需求也是供应不求的。
211 0
软件测试好学吗 只要选对了学习方式,就并不难学
|
测试技术
|
SQL 安全 测试技术
逻辑漏洞挖掘经验分享(一)
逻辑漏洞挖掘经验分享(一)
407 0
|
算法 关系型数据库 MySQL
形式化验证工具TLA+:程序员视角的入门之道
女娲是飞天分布式系统中提供分布式协同的基础服务,支撑着阿里云的计算、网络、存储等几乎所有云产品。在女娲分布式协同服务中,一致性引擎是核心基础模块,支持了Paxos,Raft,EPaxos等多种一致性协议,根据业务需求支撑不同业务状态机。如何保证一致性库的正确性是一个很大挑战,我们引入了TLA+、Jepsen等工具保证一致性库的正确性。本文即从程序员视角介绍形式化验证工具TLA+。
形式化验证工具TLA+:程序员视角的入门之道