首页
学习
活动
专区
圈层
工具
发布

使用NestJs、GraphQL、TypeORM搭建后端服务

在我们过去常用的RestFul API中,我们可能在不同的业务中需要调用同一个接口,但是各自所需的数据有不同的情况下,服务端为了同时满足两个需求则提供了更多的字段,这样导致了一个两个业务请求到的数据都包含了自己不需要的字段...后端开发同学应该都知道ORM的全称是对象关系映射(Object Relational Mapping,简称ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据库中...通过他我们可以定义一些Entity(实体),每个实体的数据字段,每个字段包含了数据类型,甚至是数据关系(一对多、多对多、多对一)。这些实体将映射到真实数据库中,创建真正的数据表。...而数据字段和关系也就生成对应的数据库表字段以及表字段与表字段的关系。...image.png 3.2、改造app.module.ts 从@nestjs/typeorm中引入NestJs与TypeORM连接模块*TypeOrmModule,然后传入一个Object作为与数据库链接的

7.7K10

基于 Nest.js+TypeORM 实战,项目已开源,推荐!

数据表关系 前面文章中已经说了TypeORM建表时,是通过@Entity()装饰的class 映射为数据表, 所以实体中的关系也就是表关系。...我们在TypeORM中如何实现user表和info之间这种对一对的关系呢?...@JoinColumn 必须在且只在关系的一侧的外键上, 你设置@JoinColumn的哪一方,哪一方的表将包含一个relation id和目标实体表的外键。记住,不能同时在二者entity中。...一对多 在一对多关系中,表A中的一条记录,可以关联表B中的一条或多条记录。比如:每一个文章分类都可以对应多篇文章,反过来一篇文章只能属于一个分类,这种文章表和分类表的关系就是一对多的关系。...多对多 在多对多关系中, 表A的中的记录可能与表B中一个或多个的记录相关联。例如,文章和标签你之间存在多对多的关系:一篇文章可以有多个标签, 一个标签页可以对应多篇文章。

12.5K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    精读《Prisma 的使用》

    在模型定义中,可以通过 @map 修改字段名映射、@@map 修改表名映射,默认情况下,字段名与 key 名相同: model Comment { title @map("comment_title...字段类型。 可选的类型修饰。 可选的属性描述。 model Tag { name String? @id } 在这个描述里,包含字段名 name、字段类型 String、类型修饰 ?...ORM 容易引发性能问题 当数据量大,或者性能、资源敏感的情况下,我们需要对 SQL 进行优化,甚至我们需要对特定的 Mysql 的特定版本的某些内核错误,对 SQL 进行某些看似无意义的申明调优(比如在...的方式访问某些属性,但这背后生成的却是一系列未经优化(或者部分自动优化)的复杂 join sql,我们在写这些 sql 时会提前考虑性能因素,但通过对象调用时却因为成本低,或觉得 ORM 有 magic...Prisma Schema 的好处 其实从语法上,Prisma Schema 与 Typeorm 基于 Class + 装饰器的拓展几乎可以等价转换,但 Prisma Schema 在实际使用中有一个很不错的优势

    4.5K30

    有了 Prisma,就别用 TypeORM 了

    文档&生态​ 从文档的细致程度上 Prisma 比 TypeORM 要清晰详尽。...findOne(undefined) 所查询到的却是第一条记录​ 首先 TypeORM 有个天坑,你可以在 这个 Issue 中查看详情或查看 这篇文章 是如何破解使用 TypeORM 的 Node.js...我举几个例子: 在 TypeORM 中,你需要 select 选择某个实体的几个字段,你可以这么写 你会发现 post 对象的类型提示依旧还是 postEntity,没有任何变化。...这无疑会诱发一些潜在 bug,我就多次因为要 select 某表中的某个字段,而因为拼写错误导致查询失败。...合理来说,Prisma 并不是一个传统的 ORM,它的工作原理并不是将表映射到编程语言中的模型类,为处理关系数据库提供了一种面向对象的方式。而是在 Prisma Schema 中定义模型。

    5.5K22

    NestJS、TypeORM 和 PostgreSQL 项目开发和数据库迁移完整示例(译)

    它可以从环境变量中读取配置,然后在运行时以只读方式提供值。为了使 dev 和 prod 灵活,我们将使用 dotenv 模块。...我们将在服务中包含一个容错模式。这意味着如果获取一个不存在的值,它将抛出含义完整的错误。这使您的设置更加健壮,因为您将在构建 / 启动时检测配置错误,而不是在运行时生命周期。...(见实体的 TypeOrmModuleOptions 中的 ConfigService) TypeORM 的另一个特性是这些实体模型支持继承。 例如,如果您希望每个实体都拥有某些数据字段。...因此,您在代码中更改了实体类, typeORM 会为你自动同步字段, 但是,一旦您的数据库中有实际数据,后期打算修改字段类型或其他操作时,TypeORM 将通过删除并重新创建数据库表来更改数据库,这意味着你极有可能丢失了表内的数据...然而,在生产或阶段环境中,您实际上经常希望在部署之后 / 之后启动 API 服务器之前自动运行迁移脚本。 为此,您只需添加一个 start.sh 脚本即可。

    7.7K21

    NestJS、TypeORM 和 PostgreSQL 项目开发和数据库迁移完整示例(译)

    它可以从环境变量中读取配置,然后在运行时以只读方式提供值。为了使 dev 和 prod 灵活,我们将使用 dotenv 模块。...我们将在服务中包含一个容错模式。这意味着如果获取一个不存在的值,它将抛出含义完整的错误。这使您的设置更加健壮,因为您将在构建 / 启动时检测配置错误,而不是在运行时生命周期。...(见实体的 TypeOrmModuleOptions 中的 ConfigService) TypeORM 的另一个特性是这些实体模型支持继承。 例如,如果您希望每个实体都拥有某些数据字段。...因此,您在代码中更改了实体类, typeORM 会为你自动同步字段, 但是,一旦您的数据库中有实际数据,后期打算修改字段类型或其他操作时,TypeORM 将通过删除并重新创建数据库表来更改数据库,这意味着你极有可能丢失了表内的数据...然而,在生产或阶段环境中,您实际上经常希望在部署之后 / 之后启动 API 服务器之前自动运行迁移脚本。 为此,您只需添加一个 start.sh 脚本即可。

    6.2K10

    NestJS、TypeORM 和 PostgreSQL 项目开发和数据库迁移完整示例(译)

    它可以从环境变量中读取配置,然后在运行时以只读方式提供值。为了使 dev 和 prod 灵活,我们将使用 dotenv 模块。...我们将在服务中包含一个容错模式。这意味着如果获取一个不存在的值,它将抛出含义完整的错误。这使您的设置更加健壮,因为您将在构建 / 启动时检测配置错误,而不是在运行时生命周期。...(见实体的 TypeOrmModuleOptions 中的 ConfigService) TypeORM 的另一个特性是这些实体模型支持继承。 例如,如果您希望每个实体都拥有某些数据字段。...因此,您在代码中更改了实体类, typeORM 会为你自动同步字段, 但是,一旦您的数据库中有实际数据,后期打算修改字段类型或其他操作时,TypeORM 将通过删除并重新创建数据库表来更改数据库,这意味着你极有可能丢失了表内的数据...然而,在生产或阶段环境中,您实际上经常希望在部署之后 / 之后启动 API 服务器之前自动运行迁移脚本。 为此,您只需添加一个 start.sh 脚本即可。

    6.5K30

    20. 精读《Nestjs》

    this.req 或 this.context 等取请求参数不同,Nestjs 通过装饰器获取请求参数: @Get('/:id') public async getUser( @Response()...3.1.1 定义实体 每个实体对应数据库的一张表,Typeorm 在每次启动都会同步表结构到数据库,我们完全不用使用数据库查看表结构,所有结构信息都定义在代码中: @Entity() export class...,但更新实体时,由于性能需要,我们一般不会一次查询所有字段,就需要指定更新时,不校验没有赋值的字段,我们通过 Typeorm 的 EventSubscriber 完成数据库操作前的代码校验,并控制新增时全字段校验...的特色之一,通过装饰器语义化解释实体之间的关系,常用的有 @OneToOne @OneToMany @ManyToOne@ManyToMany 四种,比如用户表到评论表,是一对多的关系,可以这样设置实体...在使用 Typeorm 查询 User 时,会自动外键查询到其关联的评论,保存在 user.comments 中。

    4.9K20

    Nest.js 实践总结

    例如,你可以创建一个文件夹名为 utils 来存储你的工具函数或 JSON 文件。通过将文件组织到模块文件夹中,会变得清晰,并且可以避免很多错误。...应该使用 Data Mapper/Repository 模式,而不是 Active Record 如果你正在使用 PostgreSQL 或 MySQL 等关系数据库,那么请使用 TypeOrm,它是 Typescript...数据映射器可能看起来有点冗长,但它是中 / 大型项目的更好解决方案。它也非常适合测试,因为它适用于依赖注入! 5. 应该使用相对路径,而不是绝对路径 你可以使用绝对路径或相对路径导入 es6 模块。...使用 Exclude 来隐藏不必要的数据 使用过滤器从数据库中获取的数据是很常见的。过滤器的整个目标是删除或格式化来自数据库的数据。这会导致很多垃圾逻辑,使代码变得更冗余。...如果是需要隐藏某些字段,可以使用 @Exclude () 装饰器。

    2.3K20

    Nest.js 实践总结分享

    例如,你可以创建一个文件夹名为 utils 来存储你的工具函数或 JSON 文件。通过将文件组织到模块文件夹中,会变得清晰,并且可以避免很多错误。...应该使用 Data Mapper/Repository 模式,而不是 Active Record 如果你正在使用 PostgreSQL 或 MySQL 等关系数据库,那么请使用 TypeOrm,它是 Typescript...数据映射器可能看起来有点冗长,但它是中 / 大型项目的更好解决方案。它也非常适合测试,因为它适用于依赖注入! 5. 应该使用相对路径,而不是绝对路径 你可以使用绝对路径或相对路径导入 es6 模块。...使用 Exclude 来隐藏不必要的数据 使用过滤器从数据库中获取的数据是很常见的。过滤器的整个目标是删除或格式化来自数据库的数据。这会导致很多垃圾逻辑,使代码变得更冗余。...如果是需要隐藏某些字段,可以使用 @Exclude () 装饰器。

    2.5K10

    如何开发门店业绩上报管理系统中的商品数据板块?(附架构图+流程图+代码参考)

    本文从落地可用的角度出发,讲清楚为什么要重视商品数据板块、它包含哪些内容(商品类别、商品信息、商品档案),如何设计架构、业务流程、实现细节和开发技巧,并把所有代码集中放在第12部分,方便工程化落地。...ExpressORM:TypeORM 或 Sequelize(示例采用 TypeORM)DB:PostgreSQL(支持 JSONB)缓存:Redis搜索:ElasticSearch(或 PostgreSQL...API + DB),后期拆微服务(Product Service、Search Service、Sync Service)数据迁移:先导入临时表做预检,生成老系统 ID -> 新 SKU 的映射表,人工或半自动确认后批量写入主表并生成映射关系灾备...条码(barcode)和 SKU 在实践中各有用途:条码通常由供应商或生产厂家分配,适合门店扫码使用;SKU 多由企业内部定义,承担业务唯一标识的责任。...预检阶段把上传的 CSV/Excel 解析到临时表或内存中,对每一行做字段校验(必填项、数值范围、条码格式、类目是否存在)、唯一性检测(sku/barcode)和相似度检测(名称与现有商品比对),将结果返回给前端让用户确认

    37910

    如何开发ERP(离散制造-MTO)系统中的客户管理板块(附架构图+流程图+代码参考)

    本文将给出一套可实施的客户管理模块设计(包含架构图、流程图、功能拆解、开发技巧、以及一个较大的参考代码),帮助企业快速搭建或改造适配离散制造-MTO的客户管理板块。...(电话/邮件/上门/线上会议)、内容(富文本或markdown)、结果(意向/报价中/失效)、下次跟进时间(可空)、附件列表、关联订单/报价 id。...开发技巧与实现注意点(干货)5.1 数据库与表结构(简要)使用关系型数据库(Postgres/MySQL)存客户主档和跟进记录。分析层可用 OLAP。...参考代码(较大示例:TypeScript + Express + TypeORM 后端示例)下面给出一个便于落地的后端示例,包含实体定义、主要 API、以及一个示例分析 SQL(用于计算 RFM)。...要把它用好,可以做三件事:1)把跟进记录结构化,关键字段(跟进类型、结果、下次跟进时间、意向强度)标准化,便于机器识别;2)基于结构化字段建立规则引擎,比如“跟进结果=报价中 && 下次跟进时间 <=

    39610

    如何开发门店业绩上报管理系统中的门店数据板块?(附架构图+流程图+代码参考)

    门店业绩上报管理,是把一线门店的营业数据、动销数据、人效数据等按标准化流程上报到企业中台或BI系统,用来做考核、分析和决策。...核心痛点门店分散、标准不统一:不同门店使用的口径、字段不一致(如“销售额”包含/不包含退款)。上报延迟与漏传:人工抄送导致延迟和遗漏,影响日常决策。数据校验弱:数据脏、异常无法及时发现。...data) return 加载中......需要建立一份数据字典和口径规范文档,明确每个指标的定义(例如销售额是否包含礼金卡充值、是否包含未结账行项目等)并对外发布。...技术上在上报表单内附带简短说明和示例数值,并在字段级别做校验(例如某些品类需分项上报时给予提示)。

    37610

    面试官:MySQL中能过滤到null值吗?

    test_user where hobby ' ' SELECT * from test_user where hobby 'Sports' 问题反思 想必大家看了,心里都有了答案,MySQL中的不等于会排除掉字段值为...什么场景下使用不等于 过滤掉特定值:当我们需要排除某些特定值时,例如,筛选出不是特定分类条件下的数据 比较范围之外的值:如果我们要查找某个范围之外的数据,不等于操作符可以用于排除该范围内的值。 2....使用不等于有没有什么必要条件 使用不等于操作符的必要条件取决于具体的查询需求。 如果我们需要排除特定值或比较范围之外的值,那么使用不等于操作符是有必要的。...然而,在某些情况下,可以使用其他操作符或条件语句来实现相同的效果,这取决于查询的逻辑和数据的特点。 一句话:视情况而定,没有什么是必要的。 3....因此,使用不等于操作符时,我们需要注意是否希望包含或排除 NULL值,确保查询的准确性,而这一点在数据库设计初期和编码的时候都要去看下这个字段值的范围。 4.

    69110

    狼叔直播 Reaction《学习指北:Node.js 2022 全解析》

    从 Node.js 源码更新内容来看,Node.js 正在健康平稳的发展、从可用到好用在转变,在易用性上有很大提升。性能的牌打完了,开始打“用户体验”的牌。...(如果你想优化性能,最好的办法就是升级 Node 版本 :)) 3.吐糟变多,意味着用的人变多,趋于成熟 “世界上只有两种语言,一种是没有人用的语言,一种是被抱怨的语言。”...部分代码从 trekjs[18]提取。...JavaScript 全栈⾼效研发在语雀中的实践[34] 前端 3.0 重新思考前后端的关系 BFF vs FFB 前端代码里的胶水代码太多了,本质上讲,从数据库到 API 字段,然后到前端渲染,应该是一个非常纯净的过程...: https://github.com/typeorm/typeorm [10] midway: https://github.com/midwayjs/midway [11] daruk: https

    1.2K20

    2024年Node.js精选:50款工具库集锦,项目开发轻松上手(三)

    https://www.npmjs.com/package/socket.io 22、TypeORM:打通TypeScript与数据库的桥梁 在现代Web开发中,数据库是存储和管理数据不可或缺的组成部分...TypeORM是一个为TypeScript和JavaScript设计的强大对象关系映射(ORM)库,它旨在弥合代码中的对象与关系数据库世界之间的鸿沟。...https://www.npmjs.com/package/typeorm 23、Sequelize:JavaScript与关系数据库的完美桥梁 在动态Web应用开发中,与数据库的交互是核心任务之一。...Sequelize是一个强大的对象关系映射(ORM)库,它为JavaScript对象和关系数据库之间搭建了一座桥梁。...: function getUserById(id) { // 从数据库或其他数据源获取用户数据 return { id, name: 'John Doe', email: 'johndoe@example.com

    2.2K10

    kz-admin后台管理系统

    基于NestJs + TypeScript + TypeORM + Redis + MySql + Vben Admin编写的一款前后端分离的权限管理系统 演示地址:KzAdmin 管理员账号:admin...在这三张表中关系如下(这里使用外键与数据库模型为例,实际项目并未用到外键,也不推荐使用) 用户-角色 与 角色-权限都采用的多对多的关系,即新创建一个表用于映射两表关系。...在权限管理中,最为重要的便是权限表了,由于这套后台管理系统中还涉及到前端的左侧菜单,所以将这里的 permission 表替换为 menu 表,字段 permission 表示权限值。...数据库中的 menu 表如下 对于主要字段介绍: parent:对于有父子关系的表,会创建一个 parent_id(这里为 parent)字段用于表示父节点,无则为顶级节点。...permission,然后每次请求需要鉴权的接口时,将权限标识转为接口 url,判断是否包含该 url,不包含则无访问权限。

    2.5K20
    领券