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函数。

参考

相关推荐
a程序小傲1 小时前
京东Java面试被问:动态规划的状态压缩和优化技巧
java·开发语言·mysql·算法·adb·postgresql·深度优先
牛奔6 小时前
Go语言中结构体转Map优雅实现
开发语言·后端·macos·golang·xcode
依旧风轻9 小时前
NSTimer的运行机制
macos·objective-c·cocoa·nstimer
技术不打烊14 小时前
从 MySQL 到 PG,你需要跨越的几道语法“鸿沟”
数据库·mysql·postgresql
恋猫de小郭14 小时前
Compose Multiplatform 1.10 Interop views 新特性:Overlay 和 Autosizing
android·flutter·macos·kotlin·github·objective-c·cocoa
IvorySQL15 小时前
拆解 PostgreSQL 连接机制:从进程模型到通信协议
数据库·postgresql
加油_Yeah16 小时前
Mac 科研/论文专用快捷键(Word + LaTeX + Finder) 与文件管理
macos·编辑器·word
ZhangBlossom16 小时前
Freqtrade 新人上手教程(macOS + Docker,无需 docker-compose)
macos·docker·容器
古城小栈16 小时前
Rust 交叉编译:MacOS ====> Linux (musl 静态编译)
linux·macos·rust
2501_9159214316 小时前
360移动端性能监控实践QDAS-APM(iOS篇)
android·macos·ios·小程序·uni-app·cocoa·iphone