2026_01_07_chenxiaofei_create.sql 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. -- 1. 用户基础信息表
  2. CREATE TABLE `users` (
  3. `id` BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY COMMENT '主键ID',
  4. `username` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '登录账号',
  5. `password_hash` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '加密存储的密码',
  6. `full_name` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '用户姓名',
  7. `avatar_url` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '头像URL地址',
  8. `phone` VARCHAR(20) NOT NULL DEFAULT '' COMMENT '联系电话',
  9. `role_type` TINYINT NOT NULL DEFAULT 1 COMMENT '角色: 1-铲车司机(监管员), 2-门卫',
  10. `status` TINYINT NOT NULL DEFAULT 1 COMMENT '状态: 0-禁用, 1-启用',
  11. `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间',
  12. `updated_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
  13. UNIQUE KEY `uk_username` (`username`)
  14. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户信息表';
  15. -- 2. 登录日志表
  16. CREATE TABLE `login_logs` (
  17. `id` BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  18. `user_id` BIGINT UNSIGNED NOT NULL DEFAULT 0 COMMENT '关联用户ID',
  19. `device_info` VARCHAR(100) NOT NULL DEFAULT '' COMMENT '设备型号/标识',
  20. `login_ip` VARCHAR(45) NOT NULL DEFAULT '' COMMENT '登录IP',
  21. `login_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  22. `login_type` TINYINT NOT NULL DEFAULT 1 COMMENT '1-首次登录, 2-切换账号登录',
  23. INDEX `idx_user_id` (`user_id`)
  24. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='登录日志表';
  25. -- 3. 物料信息字典表
  26. CREATE TABLE `materials` (
  27. `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  28. `material_name` VARCHAR(100) NOT NULL DEFAULT '' COMMENT '物料名称',
  29. `category` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '物料分类',
  30. `unit` VARCHAR(20) NOT NULL DEFAULT '吨' COMMENT '计量单位',
  31. UNIQUE KEY `uk_material_name` (`material_name`)
  32. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='物料信息表';
  33. -- 4. 装载作业记录表 (核心业务表)
  34. CREATE TABLE `loading_records` (
  35. `id` BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  36. `operator_id` BIGINT UNSIGNED NOT NULL DEFAULT 0 COMMENT '操作员ID',
  37. `license_plate` VARCHAR(20) NOT NULL DEFAULT '' COMMENT '车牌号',
  38. `customer_name` VARCHAR(100) NOT NULL DEFAULT '' COMMENT '客户名称',
  39. `load_type` TINYINT NOT NULL DEFAULT 1 COMMENT '装载类型: 1-装载, 2-补货',
  40. `material_id` INT UNSIGNED NOT NULL DEFAULT 0 COMMENT '物料ID',
  41. `quantity` DECIMAL(12, 2) NOT NULL DEFAULT 0.00 COMMENT '装载数量/重量',
  42. `work_date` DATE NOT NULL DEFAULT '1000-01-01' COMMENT '作业日期',
  43. `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '记录创建时间',
  44. INDEX `idx_query_composite` (`work_date`, `load_type`, `license_plate`),
  45. INDEX `idx_operator` (`operator_id`),
  46. INDEX `idx_customer` (`customer_name`)
  47. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='铲车装载记录表';
  48. -- 5. 意见反馈表
  49. CREATE TABLE `feedbacks` (
  50. `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  51. `user_id` BIGINT UNSIGNED NOT NULL DEFAULT 0 COMMENT '反馈人ID',
  52. `content` TEXT NOT NULL COMMENT '反馈正文',
  53. `images` JSON NOT NULL COMMENT '图片附件地址',
  54. `contact_info` VARCHAR(100) NOT NULL DEFAULT '' COMMENT '联系方式',
  55. `is_processed` TINYINT(1) NOT NULL DEFAULT 0 COMMENT '是否已处理',
  56. `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  57. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户反馈表';
  58. -- 6. 系统版本管理表
  59. CREATE TABLE `app_versions` (
  60. `id` INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  61. `version_code` VARCHAR(20) NOT NULL DEFAULT '' COMMENT '版本号',
  62. `platform` TINYINT NOT NULL DEFAULT 1 COMMENT '平台类型(1-Android,2-iOS)',
  63. `update_log` TEXT NOT NULL COMMENT '更新日志',
  64. `download_url` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '安装包下载地址',
  65. `is_force_update` TINYINT(1) NOT NULL DEFAULT 0 COMMENT '是否强制更新',
  66. `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP
  67. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='版本控制表';