导航属性是 FreeSql 的特色功能之一,可通过约定配置、或自定义配置对象间的关系。

导航属性有 OneToMany, ManyToOne, ManyToMany, OneToOne, Parent 五种配置关系。

有了导航属性,多表查询会非常方便,lambda 表达式中直接使用导航对象点点点,舒服!!

除了查询还有更多其他的特性在后续文章中再介绍。

自定义导航关系
//导航属性,OneToMany [Navigate("song_id")] public virtual List<song_tag>
Obj_song_tag { get; set; } //导航属性,ManyToOne/OneToOne [Navigate("song_id")]
public virtual Song Obj_song { get; set; } //导航属性,ManyToMany
[Navigate(ManyToMany = typeof(tag_song))] public virtual List<tag> tags { get;
set; }
* 可约定,可不约定;
* 不约定的,需指定 Navigate 特性关联;
* 无关联的,查询时可以指明 On 条件,LeftJoin(a => a.Parent.Id == a.ParentId);
* 已关联的,直接使用导航对象就行,On 条件会自动附上;
约定配置

OneToOne 一对一
class User { public int Id { get; set; } //Id、UserId、User_id public UserExt
UserExt { get; set; } } class UserExt { public int id { get; set; }
//Id、UserId、User_id、UserExtId、UserExt_id public User User { get; set; } }
《OneToOne 一对一,怎么添加数据?》 <https://github.com/2881099/FreeSql/issues/45>

ManyToOne 多对一
class Group { public int Id { get; set; } //Id、GroupId、Group_id } class User {
public int Id { get; set; } //Id、UserId、User_id public int AGroupId { get; set;
} public Group AGroup { get; set; } public int BGroupId { get; set; } public
Group BGroup { get; set; } }
OneToMany 一对多
class Group { public int Id { get; set; } //Id、GroupId、Group_id public
ICollection<User> AUsers { get; set; } public ICollection<User> BUsers { get;
set; } } class User { public int Id { get; set; } //Id、UserId、User_id public
int AGroupId { get; set; } public Group AGroup { get; set; } public int
BGroupId { get; set; } public Group BGroup { get; set; } }
《OneToMany 一对多,怎么添加数据?》 <https://github.com/2881099/FreeSql/issues/46>

Parent 父子
class Group { public int Id { get; set; } //Id、GroupId、Group_id public int
ParentId { get; set; } //ParentId、Parent_id public Group Parent { get; set; }
public ICollection<Group> Childs { get; set; } }
父子关系,与一对多其实差不多,添加数据参数上面的连接;

ManyToMany 多对多
class Song { [Column(IsIdentity = true)] public int Id { get; set; } public
string Title { get; set; } public virtual ICollection<Tag> Tags { get; set; } }
class Song_tag { public int Song_id { get; set; } public virtual Song Song {
get; set; } public int Tag_id { get; set; } public virtual Tag Tag { get; set;
} } class Tag { [Column(IsIdentity = true)] public int Id { get; set; } public
string Name { get; set; } public int? Parent_id { get; set; } public virtual
Tag Parent { get; set; } public virtual ICollection<Song> Songs { get; set; }
public virtual ICollection<Tag> Tags { get; set; } }
Song、Tag、Song_tag,这三个实体使用了 OneToMany、ManyToOne、Parent、ManyToMany 4种关系。

系列文章导航

*
(一)入门 <https://www.cnblogs.com/FreeSql/p/11531300.html>

*
(二)自动迁移实体 <https://www.cnblogs.com/FreeSql/p/11531301.html>

*
(三)实体特性 <https://www.cnblogs.com/FreeSql/p/11531302.html>

*
(四)实体特性 Fluent Api <https://www.cnblogs.com/FreeSql/p/11531304.html>

*
(五)插入数据 <https://www.cnblogs.com/FreeSql/p/11531306.html>

*
(六)批量插入数据 <https://www.cnblogs.com/FreeSql/p/11531309.html>

*
(七)插入数据时忽略列 <https://www.cnblogs.com/FreeSql/p/11531316.html>

*
(八)插入数据时指定列 <https://www.cnblogs.com/FreeSql/p/11531318.html>

*
(九)删除数据 <https://www.cnblogs.com/FreeSql/p/11531320.html>

*
(十)更新数据 <https://www.cnblogs.com/FreeSql/p/11531321.html>

*
(十一)更新数据 Where <https://www.cnblogs.com/FreeSql/p/11531324.html>

*
(十二)更新数据时指定列 <https://www.cnblogs.com/FreeSql/p/11531327.html>

*
(十三)更新数据时忽略列 <https://www.cnblogs.com/FreeSql/p/11531334.html>

*
(十四)批量更新数据 <https://www.cnblogs.com/FreeSql/p/11531335.html>

*
(十五)查询数据 <https://www.cnblogs.com/FreeSql/p/11531339.html>

*
(十六)分页查询 <https://www.cnblogs.com/FreeSql/p/11531341.html>

*
(十七)联表查询 <https://www.cnblogs.com/FreeSql/p/11531346.html>

*
(十八)导航属性

*
(十九)多表查询 <https://www.cnblogs.com/FreeSql/p/11531362.html>

*
(二十)多表查询 WhereCascade <https://www.cnblogs.com/FreeSql/p/11531372.html>

*
(二十一)查询返回数据 <https://www.cnblogs.com/FreeSql/p/11531376.html>

*
(二十二)Dto 映射查询 <https://www.cnblogs.com/FreeSql/p/11531381.html>

*
(二十三)分组、聚合 <https://www.cnblogs.com/FreeSql/p/11531384.html>

*
(二十四)Linq To Sql 语法使用介绍 <https://www.cnblogs.com/FreeSql/p/11531392.html>

*
(二十五)延时加载 <https://www.cnblogs.com/FreeSql/p/11531395.html>

*
(二十六)贪婪加载 Include、IncludeMany、Dto、ToList
<https://www.cnblogs.com/FreeSql/p/11531404.html>

*
(二十七)将已写好的 SQL 语句,与实体类映射进行二次查询
<https://www.cnblogs.com/FreeSql/p/11531416.html>

*
(二十八)事务 <https://www.cnblogs.com/FreeSql/p/11531423.html>

*
(二十九)Lambda 表达式 <https://www.cnblogs.com/FreeSql/p/11531425.html>

*
(三十)读写分离 <https://www.cnblogs.com/FreeSql/p/11531430.html>

*
(三十一)分区分表 <https://www.cnblogs.com/FreeSql/p/11531435.html>

*
(三十二)Aop <https://www.cnblogs.com/FreeSql/p/11531471.html>

*
(三十三)CodeFirst 类型映射 <https://www.cnblogs.com/FreeSql/p/11531543.html>

*
(三十四)CodeFirst 迁移说明 <https://www.cnblogs.com/FreeSql/p/11531550.html>

*
(三十五)CodeFirst 自定义特性 <https://www.cnblogs.com/FreeSql/p/11531576.html>