postgrestools 1.1.6
PostgresTools:VS Code的PostgreSQL扩展,提升开发效率
PostgresTools扩展为Visual Studio Code带来了强大的PostgreSQL功能,包括内联建议、语法检查和类型检查,极大地提升了开发者的工作效率。
什么是LSP?
LSP(Language Server Protocol)是由微软定义的协议,旨在跨多个编辑器标准化语言功能。如果您使用现代IDE并使用过自动完成或语法检查功能,您已经在使用LSP了。LSP服务器在后台分析您打开的文件,客户端则向服务器发送请求,如自动完成或代码操作。
设置LSP服务器
首先,您需要LSP服务器的二进制文件。Postgres语言服务器使用Rust编写,因此为不同机器编译了不同的二进制文件。您可以通过以下五种策略之一进行设置,扩展将按以下顺序检查:
- postgrestools.bin VSCode设置可以指向具有相对或绝对路径的二进制文件。如果您想从Postgres语言服务器发布中下载特定二进制文件并将其放置在您的项目中,可以使用此方法。
- 推荐:如果您使用Node.js,可以简单地运行npm i -D @postgrestools/postgrestools。重新启动扩展后,它将在您的node_modules中查找服务器二进制文件。
- 如果您使用Node.js但通过Yarn Plug'n'Play安装包,您仍然可以安装@postgrestools/postgrestools,扩展将检查您的.pnp.cjs文件以查找二进制文件。
- 您可以全局安装LSP服务器(例如通过brew或从GitHub发布中下载二进制文件)。确保其二进制文件在您的$PATH中暴露 - 扩展将在Darwin/Linux上搜索postgrestools,在Windows上搜索postgrestools.exe。
- 如果通过上述策略找不到LSP服务器二进制文件,并且您的存储库根目录没有package.json文件,您将被提示从postgrestools的GitHub发布中下载二进制文件。您也可以稍后通过下载服务器命令来执行此操作。请注意,上述策略仍将优先。
找到的二进制文件将被复制到您的VS Code扩展文件夹中的临时位置,并从那里运行。当您重新启动扩展时,将使用复制的二进制文件,并且不会搜索上述位置。
设置您的项目
其次,您需要在存储库根目录创建一个postgrestools.jsonc文件(或者,使用自定义文件位置并通过postgrestools.configFile设置指向它)。您可以在文档中找到合理的默认值。
当您指定db部分时,LSP服务器将连接到您的数据库并从中收集信息。这使得提供自动完成和类型检查成为可能。
另一方面,如果您省略该部分,这些功能将不会启用,您将仅获得语法检查。
验证其工作
要验证服务器是否已正确安装并运行,您可以使用“获取当前版本”命令,该命令列在有用命令中。
要验证客户端是否按预期工作,请打开一个.sql文件并编写一些乱码 - 您应该会看到来自pg(syntax)的红色波浪线。
与Supabase一起工作
Postgres语言服务器并非专门为与Supabase一起工作而定制 - 它适用于任何Postgres数据库。
如果您确实使用Supabase,可以通过在本地Supabase数据库上使用它来充分利用LSP(这是如何安装Supabase CLI的)。
一旦您在本地运行所有内容,运行supabase status以查看您的本地DB URL。
它的格式如下:postgresql://
如果您提取这些值,将它们添加到您的postgrestools.jsonc文件中,并重新启动扩展,您应该准备就绪。
您也可以在远程数据库上运行LSP服务器,但这可能会导致小的延迟和小的性能开销(LSP服务器针对您的数据库运行准备语句以进行类型检查)。
您可以在https://supabase.com/dashboard/project/
有用命令
扩展为您的VS Code命令面板添加了六个命令。它们都以PostgresTools为前缀。
- PostgresTools: Hard Reset(删除所有临时和全局二进制文件)是您的故障排除武器。它将基本删除所有由扩展复制和下载的二进制文件(不是您自己安装或复制的那些)。然后,扩展将再次通过设置中提到的策略搜索服务器二进制文件。
- PostgresTools: Download Server让您选择并下载服务器二进制文件。它将是与您的机器匹配的版本。如果您在您的VS Code设置中将postgrestools.allowDownloadPrereleases设置为true,您将能够选择预发布版本。
- PostgresTools: Get Current Version将在LSP服务器运行时打印当前版本。
- PostgresTools: Start和PostgresTools: Stop将停止或启动LSP服务器和客户端。
- PostgresTools: Restart连续运行stop和start。
故障排除
- 首先,尝试通过上述提到的PostgresTools: Hard Reset(...)命令重新启动扩展。
- 打开您的VS Code终端,选择输出选项卡,并在右侧选择postgrestools扩展之一。您可能会在日志中看到出了什么问题。
问题
如果您遇到任何问题,请在postgres语言服务器存储库中报告 - 我们最常阅读那里的问题。
-
- Golang云原生架构师课程
- Go是一门并发支持、垃圾回收的编译型系统编程语言;本课程转载自哔哩哔哩:https://www.bilibili.com/video/BV1Mh411M7A
- 204次学习
-
- MySQL数据管理之备份恢复案例解析视频教程
- 《MySQL数据管理之备份恢复案例解析视频教程》MySQL是一个开放源码的小型关联式数据库管理系统,目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。
- 160次学习
-
- MySQL索引优化解决方案
- 本套课程是根据MySQL索引的设计理念与数据结构、索引使用场景、索引分类、索引运用场景、索引性能分析、查询优化、MySQL索引的慢查询等组成,主要讲述了MySQL索引优化的解决方案,非常适合有MySQL使用基础或者有一定工作经验的同学。课程讲解了解决大数量查询慢的问题、如何编写一个高效的SQL、查询语句应该如何优化、索引的实现原理是什么、索引又应该如何优化...等诸多SQL索引优化的难点和面试点。
- 182次学习
-
- 极客学院Docker视频教程
- Docker是PaaS提供商dotCloud开源的一个基于LXC的高级容器引擎,源代码托管在Github上,基于go语言并遵从Apache2.0协议开源。Docker自2013年以来非常火热,无论是从github上的代码活跃度,还是各大厂商的支持,都使Docker成为了时下最受关注的技术,甚至微软都声称在下一代WindowsServer中集成对Docker的支持。所以我们收集了《极客学院Docke
- 243次学习
-
- Golang进阶实战编程
- 本课程是在《Go语言基础视频》基础之上录制的,是Go语言基础的后半部分。包括包的管理,IO操作,Go语言最大的亮点:高并发,goroutine,channel,反射等。本视频主要为了帮助Go语言的初学者,从零到一的快速入门。学完本套课程,可以学会如果通过包管理Go项目,并发模型,以及并发实现,channel通道如何传递数据,反射等等。
- 127次学习
-
- JavaScript极速入门
- 本套课程将帮助大家迅速掌握JavaScript这门高端的、动态的、弱类型编程语言。知识点简单明了,让你学习0压力,适合新手观看学习......
- 431次学习
-
- Golangmap实践及实现原理解析
- 2022-12-28 505浏览
-
- GoLand调式动态执行代码
- 2023-01-13 502浏览
-
- 试了下Golang实现try catch的方法
- 2022-12-27 502浏览
-
- 用Nginx反向代理部署go写的网站。
- 2023-01-17 502浏览
-
- MySQL主从切换的超详细步骤
- 2023-01-01 501浏览
-
- Mysql-普通索引的 change buffer
- 2023-01-25 501浏览