TDSQL-PG创建测试表并定时插入数据模拟生产

TDSQL-PG创建测试表并定时插入数据模拟生产

复制代码
-- 创建 t_customer 表
CREATE TABLE t_customer (
    id SERIAL PRIMARY KEY,
    customer_code VARCHAR(50) NOT NULL,
    customer_name VARCHAR(100) NOT NULL,
    age INTEGER,
    city VARCHAR(50),
    status VARCHAR(20) DEFAULT 'ACTIVE',
    create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    update_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

-- 添加注释
COMMENT ON TABLE t_customer IS '客户表';
COMMENT ON COLUMN t_customer.id IS '主键ID';
COMMENT ON COLUMN t_customer.customer_code IS '客户编码';
COMMENT ON COLUMN t_customer.customer_name IS '客户名称';
COMMENT ON COLUMN t_customer.age IS '年龄';
COMMENT ON COLUMN t_customer.city IS '城市';
COMMENT ON COLUMN t_customer.status IS '状态:ACTIVE/INACTIVE';
COMMENT ON COLUMN t_customer.create_time IS '创建时间';
COMMENT ON COLUMN t_customer.update_time IS '更新时间';


-- 创建插入数据的函数(修正数组访问语法)
CREATE OR REPLACE FUNCTION insert_batch_customer()
RETURNS INTEGER AS $$
DECLARE
    i INTEGER;
    v_count INTEGER;
    v_cities TEXT[];
BEGIN
    -- 定义城市数组
    v_cities := ARRAY['北京', '上海', '广州', '深圳', '杭州', '成都', '武汉', '西安'];
    
    -- 获取当前表记录数作为起始编号
    SELECT COALESCE(MAX(id), 0) INTO v_count FROM t_customer;
    
    -- 循环插入10条数据
    FOR i IN 1..10 LOOP
        INSERT INTO t_customer (
            customer_code,
            customer_name,
            age,
            city,
            status,
            create_time,
            update_time
        ) VALUES (
            'CUST_' || TO_CHAR(NOW(), 'YYYYMMDDHH24MISS') || '_' || LPAD((v_count + i)::TEXT, 6, '0'),
            '客户_' || (v_count + i),
            18 + FLOOR(RANDOM() * 50)::INTEGER,
            v_cities[FLOOR(RANDOM() * array_length(v_cities, 1)) + 1],
            CASE WHEN RANDOM() > 0.2 THEN 'ACTIVE' ELSE 'INACTIVE' END,
            NOW(),
            NOW()
        );
    END LOOP;
    
    RETURN 10;
END;
$$ LANGUAGE plpgsql;

-- 测试函数
SELECT insert_batch_customer();

-- 查询插入的数据
SELECT * FROM t_customer ORDER BY id DESC LIMIT 20;


-- 创建定时任务(需要 pg_cron 扩展)
-- 方法1:使用 pg_cron 扩展(推荐)
CREATE EXTENSION IF NOT EXISTS pg_cron;

-- 每隔5分钟执行一次插入任务
SELECT cron.schedule(
    'insert-customer-job',           -- 任务名称
    '*/5 * * * *',                   -- cron表达式:每5分钟
    'SELECT insert_batch_customer()' -- 执行的SQL
);


-- 2. 更新任务的数据库字段
UPDATE cron.job SET database = 'rsyncdb' WHERE jobname = 'insert-customer-job';

-- 3. 验证配置
-- 查看已创建的定时任务
SELECT * FROM cron.job;

-- 删除定时任务(如需要)
-- SELECT cron.unschedule('insert-customer-job');

-- 方法2:如果不支持 pg_cron,可以使用 pgAgent
-- 需要在 pgAgent 中创建作业,步骤配置为:
-- SELECT insert_batch_customer();

-- 方法3:使用 Linux crontab + psql 命令
-- 在 crontab 中添加:
-- */5 * * * * psql -U username -d dbname -c "SELECT insert_batch_customer();"

-- 手动测试插入函数
-- SELECT insert_batch_customer();

-- 查询插入的数据
SELECT * FROM t_customer ORDER BY id DESC LIMIT 20;

-- 创建索引优化查询
CREATE INDEX idx_customer_code ON t_customer(customer_code);
CREATE INDEX idx_customer_status ON t_customer(status);
CREATE INDEX idx_create_time ON t_customer(create_time);

--查看定时任务执行历史
select * from cron.job_run_details ;
相关推荐
IT_陈寒2 小时前
JavaScript的闭包把我坑惨了,说好的内存会自动回收呢?
前端·人工智能·后端
Jackson__3 小时前
分享一个横向滚动案例,带悬停暂停,通用性很强
前端
MariaH4 小时前
git rebase的使用
前端
_柳青杨4 小时前
深入理解 JavaScript 事件循环
前端·javascript
阡陌Jony4 小时前
关于前端性能优化的一些问题:
前端
用户600071819105 小时前
【翻译】简化 TSRX
前端
IT乐手6 小时前
佛德角逼平西班牙,国足还有啥借口?
前端
JustHappy6 小时前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
星栈6 小时前
Dioxus 的响应式系统:`Signal`、`Memo`、`Effect` 和异步状态到底该怎么分工
前端·前端框架
yingyima6 小时前
Java 正则表达式:比你想象的更强大
前端