PGSQL 对象创建函数生成工具
文章目录
- 代码
- 结果
代码
<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>PGSQL 函数生成器</title><style>body { font-family: Arial, sans-serif; margin: 20px; }label, select, input, button { display: block; margin-bottom: 10px; }/* 下拉列表宽度自适应 */select {width: auto;min-width: 150px;}/* 文本框宽度控制 */input[type="text"] {width: 100%;max-width: 400px;padding: 5px;}/* 按钮样式 */button { width: auto; padding: 8px 16px; cursor: pointer; }/* 使用 pre 显示 SQL 代码 */pre {width: 100%;min-height: 100px;white-space: pre-wrap;word-wrap: break-word;border: 1px solid #ccc;padding: 10px;overflow: auto;}</style>
</head>
<body><h2>PGSQL 函数生成器</h2><label for="operation">选择 SQL 操作:</label><select id="operation"><option value="create_table">新建表</option><option value="add_column">新增字段</option><option value="create_sequence">新增序列</option><option value="create_index">新增索引</option><option value="add_constraint">新增约束</option></select><!-- 表名区域(除新增序列外) --><div id="tableName-section"><label for="tableName">表名:</label><input type="text" id="tableName" placeholder="请输入表名"></div><div id="details-section"><label for="details" id="details-label">建表 SQL:</label><input type="text" id="details" placeholder="例如: create table test (id bigserial primary key, info text);"></div><div id="index-section" style="display:none;"><label for="indexName">索引名称:</label><input type="text" id="indexName" placeholder="请输入索引名称"><label for="indexFields">索引字段:</label><input type="text" id="indexFields" placeholder="例如: id, info"></div><div id="constraint-section" style="display:none;"><label for="constraintName">约束名称:</label><input type="text" id="constraintName" placeholder="请输入约束名称"><label for="constraintDetails">约束信息:</label><input type="text" id="constraintDetails" placeholder="例如: CHECK (age < 200 AND age >= 0)"></div><button onclick="generateSQL()">生成 SQL</button><label for="output">生成的 SQL:</label><pre id="output"></pre><script>// 下拉列表变化时,清空所有输入框及输出,并根据选项调整显示区域document.getElementById("operation").addEventListener("change", function(){// 清空所有文本框let inputs = document.querySelectorAll("input[type='text']");inputs.forEach(input => input.value = "");// 清空输出区域document.getElementById("output").innerHTML = "";let op = this.value;let detailsLabel = document.getElementById("details-label");let detailsInput = document.getElementById("details");let indexSection = document.getElementById("index-section");let constraintSection = document.getElementById("constraint-section");let tableNameSection = document.getElementById("tableName-section");if (op === "create_table") {// 对于新建表,显示表名输入区域tableNameSection.style.display = "block";detailsLabel.innerText = "建表 SQL";detailsInput.placeholder = "例如: create table test (id bigserial primary key, info text);";detailsInput.style.display = "block";indexSection.style.display = "none";constraintSection.style.display = "none";} else if (op === "add_column") {tableNameSection.style.display = "block";detailsLabel.innerText = "字段信息";detailsInput.placeholder = "例如: age int";detailsInput.style.display = "block";indexSection.style.display = "none";constraintSection.style.display = "none";} else if (op === "create_sequence") {// 对于新增序列,不需要表名输入tableNameSection.style.display = "none";detailsLabel.innerText = "序列创建 SQL";detailsInput.placeholder = "例如: CREATE SEQUENCE test_id_seq";detailsInput.style.display = "block";indexSection.style.display = "none";constraintSection.style.display = "none";} else if (op === "create_index") {tableNameSection.style.display = "block";detailsLabel.innerText = ""; // 不再显示 "索引创建 SQL"detailsInput.style.display = "none";indexSection.style.display = "block";constraintSection.style.display = "none";} else if (op === "add_constraint") {tableNameSection.style.display = "block";detailsLabel.innerText = ""; // 不再显示 "约束创建 SQL"detailsInput.style.display = "none";indexSection.style.display = "none";constraintSection.style.display = "block";}});function generateSQL() {let operation = document.getElementById("operation").value;// 对于 create_sequence,不使用表名输入let tableName = document.getElementById("tableName").value.trim();let details = document.getElementById("details").value.trim();let indexName = document.getElementById("indexName").value.trim();let indexFields = document.getElementById("indexFields").value.trim();let constraintName = document.getElementById("constraintName").value.trim();let constraintDetails = document.getElementById("constraintDetails").value.trim();let sql = "";// 对于新增序列操作,不需要表名if (operation !== "create_sequence" && !tableName) {alert("请输入表名");return;}switch (operation) {case "create_table":if (!details) {alert("请输入建表 SQL");return;}sql = `-- 新建表
CREATE OR REPLACE FUNCTION func_AA00000()
RETURNS int AS
$BODY$
DECLARE
BEGINPERFORM NULL FROM pg_tables WHERE tablename='${tableName}';IF NOT FOUND THENCREATE TABLE ${tableName}(${details});END IF;RETURN 0;
END;
$BODY$
LANGUAGE plpgsql VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;SELECT * FROM func_AA00000();
DROP FUNCTION IF EXISTS func_AA00000();`;break;case "add_column":if (!details) {alert("请输入字段信息");return;}sql = `-- 新增字段
CREATE OR REPLACE FUNCTION func_AA00000()
RETURNS int AS
$BODY$
DECLARE
BEGINPERFORM attname FROM pg_attribute WHERE attname = '${details.split(" ")[0]}' -- 字段名\n AND attrelid = '${tableName}'::regclass; -- 表名IF NOT FOUND THENALTER TABLE ${tableName} ADD ${details};END IF;RETURN 0;
END;
$BODY$
LANGUAGE plpgsql VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;SELECT * FROM func_AA00000();
DROP FUNCTION IF EXISTS func_AA00000();`;break;case "create_sequence":if (!details) {alert("请输入序列创建 SQL");return;}// 提取序列名称:假设格式为 "CREATE SEQUENCE seq_name"let tokens = details.split(/\s+/);let seqName = tokens[2] ? tokens[2] : "";if (!seqName) {alert("无法解析序列名称,请检查输入格式");return;}sql = `-- 新增序列
CREATE OR REPLACE FUNCTION func_AA00000()
RETURNS int AS
$BODY$
DECLARE
BEGINPERFORM NULL FROM information_schema.sequences WHERE sequence_name='${seqName}'; -- 序列名IF NOT FOUND THEN ${details};END IF;RETURN 0;
END;
$BODY$
LANGUAGE plpgsql VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;SELECT * FROM func_AA00000();
DROP FUNCTION IF EXISTS func_AA00000();`;break;case "create_index":if (!indexName || !indexFields) {alert("请输入索引名称和索引字段");return;}sql = `-- 新增索引
CREATE OR REPLACE FUNCTION func_AA00000()
RETURNS int AS
$BODY$
DECLARE
BEGINSELECT * FROM pg_indexes WHERE tablename='${tableName}' -- 表名\n AND indexname='${indexName}'; -- 索引名IF NOT FOUND THEN CREATE INDEX ${indexName} ON ${tableName}(${indexFields});END IF;RETURN 0;
END;
$BODY$
LANGUAGE plpgsql VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;SELECT * FROM func_AA00000();
DROP FUNCTION IF EXISTS func_AA00000();`;break;case "add_constraint":if (!constraintName || !constraintDetails) {alert("请输入约束名称和约束信息");return;}sql = `-- 新增约束
CREATE OR REPLACE FUNCTION func_AA00000()
RETURNS int AS
$BODY$
DECLARE
BEGINPERFORM conname FROM pg_constraint WHERE conname = '${constraintName}' -- 约束名\n AND conrelid = '${tableName}'::regclass; -- 表名IF NOT FOUND THEN ALTER TABLE ${tableName} ADD CONSTRAINT ${constraintName} ${constraintDetails};END IF;RETURN 0;
END;
$BODY$
LANGUAGE plpgsql VOLATILE CALLED ON NULL INPUT SECURITY INVOKER;SELECT * FROM func_AA00000();
DROP FUNCTION IF EXISTS func_AA00000();`;break;}// 为 SQL 文本按行处理,对注释行添加蓝色前景色let htmlContent = sql.split('\n').map(line => {if (line.trim().startsWith('--')) {return `<span style="color:blue;">${line}</span>`;}return line;}).join('\n');document.getElementById("output").innerHTML = htmlContent;}</script></body>
</html>
结果

相关文章:
PGSQL 对象创建函数生成工具
文章目录 代码结果 代码 <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>PGSQL 函数生成器</tit…...
查询当前用户的购物车和清空购物车
业务需求: 在小程序用户端购物车页面能查到当前用户的所有菜品或者套餐 代码实现 controller层 GetMapping("/list")public Result<List<ShoppingCart>> list(){List<ShoppingCart> list shoppingCartService.shopShoppingCart();r…...
八、重学C++—动态多态(运行期)
上一章节: 七、重学C—静态多态(编译期)-CSDN博客https://blog.csdn.net/weixin_36323170/article/details/146999362?spm1001.2014.3001.5502 本章节代码: cpp/dynamicPolymorphic.cpp CuiQingCheng/cppstudy - 码云 - 开源中…...
react redux的学习,多个reducer
redux系列文章目录 第一章 简单学习redux,单个reducer 前言 前面我们学习到的是单reducer的使用;要知道redux是个很强大的状态存储库,可以支持多个reducer的使用。 combineReducers combineReducers是Redux中的一个辅助函数,主要用于…...
饮食助力进行性核上性麻痹患者,提升生活质量
进行性核上性麻痹是一种少见的神经系统变性疾病,患者会出现姿势不稳、眼球运动障碍等症状。合理的饮食对于维持患者身体机能、延缓病情发展有重要意义。 高蛋白质食物是饮食结构的重要部分。像瘦肉、去皮禽肉、鱼类、豆类及其制品,还有低脂奶制品等&…...
leetcode117 填充每个节点的下一个右侧节点指针2
LeetCode 116 和 117 都是关于填充二叉树节点的 next 指针的问题,但它们的区别在于 树的类型 不同,117与 116 题类似,但给定的树是 普通二叉树(不一定完全填充),即某些节点可能缺少左或右子节点。 树的结构…...
bun 版本管理工具 bum 安装与使用
在使用 node 的过程中,我们可能会因为版本更新或者不同项目的要求而频繁切换 node 版本,或者是希望使用更简单的方式安装不同版本的 node,这个时候我们一般会用到 nvm 或者类似的工具。 在我尝试使用 bun 的时候,安装前第一个想到…...
使用RKNN进行yolo11-cls部署
文章目录 概要制作数据集模型训练onnx导出rknn导出概要 YOLO(You Only Look Once)是一系列高效的目标检测算法,其核心思想是将目标检测任务转化为一个回归问题,通过单个神经网络直接在图像上预测边界框和类别概率。当将其用于分类任务时,会去除目标检测相关的边界框预测部…...
木马学习记录
一句话木马是什么 一句话木马就是仅需要一行代码的木马,很简短且简单,木马的函数将会执行我们发送的命令 如何发送命令&发送的命令如何执行? 有三种方式:GET,POST,COOKIE,一句话木马中用$_G…...
C#编程基础知识点介绍
以下是 C# 中常见元素(属性、方法、枚举、函数等)的详细定义及示例: 1. 类(Class) 类是 C# 中最基本的类型,它是对象的蓝图,封装了数据和行为。 // 定义一个名为Person的类 public class Per…...
决策树实战:用Python实现智能分类与预测
目录 一、环境准备 二、数据加载与探索 三、数据预处理 四、决策树模型构建 五、模型可视化(生成决策树结构图) 六、模型预测与评估 七、超参数调优(网格搜索) 八、关键知识点解析 九、完整项目开发流程 十、常见问题解…...
Crond任务调度
今天我们来看看任务调度,假如我们正在睡觉,突然有个半夜两点的任务要你备份一下数据库,你怎么办?难道从被窝中爬起来吗?显然不合理,此时就需要我们定时任务调度程序了. 原理图: crontab 进行定时任务的调度 概述. 任务调度:是指系统在某个…...
HTML5+CSS3+JS小实例:带滑动指示器的导航图标
实例:带滑动指示器的导航图标 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, ini…...
MINIQMT学习课程Day7
在上一篇,我们安装好xtquant,qmt以及python后,这一章,我们学习如何使用xtquant 本章学习,如何获取账号的资金使用状况。 首先,打开qmt,输入账号密码,选择独立交易。 进入交易界面&…...
每日一个小病毒(C++)EnumChildWindows+shellcode
这里写目录标题 1. `EnumChildWindows` 的基本用法2. 如何利用 `EnumChildWindows` 执行 Shellcode?关键点:完整 Shellcode 执行示例3. 为什么 `EnumChildWindows` 能执行 Shellcode?4. 防御方法5. 总结EnumChildWindows 是 Windows API 中的一个函数,通常用于枚举所有子窗…...
使用minio客户端mc工具迁移指定文件到本地
如果需要筛选MinIO桶中的特定文件进行迁移,可以使用MinIO Client(mc)工具结合一些命令行技巧来实现。以下是具体步骤: 1、安装 MinIO Client(mc) wget https://dl.min.io/client/mc/release/linux-amd64/…...
git clone 提示需要登录 github
我们在进行git的时候,可能会弹出让你登陆github的选项,这里我们介绍Token登陆的方法。 正常登陆你的Github 下拉找到 Developer settings按照如下步骤进行操作 填写相关信息,勾选对应选项 返回就能看到token已经被生成,可以使…...
4.2-3 fiddler抓取手机接口
安卓: 长按手机连接的WiFi,点击修改网络 把代理改成手动,服务器主机选择自己电脑的IP地址,端口号为8888(在dos窗口输入ipconfig查询IP地址,为ipv4) 打开手机浏览器,输入http://自己…...
Nacos注册中心AP模式核心源码分析(单机模式)
文章目录 概述一、客户端启动主线流程源码分析1.1、客户端与Spring Boot整合1.2、注册实例(服务注册)1.3、发送心跳1.4、拉取服务端实例列表(服务发现) 二、服务端接收请求主线流程源码分析2.1、接收注册请求2.1.1、初始化注册表2…...
【进收藏夹吃灰】机器学习学习指南
博客标题URL【机器学习】线性回归(506字)https://blog.csdn.net/from__2025_03_16/article/details/146303423...
【Web 服务器】的工作原理
🌐 Web 服务器的工作原理 Web 服务器的主要作用是 接收客户端请求(通常是浏览器发出的 HTTP/HTTPS 请求),处理请求,并返回相应的数据(如网页、图片、API 响应等)。 📌 工作流程 1️…...
关于uint8_t、uint16_t、uint32_t、uint64_t的区别与分析
一、类型定义与字节大小 uint8_t、uint16_t、uint32_t、uint64_t 是 C/C 中定义的无符号整数类型,通过 typedef 对基础类型起别名实现。位宽(bit)和字节数严格固定: uint8_t:8 位,占用 1 字节ÿ…...
Linux命令-grep
grep 是一种强大的命令行工具,用于在一个或多个输入文件中搜索与正则表达式匹配的行,并将匹配的行标准输出。 1.基本搜索 参数 说明 -i 忽略大小写进行匹配 -w 只匹配完整的单词 -x 只匹配与整行完全匹配的行 -v 反向匹配,显示不匹配的行…...
【Cursor】设置语言
Ctrl Shift P 搜索 configure display language选择“中文-简体”...
k8s 1.30 安装ingress-nginx
一、下载 # wget https://mirrors.chenby.cn/https://raw.githubusercontent.com/kubernetes/ingress-nginx/main/deploy/static/provider/cloud/deploy.yaml 二、过滤镜像 修改 三、部署 四、检查: 五、扩充副本数 # kubectl scale --replicas3 deployment/ingr…...
很简单 的 将字幕生成视频的 方法
一、一键将字幕生成视频的 方法 1、下载任性动图 10.7 以上版本 2、设置背景 1)背景大小 拉伸背景到合适大小,或者选择右侧比例 2)、直接空背景,设置背景颜色等详细信息 3)、或者 复制或者突然图片做背景 3、设置文…...
OpenCv(二)——边界填充、阈值处理
目录 一、边界填充 (1)constant边界填充,填充指定宽度的像素 (2)REFLECT镜像边界填充 (3)REFLECT_101镜像边界填充改进 (4) REPLICATE使用最边界的像素值代替 (5)WRAP上下左右边依次替换 二…...
理解OSPF Stub区域和各类LSA特点
之前学习到OSPF特殊区域和各类类型LSA的分析后,一直很混乱,在网上也难找到详细的解释,在看了 HCNP书本内容后,对这块类容理解更加清晰,本次内容,我们使用实验示例,来对OSPF特殊区域和各 类型LSA…...
鸿蒙 ——选择相册图片保存到应用
photoAccessHelper // entry/src/main/ets/utils/file.ets import { fileIo } from kit.CoreFileKit; import { photoAccessHelper } from kit.MediaLibraryKit; import { bundleManager } from kit.AbilityKit;// 应用在本设备内部存储上通用的存放默认长期保存的文件路径&am…...
pat学习笔记
two pointers 双指针 给定一个递增的正整数序列和一个正整数M,求序列中的两个不同位置的数a和b,使得它们的和恰好为M,输出所有满足条件的方案。例如给定序列{1,2,3,4,5,6}和正整数M 8,就存在268和358成立。 容易想到࿱…...
