复制代码
-- 创建 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 ;