PostgreSQL16安装Mac(brew)

问题

最近需要从MySQL切换到PostgreSQL。我得在本地准备一个PostgreSQL。

步骤

使用brew安装postgresql16:

bash 复制代码
arch -arm64 brew install postgresql@16

启动postgresql16:

bash 复制代码
brew services start postgresql@16

配置postgresql环境变量,打开环境变量文件:

bash 复制代码
open ~/.zshrc

配置如下内容:

bash 复制代码
export PG_HOME=/opt/homebrew/opt/postgresql@16
export PATH=$PG_HOME/bin:$PATH

重载环境变量:

bash 复制代码
source ~/.zshrc

查看postgresql版本:

bash 复制代码
psql --version

查询数据库管理员用户名:

bash 复制代码
id -un

登录数据库:

bash 复制代码
psql -U <管理用户名> postgres

修改管理用户密码:

sql 复制代码
ALTER USER <管理用户名> PASSWORD '<密码>';

使用\q退出psql客户端。查看登录设置配置文件:

bash 复制代码
sudo -u <管理员用户名> psql postgres -c "SHOW hba_file;"

结果:

bash 复制代码
                  hba_file
---------------------------------------------
 /opt/homebrew/var/postgresql@16/pg_hba.conf
(1 行记录)

打开pg_hba.conf文件,设置需要使用密码方式登录postgresql,将trust改成scram-sha-256,如下图:

注意,这里的trust是不需要验证用户就可以直接使用;passwords是明文传用户密码给postgresql服务器;md5scram-sha-256密码加密给postgresql服务器进行登录。

重启服务:

bash 复制代码
brew services restart postgresql@16

再次验证使用登录:

bash 复制代码
psql -U <管理员用户> postgres

总结

postgresql还是很简单的,只要需要注意postgresql默认表名和字段名是小写的,默认也不支持反引号(`)。需要注意下与mysql区别的这些注意点。还有就是写sql使用函数的时候,尽可能使用大家这几个数据库都支持的sql函数。

参考

相关推荐
Sephiroth.Ma2 小时前
Mac 提示“Docker 已损坏,无法打开”?我这样排查后 10 分钟修好
macos·docker·容器
量子炒饭大师2 小时前
【OpenClaw修炼宝典】—— 【macOS安装篇】想玩《爪子船长》复刻版却卡在安装?OpenClaw 从零环境搭建与编译全攻略 (小白避坑指南)
macos·openclaw·小龙虾·龙虾
tongxh4232 小时前
5、使用 pgAdmin4 图形化创建和管理 PostgreSQL 数据库
数据库·postgresql
不才小强3 小时前
macOS 屏幕录制开发完全指南:ScreenCaptureKit与音频采集实战
macos·音视频
ShiLuoHeroKing12 小时前
Mole:面向专业用户的Mac系统清理开源方案
macos
F1FJJ1 天前
Shield CLI 的 PostgreSQL 插件 v0.5.0 发布:数据库导出 + 协作增强,ER 图全新体验
网络·数据库·docker·postgresql·go
数据库小组1 天前
Oracle 上云 / 替代场景下,NineData 完成到 PostgreSQL 的低风险迁移
大数据·数据库·mysql·postgresql·oracle·数据一致性·数据库迁移
The森1 天前
macOS 26(M芯片)部署 cocos2d-x(C++)全链路指南——Xcode + Rosetta
c++·经验分享·笔记·macos·xcode·cocos2d
念念不忘 必有回响1 天前
Drizzle ORM上手指南:在Next.js中优雅地操作PostgreSQL
开发语言·postgresql·nodejs·nextjs·drizzle
GISBox1 天前
PostGIS数据通过GISBox发布WFS/WMS全攻略
数据库·postgresql·wms·gis·postgis·矢量·gisbox