首页 web前端 js教程 如何使用Hasura和PostgreSQL建立后端

如何使用Hasura和PostgreSQL建立后端

Feb 09, 2025 am 09:22 AM

How to Build Your Backend with Hasura and PostgreSQL

建立强大的后端通常涉及对CRUD操作,授权和业务逻辑的广泛编码,这是一个耗时的过程。 本文探讨了Hasura和PostgreSQL流线后端开发如何以最少的编码工作启动更快的应用程序。

> Hasura,一种开源GraphQl引擎,会自动从数据库架构中生成GraphQL和REST API。 它支持数据建模,实时查询,事件编程,基于角色的授权以及通过GraphQl Action的自定义业务逻辑执行。

强大的开源关系数据库

> PostgreSQL提供与Oracle和Microsoft SQL Server相当的企业级功能,这使其成为大型应用程序的可靠选择。 Netflix和Spotify等公司的使用强调了其功能。尽管Hasura支持其他数据库,但由于其可访问性和开源性质,本文侧重于PostgreSQL。 MySQL支持是计划的。

本指南重点介绍了Hasura为Web和移动应用程序构建可扩展后端的功能。 它还展示了通过SQL访问的PostgreSQL的功能如何执行复杂的计算和分析,从而减少了自定义服务器端代码的需求。

>

键优点:

  • 快速的后端开发: hasura的自动生成的API大大减少了编码时间。
  • PostgreSQL功率:利用PostgreSQL的高级功能(表继承,并发控制,JSON/空间数据类型),以增强数据完整性和性能。
  • 实时功能: Hasura的实时查询,事件编程和基于角色的授权创建高度响应的应用程序。 >
  • >易于部署:
  • >使用Docker进行本地开发或Hasura Cloud的部署,用于可扩展,安全,全球分布式应用程序,具有监视和缓存等功能。>
  • 全面的Web控制台:
  • 在Hasura的直觉Web控制台中管理数据建模,CRUD操作和复杂的查询。 与身份验证和文件存储提供商集成。
  • >简化的工作流程:
  • 利用Hasura的迁移工具和环境分期进行开发与生产之间的无缝过渡,支持CI/CD。
  • 为什么选择postgresql?

> PostgreSQL(例如PostgreSQL)等关系数据库提供的优势比其他数据库类型(包括模式建模,加入操作和酸性交易)具有优势,这对数据完整性至关重要。 PostgreSQL进一步擅长:

  • 表继承:有效的数据建模。
  • >
  • 高级并发控制:处理高量数据在多用户环境中有效写入。
  • 容忍和数据完整性:降低数据损坏风险。
  • >
  • 唯一的数据类型:支持JSON和空间数据类型,对各种应用程序有益。
  • > PostgreSQL还充当计算服务器,执行自定义功能和用于分析任务的触发器,从而消除了对单独的服务器端代码的需求。 这是使用以下方式实现的:

    >视图:
  • 简化复杂的查询。>
  • 函数和运算符:
  • >执行日期格式格式,模式匹配和算术操作。
  • >扩展:
  • 扩展了PostgreSQL的功能(例如,PostGis)。>
  • 程序语言:
  • 写入用户定义的功能和存储过程(例如,PL/PGSQL)。 hasura通过GraphQl公开了此PostgreSQL逻辑,使其很容易访问前端应用程序。

> postgresql示例:

How to Build Your Backend with Hasura and PostgreSQL

>>示例1(在线用户查看):>检索当前活动用户的视图:

  • >
  • >示例2(带有postgis的地理位置):
>在1000米半径内查找商店:
CREATE OR REPLACE VIEW "public"."online_users" AS
 SELECT users.id, users.last_seen
   FROM users
  WHERE (users.last_seen >= (now() - '00:00:30'::interval));
登录后复制
  • 什么是hasura?
Hasura是一种开源的实时GraphQl引擎,为您的数据库生成API。它的Web控制台允许:
SELECT id, name, address, geom
FROM Seattle_Starbucks
WHERE ST_DWithin(geom, ST_MakePoint(-122.325959,47.625138)::geography, 1000);
登录后复制

模型建模:

