Files
services/scripts/mock-data.js
T
董海洋 ff40282dc1 new api
2026-05-26 09:18:48 +08:00

210 lines
8.9 KiB
JavaScript

const { query } = require('../config/database')
async function run() {
try {
console.log('Inserting mock orders...')
const orders = [
{
id: 'ORD202401010001',
user_id: 1,
status: 'completed',
total_price: 156.80,
cart: JSON.stringify([
{ goods_id: 1, name: '红富士苹果', price: 12.80, quantity: 5, unit: '斤' },
{ goods_id: 5, name: '土鸡蛋', price: 19.90, quantity: 2, unit: '盒' },
{ goods_id: 15, name: '可口可乐', price: 3.50, quantity: 6, unit: '瓶' }
]),
user_info: JSON.stringify({ phone: '13800138000', name: '张三' })
},
{
id: 'ORD202401020002',
user_id: 1,
status: 'paid',
total_price: 89.70,
cart: JSON.stringify([
{ goods_id: 3, name: '进口车厘子', price: 59.90, quantity: 1, unit: '斤' },
{ goods_id: 8, name: '蒙牛纯牛奶', price: 59.90, quantity: 1, unit: '箱' }
]),
user_info: JSON.stringify({ phone: '13800138000', name: '张三' })
},
{
id: 'ORD202401030003',
user_id: 2,
status: 'pending',
total_price: 45.60,
cart: JSON.stringify([
{ goods_id: 7, name: '金龙鱼花生油', price: 89.90, quantity: 1, unit: '桶' },
{ goods_id: 12, name: '卫龙辣条', price: 5.50, quantity: 3, unit: '包' }
]),
user_info: JSON.stringify({ phone: '13900139000', name: '李四' })
},
{
id: 'ORD202401040004',
user_id: 2,
status: 'completed',
total_price: 123.40,
cart: JSON.stringify([
{ goods_id: 10, name: '农夫山泉', price: 2.00, quantity: 12, unit: '瓶' },
{ goods_id: 14, name: '青岛啤酒', price: 5.00, quantity: 12, unit: '瓶' },
{ goods_id: 6, name: '五花肉', price: 28.80, quantity: 2, unit: '斤' }
]),
user_info: JSON.stringify({ phone: '13900139000', name: '李四' })
},
{
id: 'ORD202401050005',
user_id: 1,
status: 'cancelled',
total_price: 299.90,
cart: JSON.stringify([
{ goods_id: 3, name: '进口车厘子', price: 59.90, quantity: 5, unit: '斤' }
]),
user_info: JSON.stringify({ phone: '13800138000', name: '张三' })
}
]
for (const order of orders) {
await query(
'INSERT INTO orders (id, user_id, status, total_price, cart, user_info) VALUES (?, ?, ?, ?, ?, ?) ON DUPLICATE KEY UPDATE status=VALUES(status)',
[order.id, order.user_id, order.status, order.total_price, order.cart, order.user_info]
)
}
console.log('Inserting mock stock...')
const stockItems = [
{ goods_id: 1, quantity: 100, warehouse: '默认仓库' },
{ goods_id: 2, quantity: 200, warehouse: '默认仓库' },
{ goods_id: 3, quantity: 50, warehouse: '默认仓库' },
{ goods_id: 4, quantity: 80, warehouse: '默认仓库' },
{ goods_id: 5, quantity: 120, warehouse: '默认仓库' },
{ goods_id: 6, quantity: 60, warehouse: '默认仓库' },
{ goods_id: 7, quantity: 40, warehouse: '默认仓库' },
{ goods_id: 8, quantity: 30, warehouse: '默认仓库' },
{ goods_id: 9, quantity: 150, warehouse: '默认仓库' },
{ goods_id: 10, quantity: 300, warehouse: '默认仓库' },
{ goods_id: 11, quantity: 200, warehouse: '默认仓库' },
{ goods_id: 12, quantity: 500, warehouse: '默认仓库' },
{ goods_id: 13, quantity: 200, warehouse: '默认仓库' },
{ goods_id: 14, quantity: 150, warehouse: '默认仓库' },
{ goods_id: 15, quantity: 500, warehouse: '默认仓库' }
]
for (const stock of stockItems) {
await query(
'INSERT INTO stock (goods_id, quantity, warehouse) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE quantity=VALUES(quantity)',
[stock.goods_id, stock.quantity, stock.warehouse]
)
}
console.log('Inserting mock suppliers...')
const suppliers = [
{ name: '鲜果源供应链', contact: '王经理', phone: '13800001001', address: '广州市白云区江南批发市场A区' },
{ name: '旺旺食品总代理', contact: '李经理', phone: '13800001002', address: '广州市天河区中山大道88号' },
{ name: '百事饮品华南分公司', contact: '陈经理', phone: '13800001003', address: '广州市番禺区南村镇兴业大道' }
]
for (const s of suppliers) {
await query(
'INSERT INTO suppliers (name, contact, phone, address) VALUES (?, ?, ?, ?) ON DUPLICATE KEY UPDATE name=VALUES(name)',
[s.name, s.contact, s.phone, s.address]
)
}
console.log('Inserting mock purchases...')
const purchases = [
{ supplier_name: '鲜果源供应链', total: 2560.00, status: 1, remarks: '周常补货' },
{ supplier_name: '旺旺食品总代理', total: 1800.50, status: 0, remarks: '' }
]
for (const p of purchases) {
const supplier = await query('SELECT id FROM suppliers WHERE name = ?', [p.supplier_name])
const supplierId = supplier.length > 0 ? supplier[0].id : null
const purchaseResult = await query(
'INSERT INTO purchases (supplier_id, supplier_name, total, status, remarks) VALUES (?, ?, ?, ?, ?)',
[supplierId, p.supplier_name, p.total, p.status, p.remarks || '']
)
if (p.supplier_name === '鲜果源供应链') {
await query(
'INSERT INTO purchase_items (purchase_id, goods_id, goods_name, quantity, purchase_price) VALUES (?, ?, ?, ?, ?)',
[purchaseResult.insertId, 1, '红富士苹果', 50, 10.00]
)
await query(
'INSERT INTO purchase_items (purchase_id, goods_id, goods_name, quantity, purchase_price) VALUES (?, ?, ?, ?, ?)',
[purchaseResult.insertId, 3, '进口车厘子', 20, 45.00]
)
} else if (p.supplier_name === '旺旺食品总代理') {
await query(
'INSERT INTO purchase_items (purchase_id, goods_id, goods_name, quantity, purchase_price) VALUES (?, ?, ?, ?, ?)',
[purchaseResult.insertId, 12, '卫龙辣条', 100, 3.80]
)
}
}
console.log('Inserting mock points goods...')
const pointsGoods = [
{ name: '定制帆布袋', points: 200, stock: 50, image: '', description: '环保帆布袋' },
{ name: '玻璃水杯', points: 500, stock: 30, image: '', description: '350ml 双层玻璃杯' },
{ name: '50元优惠券', points: 1000, stock: 20, image: '', description: '满100可用' }
]
for (const g of pointsGoods) {
await query(
'INSERT INTO points_goods (name, points, stock, image, description) VALUES (?, ?, ?, ?, ?)',
[g.name, g.points, g.stock, g.image, g.description]
)
}
console.log('Inserting mock points logs...')
const pointsLogs = [
{ user_id: 1, type: 'earn', amount: 1000, description: '新用户注册赠送' },
{ user_id: 1, type: 'spend', amount: 200, description: '积分兑换商品' },
{ user_id: 1, type: 'earn', amount: 50, description: '购物满100元奖励' },
{ user_id: 2, type: 'earn', amount: 500, description: '新用户注册赠送' },
{ user_id: 2, type: 'earn', amount: 30, description: '购物满50元奖励' }
]
for (const log of pointsLogs) {
await query(
'INSERT INTO points_logs (user_id, type, amount, description) VALUES (?, ?, ?, ?)',
[log.user_id, log.type, log.amount, log.description]
)
}
console.log('✅ Mock data inserted successfully!')
console.log('\n--- Data Summary ---')
const categories = await query('SELECT COUNT(*) as count FROM categories')
const goods = await query('SELECT COUNT(*) as count FROM goods')
const users = await query('SELECT COUNT(*) as count FROM users')
const ordersCount = await query('SELECT COUNT(*) as count FROM orders')
const stockCount = await query('SELECT COUNT(*) as count FROM stock')
const logsCount = await query('SELECT COUNT(*) as count FROM points_logs')
const suppliersCount = await query('SELECT COUNT(*) as count FROM suppliers')
const purchasesCount = await query('SELECT COUNT(*) as count FROM purchases')
const pointsGoodsCount = await query('SELECT COUNT(*) as count FROM points_goods')
console.log(`分类: ${categories[0]?.count || 0}`)
console.log(`商品: ${goods[0]?.count || 0}`)
console.log(`用户: ${users[0]?.count || 0}`)
console.log(`订单: ${ordersCount[0]?.count || 0}`)
console.log(`库存: ${stockCount[0]?.count || 0}`)
console.log(`积分记录: ${logsCount[0]?.count || 0}`)
console.log(`供应商: ${suppliersCount[0]?.count || 0}`)
console.log(`采购单: ${purchasesCount[0]?.count || 0}`)
console.log(`积分商品: ${pointsGoodsCount[0]?.count || 0}`)
process.exit(0)
} catch (error) {
console.error('Failed to insert mock data:', error)
process.exit(1)
}
}
run()