init.sql 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. -- 创建数据库表结构
  2. -- 用户表
  3. CREATE TABLE IF NOT EXISTS users (
  4. id INT AUTO_INCREMENT PRIMARY KEY,
  5. username VARCHAR(50) NOT NULL UNIQUE,
  6. email VARCHAR(100) NOT NULL UNIQUE,
  7. password VARCHAR(255) NOT NULL,
  8. first_name VARCHAR(50),
  9. last_name VARCHAR(50),
  10. avatar VARCHAR(255),
  11. phone VARCHAR(20),
  12. address VARCHAR(255),
  13. is_active BOOLEAN DEFAULT TRUE,
  14. role VARCHAR(20) DEFAULT 'user',
  15. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  16. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  17. deleted_at TIMESTAMP NULL,
  18. INDEX idx_username (username),
  19. INDEX idx_email (email),
  20. INDEX idx_deleted_at (deleted_at)
  21. );
  22. -- 商品分类表
  23. CREATE TABLE IF NOT EXISTS categories (
  24. id INT AUTO_INCREMENT PRIMARY KEY,
  25. name VARCHAR(100) NOT NULL,
  26. description TEXT,
  27. parent_id INT,
  28. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  29. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  30. FOREIGN KEY (parent_id) REFERENCES categories(id) ON DELETE SET NULL,
  31. INDEX idx_parent_id (parent_id)
  32. );
  33. -- 商品表
  34. CREATE TABLE IF NOT EXISTS products (
  35. id INT AUTO_INCREMENT PRIMARY KEY,
  36. name VARCHAR(255) NOT NULL,
  37. description TEXT,
  38. price DECIMAL(10, 2) NOT NULL,
  39. stock INT DEFAULT 0,
  40. category_id INT,
  41. image VARCHAR(255),
  42. is_active BOOLEAN DEFAULT TRUE,
  43. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  44. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  45. FOREIGN KEY (category_id) REFERENCES categories(id) ON DELETE SET NULL,
  46. INDEX idx_category_id (category_id),
  47. INDEX idx_name (name),
  48. INDEX idx_price (price)
  49. );
  50. -- 购物车表
  51. CREATE TABLE IF NOT EXISTS carts (
  52. id INT AUTO_INCREMENT PRIMARY KEY,
  53. user_id INT NOT NULL,
  54. product_id INT NOT NULL,
  55. quantity INT NOT NULL DEFAULT 1,
  56. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  57. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  58. FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
  59. FOREIGN KEY (product_id) REFERENCES products(id) ON DELETE CASCADE,
  60. UNIQUE KEY unique_user_product (user_id, product_id),
  61. INDEX idx_user_id (user_id),
  62. INDEX idx_product_id (product_id)
  63. );
  64. -- 订单表
  65. CREATE TABLE IF NOT EXISTS orders (
  66. id INT AUTO_INCREMENT PRIMARY KEY,
  67. user_id INT NOT NULL,
  68. order_number VARCHAR(50) NOT NULL UNIQUE,
  69. total_amount DECIMAL(10, 2) NOT NULL,
  70. status VARCHAR(20) DEFAULT 'pending',
  71. shipping_address TEXT,
  72. payment_method VARCHAR(50),
  73. payment_status VARCHAR(20) DEFAULT 'pending',
  74. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  75. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  76. FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
  77. INDEX idx_user_id (user_id),
  78. INDEX idx_order_number (order_number),
  79. INDEX idx_status (status)
  80. );
  81. -- 订单项表
  82. CREATE TABLE IF NOT EXISTS order_items (
  83. id INT AUTO_INCREMENT PRIMARY KEY,
  84. order_id INT NOT NULL,
  85. product_id INT NOT NULL,
  86. quantity INT NOT NULL,
  87. price DECIMAL(10, 2) NOT NULL,
  88. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  89. FOREIGN KEY (order_id) REFERENCES orders(id) ON DELETE CASCADE,
  90. FOREIGN KEY (product_id) REFERENCES products(id) ON DELETE CASCADE,
  91. INDEX idx_order_id (order_id),
  92. INDEX idx_product_id (product_id)
  93. );
  94. -- 插入初始数据
  95. -- 插入默认管理员用户
  96. INSERT INTO users (username, email, password, first_name, last_name, role) VALUES
  97. ('admin', '[email protected]', '$2a$10$92IXUNpkjO0rOQ5byMi.Ye4oKoEa3Ro9llC/.og/at2.uheWG/igi', 'Admin', 'User', 'admin');
  98. -- 插入商品分类
  99. INSERT INTO categories (name, description) VALUES
  100. ('电子产品', '各类电子设备和配件'),
  101. ('服装', '男女服装和配饰'),
  102. ('家居', '家居用品和装饰'),
  103. ('图书', '各类图书和教材'),
  104. ('运动', '运动器材和服装');
  105. -- 插入示例商品
  106. INSERT INTO products (name, description, price, stock, category_id) VALUES
  107. ('智能手机', '最新款智能手机,配备高清摄像头和长续航电池', 2999.00, 100, 1),
  108. ('笔记本电脑', '轻薄便携,高性能处理器,适合办公和娱乐', 5999.00, 50, 1),
  109. ('运动T恤', '透气舒适,适合各种运动场景', 99.00, 200, 2),
  110. ('牛仔裤', '经典款式,舒适耐穿', 199.00, 150, 2),
  111. ('沙发', '现代简约风格,舒适耐用', 2999.00, 20, 3),
  112. ('台灯', 'LED护眼台灯,多档调节', 199.00, 100, 3),
  113. ('编程入门', '适合初学者的编程入门书籍', 59.00, 500, 4),
  114. ('瑜伽垫', '防滑瑜伽垫,厚度适中', 99.00, 300, 5);