PGSQL大小写敏感总结

article/2025/11/6 20:04:27

PGSQL大小写敏感总结


由于PGSQL使用会出现大小写敏感的问题,所以在设置字段名字的时候,如果字段名需要大写需要加上""号来表示,该字段需要大写

公司业务需要我使用PGSQL创建自增主键,我在使用 nextval() 绑定创建的序列的时候,创建的序列如下图所示,PGSQL会报错不让你通过。原因是 nextval()函数将双引号包裹的字段当成列 column,而我并没有创建这个类,所以导致创建失败了。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GVEPJASB-1662013455742)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220830095050152.png)]

而如果我使用 ''来包裹创建的序列字段的时候,PGSQL 会将我的序列名自动转换为小写,从而报找不到该序列的值的错误,如下图所示,如果是使用小写创建序列就没有问题了,但公司要求所有字段都必须要大写,难道真的没办法使用PGSQL使用大写的序列吗?

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0ICDtNSW-1662013455744)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220901134942296.png)]

后来,我误打误撞发现了,如果需要在nextval()函数使用大写的序列名,则需要在原本""的外面在包裹一层'',实在是太坑了,正常人一时半会也想不到,于是我写下这篇博客来记录一下。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VkE3LwCg-1662013455745)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20220830094800292.png)]

顺便附上我使用PGSQL创建自增主键的语句

-- 创建序列
create sequence "FR_IT_RM_ODS_TABLE_FI_ODS_SEQ"
start with 1
increment by 1
no minvalue
no maxvalue
cache 1;-- 修改主键的默认值,添加上序列
alter table "FR_IT_RM_ODS_TABLE_FI_ODS_SEQ" alter column "ID" set default nextval('"FR_IT_RM_ODS_TABLE_FI_ODS_SEQ"')

如果建表的时候使用的是 serial 类型的主键,则会自动帮你创建一个 表名_小写主键名_SEQ 命名方式的序列,也可以实现主键自增的效果,你可以在建表的时候就修改 serial 生成序列的名字,也可以在建表后使用上面 alter 的SQL语句进行修改。


http://chatgpt.dhexx.cn/article/4titanJZ.shtml

相关文章

PGSQL常用操作

0. 启动pgsl数据库 pg_ctl -D /xx/pgdata start 回到顶部 1. 查看pgsl版本 pg_ctl --version 回到顶部 1. 命令行登录数据库 1 psql -U username -d dbname -h hostip -p port 回到顶部 2. 列出所有数据库 \l 回到顶部 3. 切换数据库 1 \c dbname 回到顶部 …

PL/pgSQL

1.简介 L/pgSQL是一种用于PostgreSQL数据库系统的可载入的过程语言。 可以被用来创建函数和触发器过程对SQL语言增加控制结构可以执行复杂计算继承所有用户定义类型、函数和操作符可以被定义为受服务器信任便于使用 [1]使用PL/pgSQL的优点 SQL 是一种查询语言,可…

Windows 10 安装配置连接PostgreSQL教程

Windows 10 安装配置连接PostgreSQL教程 1.1 PostgreSQL 下载1.2 配置环境变量1.3 PostgreSQL 初始化1.4 创建postgres用户1.5 启动postgresql1.6 客户端连接测试1.6.1 SQL Shell (psql)命令行连接测试1.6.2 客户端 pdAdmin 4 连接测试1.6.3 客户端Navicat Permium 连接测试 1.…

Spring原理-IOC控制反转

spring相关文章 Spring原理-IOC控制反转 Spring框架七大核心模块 Spring Beans原理–bean生命周期 一、Spring概述 1、 定义 Spring是一个轻量级Java开发框架,最早有Rod Johnson创建,目的是为了解决企业级应用开发复杂性。它是一个分层的JavaSE/Java…

依赖倒置和控制反转

依赖倒置 定义 依赖反转原则(Dependency inversion principle,DIP)是指一种特定的解耦形式,使得高层次的类不依赖于低层次的类的实现细节,依赖关系被颠倒(反转),从而使得低层次类依…

Inversion of Control (IOC)控制反转 有什么好处

要了解控制反转( Inversion of Control ), 我觉得有必要先了解软件设计的一个重要思想:依赖倒置原则(Dependency Inversion Principle )。 什么是依赖倒置原则?假设我们设计一辆汽车:先设计轮子,然后根据…

