2026_01_07_chenxiaofei_create.sql 6.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. -- 1. 用户基础信息表
  2. CREATE TABLE `users` (
  3. `id` BIGINT UNSIGNED 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` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间',
  12. `updated_at` DATETIME 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 PRIMARY KEY COMMENT '雪花ID',
  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` DATETIME 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` BIGINT UNSIGNED PRIMARY KEY COMMENT '雪花ID',
  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 PRIMARY KEY COMMENT '雪花ID',
  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` DATETIME 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` BIGINT UNSIGNED PRIMARY KEY COMMENT '雪花ID',
  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` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
  57. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户反馈表';
  58. -- 6. 系统版本管理表
  59. CREATE TABLE `app_versions` (
  60. `id` BIGINT UNSIGNED PRIMARY KEY COMMENT '雪花ID',
  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` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP
  67. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='版本控制表';
  68. -- 系统内容配置表
  69. CREATE TABLE `sys_articles` (
  70. `id` BIGINT UNSIGNED PRIMARY KEY COMMENT '雪花ID',
  71. `article_key` VARCHAR(50) NOT NULL DEFAULT '' COMMENT '条款唯一标识 (如: REG_AGREEMENT, PRIVACY_POLICY)',
  72. `title` VARCHAR(100) NOT NULL DEFAULT '' COMMENT '条款标题',
  73. `content` LONGTEXT NOT NULL COMMENT '条款详细内容 (富文本/HTML)',
  74. `version` VARCHAR(20) NOT NULL DEFAULT '1.0.0' COMMENT '版本号',
  75. `updated_at` DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  76. UNIQUE KEY `uk_key` (`article_key`)
  77. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='法律条款配置表';