PGSQL 对象创建函数生成工具

news2025/4/5 16:32:24

文章目录

  • 代码
  • 结果

代码

<!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
BEGIN
    PERFORM NULL FROM pg_tables WHERE tablename='${tableName}';
    IF NOT FOUND THEN
        CREATE 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
BEGIN
    PERFORM attname FROM pg_attribute 
    WHERE attname = '${details.split(" ")[0]}'  -- 字段名\n    AND attrelid = '${tableName}'::regclass; -- 表名
    IF NOT FOUND THEN
        ALTER 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
BEGIN
    PERFORM 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
BEGIN
    SELECT * 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
BEGIN
    PERFORM 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>

结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2328687.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

查询当前用户的购物车和清空购物车

业务需求&#xff1a; 在小程序用户端购物车页面能查到当前用户的所有菜品或者套餐 代码实现 controller层 GetMapping("/list")public Result<List<ShoppingCart>> list(){List<ShoppingCart> list shoppingCartService.shopShoppingCart();r…

八、重学C++—动态多态(运行期)

上一章节&#xff1a; 七、重学C—静态多态&#xff08;编译期&#xff09;-CSDN博客https://blog.csdn.net/weixin_36323170/article/details/146999362?spm1001.2014.3001.5502 本章节代码&#xff1a; cpp/dynamicPolymorphic.cpp CuiQingCheng/cppstudy - 码云 - 开源中…

饮食助力进行性核上性麻痹患者,提升生活质量

进行性核上性麻痹是一种少见的神经系统变性疾病&#xff0c;患者会出现姿势不稳、眼球运动障碍等症状。合理的饮食对于维持患者身体机能、延缓病情发展有重要意义。 高蛋白质食物是饮食结构的重要部分。像瘦肉、去皮禽肉、鱼类、豆类及其制品&#xff0c;还有低脂奶制品等&…

bun 版本管理工具 bum 安装与使用

在使用 node 的过程中&#xff0c;我们可能会因为版本更新或者不同项目的要求而频繁切换 node 版本&#xff0c;或者是希望使用更简单的方式安装不同版本的 node&#xff0c;这个时候我们一般会用到 nvm 或者类似的工具。 在我尝试使用 bun 的时候&#xff0c;安装前第一个想到…

木马学习记录

一句话木马是什么 一句话木马就是仅需要一行代码的木马&#xff0c;很简短且简单&#xff0c;木马的函数将会执行我们发送的命令 如何发送命令&#xff06;发送的命令如何执行? 有三种方式&#xff1a;GET&#xff0c;POST&#xff0c;COOKIE&#xff0c;一句话木马中用$_G…

决策树实战:用Python实现智能分类与预测

目录 一、环境准备 二、数据加载与探索 三、数据预处理 四、决策树模型构建 五、模型可视化&#xff08;生成决策树结构图&#xff09; 六、模型预测与评估 七、超参数调优&#xff08;网格搜索&#xff09; 八、关键知识点解析 九、完整项目开发流程 十、常见问题解…

Crond任务调度

今天我们来看看任务调度,假如我们正在睡觉,突然有个半夜两点的任务要你备份一下数据库,你怎么办&#xff1f;难道从被窝中爬起来吗&#xff1f;显然不合理,此时就需要我们定时任务调度程序了. 原理图&#xff1a; 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

在上一篇&#xff0c;我们安装好xtquant&#xff0c;qmt以及python后&#xff0c;这一章&#xff0c;我们学习如何使用xtquant 本章学习&#xff0c;如何获取账号的资金使用状况。 首先&#xff0c;打开qmt&#xff0c;输入账号密码&#xff0c;选择独立交易。 进入交易界面&…

git clone 提示需要登录 github

我们在进行git的时候&#xff0c;可能会弹出让你登陆github的选项&#xff0c;这里我们介绍Token登陆的方法。 正常登陆你的Github 下拉找到 Developer settings按照如下步骤进行操作 填写相关信息&#xff0c;勾选对应选项 返回就能看到token已经被生成&#xff0c;可以使…

4.2-3 fiddler抓取手机接口

安卓&#xff1a; 长按手机连接的WiFi&#xff0c;点击修改网络 把代理改成手动&#xff0c;服务器主机选择自己电脑的IP地址&#xff0c;端口号为8888&#xff08;在dos窗口输入ipconfig查询IP地址&#xff0c;为ipv4&#xff09; 打开手机浏览器&#xff0c;输入http://自己…

Nacos注册中心AP模式核心源码分析(单机模式)

文章目录 概述一、客户端启动主线流程源码分析1.1、客户端与Spring Boot整合1.2、注册实例&#xff08;服务注册&#xff09;1.3、发送心跳1.4、拉取服务端实例列表&#xff08;服务发现&#xff09; 二、服务端接收请求主线流程源码分析2.1、接收注册请求2.1.1、初始化注册表2…

【进收藏夹吃灰】机器学习学习指南

博客标题URL【机器学习】线性回归&#xff08;506字&#xff09;https://blog.csdn.net/from__2025_03_16/article/details/146303423

【Web 服务器】的工作原理

&#x1f310; Web 服务器的工作原理 Web 服务器的主要作用是 接收客户端请求&#xff08;通常是浏览器发出的 HTTP/HTTPS 请求&#xff09;&#xff0c;处理请求&#xff0c;并返回相应的数据&#xff08;如网页、图片、API 响应等&#xff09;。 &#x1f4cc; 工作流程 1️…

【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 二、过滤镜像 修改 三、部署 四、检查&#xff1a; 五、扩充副本数 # kubectl scale --replicas3 deployment/ingr…

很简单 的 将字幕生成视频的 方法

一、一键将字幕生成视频的 方法 1、下载任性动图 10.7 以上版本 2、设置背景 1&#xff09;背景大小 拉伸背景到合适大小&#xff0c;或者选择右侧比例 2&#xff09;、直接空背景&#xff0c;设置背景颜色等详细信息 3&#xff09;、或者 复制或者突然图片做背景 3、设置文…

OpenCv(二)——边界填充、阈值处理

目录 一、边界填充 &#xff08;1&#xff09;constant边界填充&#xff0c;填充指定宽度的像素 &#xff08;2&#xff09;REFLECT镜像边界填充 &#xff08;3&#xff09;REFLECT_101镜像边界填充改进 (4) REPLICATE使用最边界的像素值代替 (5)WRAP上下左右边依次替换 二…

理解OSPF Stub区域和各类LSA特点

之前学习到OSPF特殊区域和各类类型LSA的分析后&#xff0c;一直很混乱&#xff0c;在网上也难找到详细的解释&#xff0c;在看了 HCNP书本内容后&#xff0c;对这块类容理解更加清晰&#xff0c;本次内容&#xff0c;我们使用实验示例&#xff0c;来对OSPF特殊区域和各 类型LSA…

CAN/FD CAN总线配置 最新详解 包含理论+实战(附带源码)

看前须知&#xff1a;本篇文章不会说太多理论性的内容&#xff08;重点在理论结合实践&#xff09;&#xff0c;顾及实操&#xff0c;应用&#xff0c;一切理论内容支撑都是为了后续实际操作进行铺垫&#xff0c;重点在于读者可以看完文章应用。&#xff08;也为节约读者时间&a…