基于LibreOffice +python 实现一个小型销售管理系统的数据库原型教学实验

项目概述

本项目使用 SQLite 数据库和 LibreOffice 创建了一个完整的销售管理系统数据库,包含客户、商品、订单等数据,并生成了所需的报表。

创建一个 销售管理系统数据库 ,主要用于:

主要用途

1. 教学实验

这是 Week 5 数据库实验课 的作业,目的是学习如何:

  • 创建数据库表(客户、商品、订单等)
  • 编写 SQL 查询
  • 生成报表

2. 业务数据管理

系统可以管理:

  • 客户信息 - 公司名称、联系方式、地址等
  • 商品目录 - 商品名称、价格、库存等
  • 订单处理 - 订单状态(已完成/待处理)、发货信息等
  • 利润计算 - 每笔订单的利润分析

3. 报表生成

可以生成以下报表:

报表 用途 Customer Item List 客户商品目录 Profit by Order & Item 订单利润分析 Item Profit Summary 商品销售汇总

4. 数据分析

可以分析:

  • 哪些商品卖得最好
  • 哪些商品利润最高
  • 销售额和利润趋势

文件说明

数据库文件

  • Week5_Database.odb - LibreOffice Base 数据库文件,包含了所有表和查询

Python 脚本

文件 用途
create_database.py 创建数据库结构、表、插入示例数据、创建查询
export_csv.py 将查询结果导出为 CSV 文件
verify_data.py 验证数据库内容和查询结果

输出文件

文件 说明
Customer_Item_List.pdf 客户商品列表报表 (STEP 1)
Profit_By_Order_Item.pdf 订单利润报表 (STEP 2)
Item_Profit_Summary.pdf 商品利润汇总报表 (STEP 3)

数据库结构

表 (Tables)

  1. Customer - 客户表

    • CustomerID, CompanyName, ContactName, ContactTitle, Address, City, Region, PostalCode, Country, Phone, Fax
  2. Category - 商品类别表

    • CategoryID, CategoryName, Description
  3. Item - 商品表

    • ItemID, ItemName, CategoryID, UnitPrice, UnitsInStock, UnitsOnOrder, ReorderLevel, Discontinued
  4. Order - 订单表

    • OrderID, CustomerID, OrderDate, RequiredDate, ShippedDate, ShipVia, Freight, ShipName, ShipAddress, ShipCity, ShipRegion, ShipPostalCode, ShipCountry, OrderStatus
  5. Order Detail - 订单明细表

    • OrderDetailID, OrderID, ItemID, UnitPrice, Quantity, Discount

查询 (Queries)

  1. Customer Item List - 客户商品列表查询

    • 显示所有客户和商品的交叉列表
  2. Profit by Order & Item - 按订单和商品计算利润

    • 显示已完成订单的利润详情
  3. Order Detail Query - 订单明细查询

    • 用于汇总分析的详细数据
  4. Item Profit Summary - 商品利润汇总

    • 按商品汇总销量和利润

使用方法

1. 重新创建数据库

bash 复制代码
python3 create_database.py

2. 导出查询结果为 CSV

bash 复制代码
python3 export_csv.py

3. 验证数据

bash 复制代码
python3 verify_data.py

4. 使用 LibreOffice 打开数据库

bash 复制代码
"C:\Program Files\LibreOffice\program\soffice.exe" "Week5_Database.odb"

5. 将 CSV 转换为 Excel

bash 复制代码
"C:\Program Files\LibreOffice\program\soffice.exe" --headless --invisible --convert-to xlsx input.csv --outdir output_dir

6. 将 Excel 转换为 PDF

bash 复制代码
"C:\Program Files\LibreOffice\program\soffice.exe" --headless --invisible --convert-to pdf input.xlsx --outdir output_dir

数据分析结果

根据 STEP 3 的要求,系统可以分析以下内容:

  • 销量最高的商品
  • 销量最低的商品
  • 利润最高的商品
  • 利润最低的商品

环境要求

  • Python 3.x
  • LibreOffice 26.x
  • pypdf 库 (用于 PDF 处理)

安装依赖

bash 复制代码
pip install pypdf
相关推荐
倔强的石头_4 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB6 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
荣码14 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
金銀銅鐵1 天前
[Python] 基于欧几里得算法,实现分数约分计算器
python·数学
Lyn_Li1 天前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现
python·kaggle·比赛复盘·金融预测
小九九的爸爸1 天前
前端想要入门Agent开发,要具备哪些Python基础?
python·agent·ai编程
阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构
python·程序员
jiayou641 天前
KingbaseES 表级与列级加密完全指南
数据库·后端
花酒锄作田2 天前
Pydantic校验配置文件
python
hboot2 天前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络