在本文中,我们将深入研究数据库管理工具的内部工作原理,探索为其提供支持的架构和技术。了解应用程序在幕后的功能将使您深入了解其设计、它如何管理数据库、表以及 api 如何与数据交互。
我们将讨论所使用的核心技术,包括作为主数据库的 InterSystems IRIS 和用于缓存的 redis。此外,我们将分解所使用的表的结构,并解释系统如何通过 REST API 处理数据创建、检索和操作。
Web 应用程序概述
此应用程序是一个基于 Web 的工具,由两个主要组件组成:后端和前端。
- 后端:后端是使用Java和spring Boot框架开发的。 spring boot 简化了开发过程,提供了强大且可扩展的结构来处理服务器端逻辑。为了管理与数据库的连接,我使用了 Spring Data,它与 InterSystems IRIS(用于主数据库)和 Redis(用于缓存 JWT)无缝集成。此设置通过处理与数据访问和存储相关的大部分样板代码,使编程变得更容易。
- 前端:前端是使用 angular 17 构建的,它提供了一个动态且响应式的用户界面,用于管理数据库、表以及与数据交互。 Angular 基于组件的架构可确保 ui 随着应用程序的增长而保持可维护性和可扩展性。
数据库结构和工作流程
主InterSystems IRIS数据库包含四个关键表,用于存储有关用户、其数据库以及他们创建的表的重要信息。其工作原理如下:
- Users 表(users):当新用户注册时,他们的信息会保存在 users 表中。该表跟踪所有注册用户,确保每个用户都有唯一的标识符来管理其资源。
- 数据库表(dbs):当用户创建新数据库时,数据库的详细信息(例如数据库名称)存储在 dbs 表中。这允许应用程序跟踪哪个用户拥有哪个数据库。
- 数据库令牌表(db_tokens):对于每个新数据库,都会生成一个唯一的令牌。此令牌用于验证对该特定数据库的 API 请求。令牌的生命周期(可以是一天、一周、一个月或一年)存储在 db_tokens 表中,确保随着时间的推移,对数据库的访问得到安全管理。
- Tables 表(tables):当用户在数据库中创建新表时,表的名称与关联的数据库 ID 一起保存在tables表中。这确保每个表都链接到正确的数据库。
除了存储表的元数据之外,系统还会在 InterSystems IRIS 中为实际用户数据创建一个新的 sql 表。每个 SQL 表均使用技术命名约定进行命名,前缀为 table_,后跟表的 ID 作为后缀。此 SQL 表将存储该特定表的用户数据。
Redis 数据库
Redis 数据库通过管理用户身份验证在应用程序中扮演简单的角色。当用户登录网站时,会生成他们的 JWT 令牌(json Web 令牌)以进行安全会话管理。然后,这些令牌将存储在 Redis 中,以便快速访问和验证。
Redis 充当内存缓存,确保用户身份验证快速高效。当用户向后端发出请求时,应用程序会检查存储的令牌的有效性,以确认用户的身份并授予对适当资源的访问权限。
表操作API
正如第一篇文章中提到的,为了与用户表中存储的数据进行交互,应用程序提供了一个简单但功能强大的 REST API。目前,该API支持五种基本操作,允许用户高效管理数据:
- 按条件获取所有记录:根据特定条件或过滤器从表中检索记录。
- 获取所有记录:从表中获取所有记录,不使用任何过滤器。
- 保存:将新记录添加到表中。
- 更新:修改表中的现有记录。
- 删除:从表中删除记录。
这些API端点可以轻松地对表数据执行CRUD(创建、读取、更新、删除)操作。未来,API 将扩展支持自定义查询,让用户更灵活地直接通过 API 执行复杂的数据操作。
结论
在本文中,我们探讨了数据库管理工具的内部工作原理,分解了后端和前端技术,并解释了 InterSystems IRIS 和 Redis 数据库如何在系统中运行。我们还研究了如何通过 API 管理数据,目前支持基本的 CRUD 操作。
虽然该应用程序已经提供了一组强大的功能来管理数据库、表和记录,但还有更多功能即将推出。未来的更新将引入对自定义查询和其他高级功能的支持,使该工具对于希望无缝管理数据的用户来说更加通用。