Spring学习:IOC控制反转

一、Spring概述: Spring是一个开源框架,其存在的根本使命就是简化JAVA开发。为了降低JAVA开发的复杂性,Spring采取了以下四种关键策略: 基于POJO的最轻量级和最小侵入性编程;通过依赖注入和面向接口实现松耦合&#x…

控制反转(IOC)简介

IOC是Inversion of Control的缩写,多数书籍翻译成“控制反转”,还有些书籍翻译成为“控制反向”或者“控制倒置”。 1996年,Michael Mattson在一篇有关探讨面向对象框架的文章中,首先提出了IOC 这个概念。对于面向对象设计及编程…

IoC 控制反转理解

控制反转——Inversion of Control,缩写为IoC ,是一个重要的面向对象编程的法则,说到底它是一种设计思想,其可以降低程序中的耦合度,在以前,我们通过new进行创建对象,这是程序主动去创建依赖对象…

IOC控制反转理解

1. IOC基础 IOC:全称Inversion Of Control,中文翻译是控制反转的意思。初学Spring绕不过去的一个弯,需要好好理解IOC的思想。网上看了很多博客,也看了很多网课,但是还是云里云雾。终于看到一个容易理解的例子&#xf…

C# IoC控制反转学习笔记

一、什么是IOC IoC-Invertion of Control,即控制反转,是一种程序设计思想。 先初步了解几个概念: 依赖(Dependency):就是有联系,表示一个类依赖于另一个类。 依赖倒置原则(DIP&a…

spring -- 控制反转IOC

1.IOC的理论背景 在面向对象设计的软件系统中,它的底层都是由N个对象构成的,各个对象之间通过相互合作,最终实现系统地业务逻辑。 图1 软件系统中耦合的对象 齿轮组中齿轮之间的啮合关系,与软件系统中对象之间的耦合关系非常相似。对象之间…

Java:控制反转

Java中自带的函数或对象都是编写软件的时候写的,当它需要调用你自己编写的数据的时候,它如何又不知道你定义的类(对象)是什么,里面有什么成员,它无法调用你的代码,这个时候就需要用到控制反转了…

IoC控制反转

IoC控制反转 一、IoC概念和原理1. 什么是IoC2. IoC底层原理 二、IoC过程1. xml配置文件,配置创建的对象2. 有UserService和UserDao类,创建工厂类 三、IoC接口1. IoC思想基于IoC容器完成,IoC容器底层就是Bean工厂2. Spring提供实现IoC容器的两…

IOC 控制反转

文章目录 一.IOC概念二. IOC的体现三.ioc的技术实现三.基于XML的DI1.引用类型属性自动注入 四.包含关系的配置文件五.基于注解的DI五.简单类型的属性赋值1.vaule(简单类型的属性赋值)2.自动注入 一.IOC概念 IOC:控制反转,是一个理论&#xf…

浅谈控制反转(IoC)

Inversion of Control 什么是控制反转? 程序的流程控制权相对于传统的面向过程编程而言发生了反转。下面是维基百科的描述 In software engineering, inversion of control (IoC) is a programming principle. IoC inverts the flow of control as compared to tr…

Spring---浅谈IOC

概念 IOC(Inversion of Control 控制反转)是spring的核心,贯穿始终。所谓IOC,对于spring框架来说,就是由spring来负责控制对象的生命周期和对象间的关系。 传统开发模式与IOC开发模式的对比 传统开发模式:对…

控制反转-Inversion Of Control

一、控制反转 控制反转(Inversion of Control,英文缩写为IoC)把创建对象的权利交给框架,是框架的重要特征,并非面向对象编程的专业术语。它包括依赖注入(Dependency Injection,简称DI&#xff…

微信小程序hamburgers汉堡包css动画

微信小程序hamburgers汉堡包css动画 源码在我的csdn里下载 https://download.csdn.net/download/ozhy111/12201373

汉堡式折叠html,美味的CSS动画汉堡包:hamburgers_html/css_WEB-ITnose

s if you insist, but they’re not accessible as a menu button. Append the class name of the type of hamburger you’re craving: Here’s the list of hamburger-type classes you can choose from: hamburger--arrowhamburger--arrow-rhamburger--arrowalthamburger--a…