基于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
相关推荐
摇滚侠17 分钟前
Spring 零基础入门到进阶 基于 XML 管理 Bean 14-28
xml·数据库·spring
Metaphor69233 分钟前
使用 Python 给 PDF 设置背景色或背景图
数据库·python·pdf
Gauss松鼠会34 分钟前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结
睡不醒男孩0308231 小时前
第五篇:2026年企业级 PostgreSQL 高可用方案深度横评:Patroni vs. CLup 架构与可靠性全面对决
数据库·postgresql·架构
NineData1 小时前
SQL 都在等锁时,ChatDBA 先帮 MySQL 找到谁在挡路
数据库·人工智能·sql·mysql·安全·数据复制·数据迁移工具
超级无敌zhq1 小时前
后渗透痕迹清理:攻防对抗中的隐身术
网络·数据库·网络安全
郝亚军1 小时前
如何让pycharm-2026.1.2顶部菜单栏固定显示在最上端
python
怪兽学LLM1 小时前
LeetCode 438 找到字符串中所有字母异位词(Python 固定滑动窗口+字符计数解法)
python·算法·leetcode
麻雀飞吧1 小时前
期货量化日志别泄露密码:天勤账户凭证脱敏写法
python