Files
nxxmdata/bank-backend/scripts/seed-basic-data.js

298 lines
10 KiB
JavaScript
Raw Normal View History

const { sequelize, User, Role, Account, Transaction, LoanProduct, Employee, Department, Position } = require('../models');
const bcrypt = require('bcryptjs');
async function seedBasicData() {
try {
console.log('开始补充基础测试数据...');
// 1. 创建角色
console.log('创建角色...');
const roles = await Role.bulkCreate([
{ name: 'admin', display_name: '系统管理员', description: '系统管理员,拥有所有权限' },
{ name: 'manager', display_name: '经理', description: '部门经理,拥有部门管理权限' },
{ name: 'teller', display_name: '柜员', description: '银行柜员,处理日常业务' },
{ name: 'user', display_name: '普通用户', description: '普通银行客户' }
], { ignoreDuplicates: true });
// 2. 创建部门
console.log('创建部门...');
const departments = await Department.bulkCreate([
{ name: '行政部', code: 'ADMIN', description: '行政管理部门' },
{ name: '财务部', code: 'FINANCE', description: '财务管理部门' },
{ name: '技术部', code: 'IT', description: '技术开发部门' },
{ name: '人事部', code: 'HR', description: '人力资源部门' },
{ name: '销售部', code: 'SALES', description: '销售部门' },
{ name: '风控部', code: 'RISK', description: '风险控制部门' },
{ name: '客服部', code: 'SERVICE', description: '客户服务部门' }
], { ignoreDuplicates: true });
// 3. 创建职位
console.log('创建职位...');
const positions = await Position.bulkCreate([
{ name: '总经理', code: 'GM', level: 1, description: '总经理职位' },
{ name: '副总经理', code: 'DGM', level: 2, description: '副总经理职位' },
{ name: '部门经理', code: 'MGR', level: 3, description: '部门经理职位' },
{ name: '主管', code: 'SUP', level: 4, description: '主管职位' },
{ name: '高级员工', code: 'SENIOR', level: 5, description: '高级员工职位' },
{ name: '普通员工', code: 'STAFF', level: 6, description: '普通员工职位' },
{ name: '实习生', code: 'INTERN', level: 7, description: '实习生职位' }
], { ignoreDuplicates: true });
// 4. 创建用户
console.log('创建用户...');
const users = await User.bulkCreate([
{
username: 'admin',
email: 'admin@bank.com',
password: await bcrypt.hash('Admin123456', 10),
phone: '13800138000',
real_name: '系统管理员',
id_card: '110101199003071234',
role_id: roles.find(r => r.name === 'admin').id,
status: 'active'
},
{
username: 'manager1',
email: 'manager1@bank.com',
password: await bcrypt.hash('Manager123456', 10),
phone: '13800138001',
real_name: '张经理',
id_card: '110101198503071234',
role_id: roles.find(r => r.name === 'manager').id,
status: 'active'
},
{
username: 'teller1',
email: 'teller1@bank.com',
password: await bcrypt.hash('Teller123456', 10),
phone: '13800138002',
real_name: '李柜员',
id_card: '110101199203071234',
role_id: roles.find(r => r.name === 'teller').id,
status: 'active'
},
{
username: 'user1',
email: 'user1@bank.com',
password: await bcrypt.hash('User123456', 10),
phone: '13800138003',
real_name: '王客户',
id_card: '110101199503071234',
role_id: roles.find(r => r.name === 'user').id,
status: 'active'
},
{
username: 'user2',
email: 'user2@bank.com',
password: await bcrypt.hash('User123456', 10),
phone: '13800138004',
real_name: '赵客户',
id_card: '110101199603071234',
role_id: roles.find(r => r.name === 'user').id,
status: 'active'
}
], { ignoreDuplicates: true });
// 5. 创建员工
console.log('创建员工...');
const employees = await Employee.bulkCreate([
{
name: '张经理',
employee_id: 'EMP001',
email: 'manager1@bank.com',
phone: '13800138001',
id_card: '110101198503071234',
department_id: departments.find(d => d.name === '财务部').id,
position_id: positions.find(p => p.name === '部门经理').id,
hire_date: '2020-01-15',
salary_level: 'L6',
status: 'active',
supervisor: '系统管理员'
},
{
name: '李柜员',
employee_id: 'EMP002',
email: 'teller1@bank.com',
phone: '13800138002',
id_card: '110101199203071234',
department_id: departments.find(d => d.name === '客服部').id,
position_id: positions.find(p => p.name === '普通员工').id,
hire_date: '2021-03-20',
salary_level: 'L4',
status: 'active',
supervisor: '张经理'
},
{
name: '王技术',
employee_id: 'EMP003',
email: 'wangtech@bank.com',
phone: '13800138005',
id_card: '110101199103071234',
department_id: departments.find(d => d.name === '技术部').id,
position_id: positions.find(p => p.name === '高级员工').id,
hire_date: '2019-06-10',
salary_level: 'L5',
status: 'active',
supervisor: '张经理'
}
], { ignoreDuplicates: true });
// 6. 创建账户
console.log('创建账户...');
const accounts = await Account.bulkCreate([
{
account_number: '6225123456789001',
account_type: 'savings',
balance: 500000, // 5000元
user_id: users.find(u => u.username === 'user1').id,
status: 'active',
interest_rate: 0.0035
},
{
account_number: '6225123456789002',
account_type: 'checking',
balance: 100000, // 1000元
user_id: users.find(u => u.username === 'user1').id,
status: 'active',
interest_rate: 0.001
},
{
account_number: '6225123456789003',
account_type: 'savings',
balance: 200000, // 2000元
user_id: users.find(u => u.username === 'user2').id,
status: 'active',
interest_rate: 0.0035
},
{
account_number: '6225123456789004',
account_type: 'credit',
balance: -50000, // -500元信用卡欠款
user_id: users.find(u => u.username === 'user2').id,
status: 'active',
credit_limit: 100000, // 1000元信用额度
interest_rate: 0.18
}
], { ignoreDuplicates: true });
// 7. 创建交易记录
console.log('创建交易记录...');
const transactions = await Transaction.bulkCreate([
{
account_id: accounts[0].id,
type: 'deposit',
amount: 100000, // 1000元
balance_after: 600000, // 6000元
description: '工资入账',
status: 'completed',
reference_number: 'TXN001'
},
{
account_id: accounts[0].id,
type: 'withdrawal',
amount: 50000, // 500元
balance_after: 550000, // 5500元
description: 'ATM取款',
status: 'completed',
reference_number: 'TXN002'
},
{
account_id: accounts[1].id,
type: 'transfer',
amount: 20000, // 200元
balance_after: 120000, // 1200元
description: '转账到储蓄账户',
status: 'completed',
reference_number: 'TXN003'
},
{
account_id: accounts[2].id,
type: 'deposit',
amount: 50000, // 500元
balance_after: 250000, // 2500元
description: '现金存款',
status: 'completed',
reference_number: 'TXN004'
},
{
account_id: accounts[3].id,
type: 'payment',
amount: 30000, // 300元
balance_after: -80000, // -800元
description: '信用卡消费',
status: 'completed',
reference_number: 'TXN005'
}
], { ignoreDuplicates: true });
// 8. 创建贷款产品
console.log('创建贷款产品...');
const loanProducts = await LoanProduct.bulkCreate([
{
name: '个人住房贷款',
type: 'mortgage',
min_amount: 1000000, // 10万元
max_amount: 50000000, // 500万元
min_term: 12, // 1年
max_term: 360, // 30年
interest_rate: 0.045, // 4.5%
max_interest_rate: 0.055, // 5.5%
description: '个人住房按揭贷款,利率优惠',
status: 'active'
},
{
name: '个人消费贷款',
type: 'consumer',
min_amount: 10000, // 1万元
max_amount: 500000, // 50万元
min_term: 6, // 6个月
max_term: 60, // 5年
interest_rate: 0.065, // 6.5%
max_interest_rate: 0.085, // 8.5%
description: '个人消费贷款,用途广泛',
status: 'active'
},
{
name: '小微企业贷款',
type: 'business',
min_amount: 50000, // 5万元
max_amount: 1000000, // 100万元
min_term: 12, // 1年
max_term: 60, // 5年
interest_rate: 0.055, // 5.5%
max_interest_rate: 0.075, // 7.5%
description: '小微企业生产经营贷款',
status: 'active'
}
], { ignoreDuplicates: true });
console.log('✅ 基础测试数据补充完成');
console.log(`- 角色: ${roles.length}`);
console.log(`- 部门: ${departments.length}`);
console.log(`- 职位: ${positions.length}`);
console.log(`- 用户: ${users.length}`);
console.log(`- 员工: ${employees.length}`);
console.log(`- 账户: ${accounts.length}`);
console.log(`- 交易记录: ${transactions.length}`);
console.log(`- 贷款产品: ${loanProducts.length}`);
} catch (error) {
console.error('❌ 补充测试数据失败:', error);
throw error;
}
}
async function main() {
try {
await seedBasicData();
console.log('🎉 基础测试数据补充完成');
} catch (error) {
console.error('💥 基础测试数据补充失败:', error);
process.exit(1);
} finally {
await sequelize.close();
}
}
main();