创建表格,定义关系并管理数据。

    crud操作:
  • 执行创建,读取,更新和删除操作。> 基于角色的访问控制:>
  • graphql/ret ensentpoint创建:为您的数据生成API。
  • sql execution:运行自定义SQL查询。
  • 操作和触发定义:自动化任务并处理事件。
  • 注意:Hasura需要与单独的身份验证提供商(例如Auth0,Firebase)和文件存储服务集成。 NHOST提供了一个集成的解决方案。
  • >启动hasura:>
    • > docker:建议用于本地开发,提供简单的设置和无速率限制。
    • >
    • > hasura cloud:用可扩展性,安全性和全局分布(包括监视和缓存功能)简化了部署。 有限制的免费层。

    How to Build Your Backend with Hasura and PostgreSQL

    > hasura功能(详细概述):>

    • 数据管理器: Visual模式设计器,用于创建表,定义关系和管理数据类型(包括JSON和自定义类型)。 How to Build Your Backend with Hasura and PostgreSQL
    • 授权:
    • 基于角色的访问控制,具有插入,选择,更新和删除操作的粒状权限。 How to Build Your Backend with Hasura and PostgreSQL
    • 查询:
    • 直接在控制台内执行各种GraphQl查询(简单,嵌套,聚合,过滤)。 How to Build Your Backend with Hasura and PostgreSQL
    • 突变:
    • 执行插入,UPSERT,更新和删除操作,并支持交易。
    • 订阅:
    • >使用WebSockets上的GraphQL订阅实现实时数据更新。
    • 远程模式:
    • 与数据和逻辑的第三方API集成 动作:
    • 使用任何编程语言通过Webhooks执行自定义业务逻辑。
    • 基于数据库事件(插入,更新,删除),>事件触发器:调用Webhooks。 支持手动调用。
    • 计划的触发器:通过webhooks定期运行任务(CRON)或一次(一次性)。
    • 迁移和环境:How to Build Your Backend with Hasura and PostgreSQL 使用数据库和hasura元数据的迁移文件管理模式更改,支持CI/CD Workflows。
    • >部署选项:

    > hasura云:最简单的生产部署。

    >
      >
    • 外部托管: Heroku,数字海洋,渲染,Azure,Kubernetes,AWS(更复杂)。 > nhost:全in-Baas解决方案,包括PostgreSQL,Hasura,Authentication和Storage。
    • >
    • 摘要:
    • Hasura和PostgreSQL为快速后端开发提供了强大的组合。 减少的编码工作,实时功能和鲁棒功能使其成为构建可扩展和可维护应用程序的引人注目的解决方案。 虽然在各个方面都不像某些替代方案那样丰富,但其易用性,专注于性能和开源性质是显着的优势。

      >

      常见问题(常见问题解答):(提供的常见问题解答已经全面且写得很好;不需要修改。)

以上是如何使用Hasura和PostgreSQL建立后端的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

前端热敏纸小票打印遇到乱码问题怎么办? 前端热敏纸小票打印遇到乱码问题怎么办? Apr 04, 2025 pm 02:42 PM

前端热敏纸小票打印的常见问题与解决方案在前端开发中,小票打印是一个常见的需求。然而,很多开发者在实...

神秘的JavaScript:它的作用以及为什么重要 神秘的JavaScript:它的作用以及为什么重要 Apr 09, 2025 am 12:07 AM

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

谁得到更多的Python或JavaScript? 谁得到更多的Python或JavaScript? Apr 04, 2025 am 12:09 AM

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

如何实现视差滚动和元素动画效果,像资生堂官网那样?
或者:
怎样才能像资生堂官网一样,实现页面滚动伴随的动画效果? 如何实现视差滚动和元素动画效果,像资生堂官网那样? 或者: 怎样才能像资生堂官网一样,实现页面滚动伴随的动画效果? Apr 04, 2025 pm 05:36 PM

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的演变:当前的趋势和未来前景 JavaScript的演变:当前的趋势和未来前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

JavaScript难以学习吗? JavaScript难以学习吗? Apr 03, 2025 am 12:20 AM

学习JavaScript不难,但有挑战。1)理解基础概念如变量、数据类型、函数等。2)掌握异步编程,通过事件循环实现。3)使用DOM操作和Promise处理异步请求。4)避免常见错误,使用调试技巧。5)优化性能,遵循最佳实践。

如何使用JavaScript将具有相同ID的数组元素合并到一个对象中? 如何使用JavaScript将具有相同ID的数组元素合并到一个对象中? Apr 04, 2025 pm 05:09 PM

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

前端开发中如何实现类似 VSCode 的面板拖拽调整功能? 前端开发中如何实现类似 VSCode 的面板拖拽调整功能? Apr 04, 2025 pm 02:06 PM

探索前端中类似VSCode的面板拖拽调整功能的实现在前端开发中,如何实现类似于VSCode...

See all articles