前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PostgreSQL 是不是大小写敏感

PostgreSQL 是不是大小写敏感

原创
作者头像
HoneyMoose
发布2024-01-20 11:46:44
1800
发布2024-01-20 11:46:44
举报
文章被收录于专栏:CWIKIUSCWIKIUS

如果你踩过 MySQL 的大坑的话就知道:MySQL 在 Windows 下不区分大小写,但在 Linux 下默认是区分大小写。

如果你稍加不注意就会出现在本机开发的程序运行一切正常,发布到服务器行就出现表名找不到的问题。

这是我们前一个项目遇到的巨大问题,开发是在 Windows 下进行,但是部署是在 Linux 下进行。

例如一个表:tableName 和 tablename,这 2 个表在 Windows 下是一样的,但在 Linux 下就不一样了。

所以我们的程序在 Windows 下查询表 tableName 没有问题,但是如果 Linux 下数据库的表名为 tableName 的话,那么查询就找不到表了。

有过上面经历的话,我们来看看 PostgreSQL

PostgreSQL 是大小写敏感的

在默认情况,PostgreSQL 在存储和比较数据值的时候字符串的值如果是大小写的处理方式是不一样的。

例如: “isharkfly” 和 “iSharkFly” 是不同的值,这个在 PostgreSQL 会影响存储的。

创建表的 SQL

如果我们有一个创建表的 SQL:

代码语言:javascript
复制
create table test.Table_name
(
    id        integer,
    user_name varchar
);

代码语言:javascript
复制
create table test.table_name
(
    id        integer,
    user_name varchar
);

注意到,上面的 T 是大写的,如果运行上面的 SQL,在数据库上,我们会看到表的名字被转换成小写了。

2024-01-19_22-35-42
2024-01-19_22-35-42

如果我们想在数据库中创建一个 Table_name 可以吗?

答案是可以的。

需要把 Table_name 放在双引号里面。

运行的 SQL 就成这样了。

代码语言:javascript
复制
create table test."Table_name"
(
    id        integer,
    user_name varchar
);
2024-01-19_22-37-31
2024-01-19_22-37-31

结论

为了避免我们在 MySQL 上遇到的大小写问题和平台问题。

在设计数据库表的时候,不要使用大小写混合模式,要么就全部约定为小写,要不就全部约定为大写。

因为 PostgreSQL 会默认全部使用小写,所以在 PostgreSQL 的表面和字段名要全部为小写为好。

Oracle 数据库在这里是另类,在 Oracle 中全部按照大写存储的。

https://www.isharkfly.com/t/postgresql/15350

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • PostgreSQL 是大小写敏感的
    • 创建表的 SQL
    • 结论
    相关产品与服务
    云数据库 MySQL
    腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档