mirror of
https://github.com/csunny/DB-GPT.git
synced 2025-07-27 05:47:47 +00:00
220 lines
7.9 KiB
Python
220 lines
7.9 KiB
Python
import os
|
||
import random
|
||
import string
|
||
from datetime import datetime, timedelta
|
||
from typing import List
|
||
|
||
import pymysql
|
||
import pymysql.cursors
|
||
|
||
# At first you need to create an test database which called dbgpt_test;
|
||
# you can use next command to create.
|
||
# CREATE DATABASE IF NOT EXISTS dbgpt_test CHARACTER SET utf8;
|
||
|
||
|
||
def build_table(connection):
|
||
connection.cursor().execute(
|
||
"""CREATE TABLE user (
|
||
id INT(11) NOT NULL AUTO_INCREMENT COMMENT '用户ID',
|
||
name VARCHAR(50) NOT NULL COMMENT '用户名',
|
||
email VARCHAR(50) NOT NULL COMMENT '电子邮件',
|
||
mobile CHAR(11) NOT NULL COMMENT '手机号码',
|
||
gender VARCHAR(20) COMMENT '性别,可选值:Male, Female',
|
||
birth DATE COMMENT '出生日期',
|
||
country VARCHAR(20) COMMENT '国家',
|
||
city VARCHAR(20) COMMENT '城市',
|
||
create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||
update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
|
||
PRIMARY KEY (id),
|
||
UNIQUE KEY uk_email (email)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户信息表';"""
|
||
)
|
||
connection.cursor().execute(
|
||
"""CREATE TABLE transaction_order (
|
||
id INT(11) NOT NULL AUTO_INCREMENT COMMENT '订单ID',
|
||
order_no CHAR(20) NOT NULL COMMENT '订单编号',
|
||
product_name VARCHAR(50) NOT NULL COMMENT '产品名称',
|
||
product_category VARCHAR(20) COMMENT '产品分类',
|
||
amount DECIMAL(10, 2) NOT NULL COMMENT '订单金额',
|
||
pay_status VARCHAR(20) COMMENT '付款状态,可选值:CANCEL, REFUND, SUCCESS, FAILD',
|
||
user_id INT(11) NOT NULL COMMENT '用户ID',
|
||
user_name VARCHAR(50) COMMENT '用户名',
|
||
create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
|
||
update_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
|
||
PRIMARY KEY (id),
|
||
UNIQUE KEY uk_order_no (order_no),
|
||
KEY idx_user_id (user_id)
|
||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='交易订单表';"""
|
||
)
|
||
|
||
|
||
def user_build(names: List, country: str, grander: str = "Male") -> List:
|
||
countries = ["China", "US", "India", "Indonesia", "Pakistan"] # 国家列表
|
||
cities = {
|
||
"China": ["Beijing", "Shanghai", "Guangzhou", "Shenzhen", "Hangzhou"],
|
||
"US": ["New York", "Los Angeles", "Chicago", "Houston", "Phoenix"],
|
||
"India": ["Mumbai", "Delhi", "Bangalore", "Hyderabad", "Chennai"],
|
||
"Indonesia": ["Jakarta", "Surabaya", "Medan", "Bandung", "Makassar"],
|
||
"Pakistan": ["Karachi", "Lahore", "Faisalabad", "Rawalpindi", "Multan"],
|
||
}
|
||
|
||
users = []
|
||
for i in range(1, len(names) + 1):
|
||
if grander == "Male":
|
||
id = int(str(countries.index(country) + 1) + "10") + i
|
||
else:
|
||
id = int(str(countries.index(country) + 1) + "20") + i
|
||
|
||
name = names[i - 1]
|
||
email = f"{name}@example.com"
|
||
mobile = "".join(random.choices(string.digits, k=10))
|
||
gender = grander
|
||
birth = f"19{random.randint(60, 99)}-{random.randint(1, 12):02d}-{random.randint(1, 28):02d}"
|
||
country = country
|
||
city = random.choice(cities[country])
|
||
|
||
now = datetime.now()
|
||
year = now.year
|
||
|
||
start = datetime(year, 1, 1)
|
||
end = datetime(year, 12, 31)
|
||
random_date = start + timedelta(days=random.randint(0, (end - start).days))
|
||
random_time = datetime.combine(random_date, datetime.min.time()) + timedelta(
|
||
seconds=random.randint(0, 24 * 60 * 60 - 1)
|
||
)
|
||
|
||
random_datetime_str = random_time.strftime("%Y-%m-%d %H:%M:%S")
|
||
create_time = random_datetime_str
|
||
users.append(
|
||
(
|
||
id,
|
||
name,
|
||
email,
|
||
mobile,
|
||
gender,
|
||
birth,
|
||
country,
|
||
city,
|
||
create_time,
|
||
create_time,
|
||
)
|
||
)
|
||
return users
|
||
|
||
|
||
def gnerate_all_users(cursor):
|
||
users = []
|
||
users_f = ["ZhangWei", "LiQiang", "ZhangSan", "LiSi"]
|
||
users.extend(user_build(users_f, "China", "Male"))
|
||
users_m = ["Hanmeimei", "LiMeiMei", "LiNa", "ZhangLi", "ZhangMing"]
|
||
users.extend(user_build(users_m, "China", "Female"))
|
||
|
||
users1_f = ["James", "John", "David", "Richard"]
|
||
users.extend(user_build(users1_f, "US", "Male"))
|
||
users1_m = ["Mary", "Patricia", "Sarah"]
|
||
users.extend(user_build(users1_m, "US", "Female"))
|
||
|
||
users2_f = ["Ravi", "Rajesh", "Ajay", "Arjun", "Sanjay"]
|
||
users.extend(user_build(users2_f, "India", "Male"))
|
||
users2_m = ["Priya", "Sushma", "Pooja", "Swati"]
|
||
users.extend(user_build(users2_m, "India", "Female"))
|
||
for user in users:
|
||
cursor.execute(
|
||
"INSERT INTO user (id, name, email, mobile, gender, birth, country, city, create_time, update_time) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s)",
|
||
user,
|
||
)
|
||
|
||
return users
|
||
|
||
|
||
def gnerate_all_orders(users, cursor):
|
||
orders = []
|
||
orders_num = 200
|
||
categories = ["Clothing", "Food", "Home Appliance", "Mother and Baby", "Travel"]
|
||
|
||
categories_product = {
|
||
"Clothing": ["T-shirt", "Jeans", "Skirt", "Other"],
|
||
"Food": ["Snack", "Fruit"],
|
||
"Home Appliance": ["Refrigerator", "Television", "Air conditioner"],
|
||
"Mother and Baby": ["Diapers", "Milk Powder", "Stroller", "Toy"],
|
||
"Travel": ["Tent", "Fishing Rod", "Bike", "Rawalpindi", "Multan"],
|
||
}
|
||
|
||
for i in range(1, orders_num + 1):
|
||
id = i
|
||
order_no = "".join(random.choices(string.ascii_uppercase, k=3)) + "".join(
|
||
random.choices(string.digits, k=10)
|
||
)
|
||
product_category = random.choice(categories)
|
||
product_name = random.choice(categories_product[product_category])
|
||
amount = round(random.uniform(0, 10000), 2)
|
||
pay_status = random.choice(["SUCCESS", "FAILD", "CANCEL", "REFUND"])
|
||
user_id = random.choice(users)[0]
|
||
user_name = random.choice(users)[1]
|
||
|
||
now = datetime.now()
|
||
year = now.year
|
||
|
||
start = datetime(year, 1, 1)
|
||
end = datetime(year, 12, 31)
|
||
random_date = start + timedelta(days=random.randint(0, (end - start).days))
|
||
random_time = datetime.combine(random_date, datetime.min.time()) + timedelta(
|
||
seconds=random.randint(0, 24 * 60 * 60 - 1)
|
||
)
|
||
|
||
random_datetime_str = random_time.strftime("%Y-%m-%d %H:%M:%S")
|
||
create_time = random_datetime_str
|
||
|
||
order = (
|
||
id,
|
||
order_no,
|
||
product_category,
|
||
product_name,
|
||
amount,
|
||
pay_status,
|
||
user_id,
|
||
user_name,
|
||
create_time,
|
||
)
|
||
cursor.execute(
|
||
"INSERT INTO transaction_order (id, order_no, product_name, product_category, amount, pay_status, user_id, user_name, create_time) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s)",
|
||
order,
|
||
)
|
||
|
||
|
||
if __name__ == "__main__":
|
||
connection = pymysql.connect(
|
||
host=os.getenv("DB_HOST", "127.0.0.1"),
|
||
port=int(
|
||
os.getenv("DB_PORT", 3306),
|
||
),
|
||
user=os.getenv("DB_USER", "root"),
|
||
password=os.getenv("DB_PASSWORD", "aa12345678"),
|
||
database=os.getenv("DB_DATABASE", "dbgpt_test"),
|
||
charset="utf8mb4",
|
||
ssl_ca=None,
|
||
)
|
||
|
||
build_table(connection)
|
||
|
||
connection.commit()
|
||
|
||
cursor = connection.cursor()
|
||
|
||
users = gnerate_all_users(cursor)
|
||
connection.commit()
|
||
|
||
gnerate_all_orders(users, cursor)
|
||
connection.commit()
|
||
|
||
cursor.execute("SELECT * FROM user")
|
||
data = cursor.fetchall()
|
||
print(data)
|
||
|
||
cursor.execute("SELECT count(*) FROM transaction_order")
|
||
data = cursor.fetchall()
|
||
print("orders:" + str(data))
|
||
|
||
cursor.close()
|
||
connection.close()
|