Linq to sql:论坛表结构

2024-06-03 20:48
文章标签 sql 论坛 结构 database linq

本文主要是介绍Linq to sql:论坛表结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为了演示继承与关系,我们创建一个论坛数据库,在数据库中创建三个表:

 

1           论坛版块分类表 dbo.Categories


 

字段名


字段类型


可空


备注


 

CategoryID int

 

CategoryName            varchar(50)

 

2           论坛版块表 dbo.Boards


not null

 

not null


identity/主键


 

字段名

 

BoardID

 

BoardName

 

BoardCategory


字段类型

 

int

 

varchar(50)

 

int


可空

 

not null

 

not null

 

not null


备注

 

identity/主键

 

 

 

 

对应论坛版块分类表

 

CategoryID


 

3           论坛主题表 dbo.Topics

 

字段名                        字段类型


 

 

 

可空


 

 

 

备注


 

TopicID

 

TopicTitle

 

TopicContent

 

ParentTopic


int

 

varchar(50)

 

varchar(max)

 

int


not null

 

not null

 

not null

 

null


identity/主键

 

如果帖子是主题贴这

 

TopicType

 

实体继承的定义


tinyint


not null


个字段为null,否则

 

就是所属主题id

 

0 –  主题贴

 

1 –  回复帖


 

Linq to sql 支持实体的单表继承,也就是基类和派生类都存储在一个表中。对于论坛来

 

说,帖子有两种,一种是主题贴,一种是回复帖。那么,我们就先定义帖子基类:

 

[Table(Name = "Topics")]

 

public class Topic

 

{

 

       [Column(Name = "TopicID", DbType = "int identity", IsPrimaryKey = true,

 

IsDbGenerated = true,CanBeNull = false)]

 

public int TopicID { get; set; }

 

 

 

 

       [Column(Name = "TopicType", DbType = "tinyint", CanBeNull = false)]

 

public int TopicType { get; set; }

 

 

 

 

       [Column(Name = "TopicTitle", DbType = "varchar(50)", CanBeNull = false)]

 

public string TopicTitle { get; set; }

 

       [Column(Name = "TopicContent", DbType = "varchar(max)", CanBeNull = false)]

 

public string TopicContent { get; set; }

 

}

 

这些实体的定义大家应该很熟悉了。下面,我们再来定义两个实体继承帖子基类,分别

 

是主题贴和回复贴:

 

public class NewTopic : Topic

 

{

 

public NewTopic()

 

       {

 

base.TopicType = 0;

 

       }

 

}

 

 

 

 

public class Reply : Topic

 

{

 

public Reply()

 

       {

 

base.TopicType = 1;

 

       }

   [Column(Name = "ParentTopic", DbType = "int", CanBeNull = false)]

 

public int ParentTopic { get; set; }

 

}

 

对于主题贴,在数据库中的TopicType就保存为0,而对于回复贴就保存为1。回复贴

 

还有一个相关字段就是回复所属主题贴的TopicID。那么,我们怎么告知Linq to sql

 

TopicType 0 的时候识别为NewTopic,而1 则识别为Reply 那?只需稍微修改一下前面

 

Topic 实体定义:

 

[Table(Name = "Topics")]

 

[InheritanceMapping(Code= 0, Type = typeof(NewTopic), IsDefault = true)]

 

[InheritanceMapping(Code= 1, Type = typeof(Reply))]

 

public class Topic

 

{

 

       [Column(Name = "TopicID", DbType = "int identity", IsPrimaryKey = true,

 

IsDbGenerated = true,CanBeNull = false)]

 

public int TopicID { get; set; }

   [Column(Name = "TopicType", DbType = "tinyint", CanBeNull = false, IsDiscriminator

 

= true)]

 

public int TopicType { get; set; }

    [Column(Name = "TopicTitle", DbType = "varchar(50)", CanBeNull = false)]

 public string TopicTitle { get; set; }

 [ Column (Name = "TopicContent" , DbType = "varchar(max)" , CanBeNull = false )]

 

public string TopicContent { get; set; }

 

}

 

为类加了InheritanceMapping 特性定义,0 的时候类型就是NewTopic1 的时候就是

 

Reply。并且为TopicType字段上的特性中加了IsDiscriminator = true,告知Linqto sql

 

个字段就是用于分类的字段。


这篇关于Linq to sql:论坛表结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028074

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID