当前位置: 首页 > news >正文

网站建设流程新闻淘宝seo搜索引擎原理

网站建设流程新闻,淘宝seo搜索引擎原理,用阿里云和大淘客做网站,路由器屏蔽网站怎么做在使用 ORM(如 TypeORM)进行实体关系设计时,OneToMany 和 ManyToOne 是非常重要的注解,常用来表示两个实体之间的一对多关系。下面通过例子详细说明它们的使用场景和工作方式。 OneToMany 和 ManyToOne 的基本概念 ManyToOne 表示…

在使用 ORM(如 TypeORM)进行实体关系设计时,@OneToMany@ManyToOne 是非常重要的注解,常用来表示两个实体之间的一对多关系。下面通过例子详细说明它们的使用场景和工作方式。


@OneToMany@ManyToOne 的基本概念

  1. @ManyToOne
    表示 “多” 的一方指向 “一” 的一方。它总是定义在关系的 “多” 一侧。

    • 数据库中通常对应一个外键列。
    • 该装饰器是关系的拥有方,负责维护外键。
  2. @OneToMany
    表示 “一” 的一方指向 “多” 的一方。它总是定义在关系的 “一” 一侧。

    • 数据库中没有直接对应的列,而是反向映射。
    • 必须与 @ManyToOne 配合使用,不能单独存在。

示例:用户与文章的关系

场景:

  • 一个用户可以拥有多篇文章。
  • 每篇文章属于一个用户。
1. 实体设计
User 实体
import { Entity, PrimaryGeneratedColumn, Column, OneToMany } from 'typeorm';
import { Article } from './article.entity';@Entity()
export class User {@PrimaryGeneratedColumn()id: number;@Column()name: string;// 一个用户拥有多篇文章@OneToMany(() => Article, (article) => article.author)articles: Article[];
}
Article 实体
import { Entity, PrimaryGeneratedColumn, Column, ManyToOne } from 'typeorm';
import { User } from './user.entity';@Entity()
export class Article {@PrimaryGeneratedColumn()id: number;@Column()title: string;@ManyToOne(() => User, (user) => user.articles, { onDelete: 'CASCADE' })author: User; // 每篇文章属于一个用户
}

2. 数据库结构

根据上述实体,TypeORM 将生成以下表结构:

User

idname
1Alice
2Bob

Article

idtitleauthorId
1First Post1
2Second Post1
3Third Post2

3. 插入数据
创建用户和文章
const userRepository = dataSource.getRepository(User);
const articleRepository = dataSource.getRepository(Article);// 创建用户
const user = userRepository.create({ name: 'Alice' });
await userRepository.save(user);// 创建文章
const article1 = articleRepository.create({ title: 'First Post', author: user });
const article2 = articleRepository.create({ title: 'Second Post', author: user });
await articleRepository.save([article1, article2]);

4. 查询数据
查询用户的文章
const userWithArticles = await userRepository.findOne({where: { id: 1 },relations: ['articles'],
});console.log(userWithArticles);

输出:

{"id": 1,"name": "Alice","articles": [{ "id": 1, "title": "First Post" },{ "id": 2, "title": "Second Post" }]
}
查询文章及其作者
const articleWithAuthor = await articleRepository.findOne({where: { id: 1 },relations: ['author'],
});console.log(articleWithAuthor);

输出:

{"id": 1,"title": "First Post","author": { "id": 1, "name": "Alice" }
}

关键点总结

  1. @ManyToOne 是外键的维护者

    • 它在数据库中定义外键列(如 authorId)。
    • 用于指向关系的 “一” 侧。
  2. @OneToMany 是关系的反向映射

    • 它没有单独的数据库列。
    • 它仅用作 @ManyToOne 的反向映射,表示 “一” 侧可以访问所有 “多” 侧的记录。
  3. relations 必须手动加载

    • TypeORM 默认不会加载关联字段,需在查询时指定 relations
  4. cascade 选项

    • cascade: true 允许保存或删除时级联操作(如在保存用户时自动保存其文章)。

http://www.hengruixuexiao.com/news/56873.html

相关文章:

  • 广告投放渠道有哪些重庆百度推广seo
  • 整合营销的特点有哪些网站优化seo推广服务
  • 重庆做网站找谁如何推广seo
  • 营销型网站建设调查表厦门关键词优化报价
  • 前端做网站需要的技能策划推广
  • 库尔勒市建设路街道办网站网站权重
  • 江阴外贸网站制作网络营销的营销方式是什么
  • 池州集团网站建设资源猫
  • 广州 营销型网站建设网络营销的发展前景
  • 有什么网站可以免费做四六级模拟题如何建网站详细步骤
  • 百度网站打不开seo企业培训班
  • 有人有片吗视频免费的seo优化网络公司排名
  • Oss怎么做静态网站个人网页怎么制作
  • 长沙做网站开发大概价格搜索关键词优化排名
  • 上海利恩建设集团有限公司网站免费网站软件推荐
  • 做网站建设公司赚钱吗娄底seo
  • 网站上如何做相关推荐企业网络推广服务
  • 城乡与建设厅网站首页seo是什么公司
  • 国人在线做网站长沙官网seo技术厂家
  • 邵阳做网站公司网站数据
  • 昆山seo网站优化软件2022近期时事热点素材
  • 网站后台上传不了图片网站优化最为重要的内容是
  • wordpress付费查看内容网站关键词优化排名推荐
  • 国外浏览广告赚钱网站大全网易企业邮箱
  • 为什么要用h5建站产品宣传推广方式有哪些
  • 开发一个网站做爬虫安徽seo团队
  • 昆明做网站建设技巧公司网络竞价
  • 网站开发和app开发网站网络营销公司
  • 有什么公司做网站好郑州专业seo首选
  • 三只松鼠品牌案例分析白城seo