这篇博客将介绍如何使用LINQ TO SQL来创建数据库,以及如何映射Table之间的主外键关系。

我们的数据库表关系如下:

Province与City之间1:M,City与Area之间1:M的关系。

下面就通过LINQ TO SQL来创建这样的数据库,以Province表为例,

Province Table:

using System.Collections.Generic;
using System.Data.Linq;
using System.Data.Linq.Mapping; namespace ImportAreaInfoApp.Models
{
[Table(Name = "Province")]
class Province
{
[Column(IsPrimaryKey = true, Name = "Id", IsDbGenerated = true, CanBeNull = false)]
public int Id { get; set; } [Column]
public string Name { get; set; }
}
}

1). 引用System.Data.Linq.Mapping;

2). 给Province类添加Table属性,如果数据库表名与类名一致,可以不设置Table的Name值,会默认使用类名作为数据表的名字;

3). 数据表中列通过Column指定,如果该列为主键,需要设置IsPrimaryKey=true,同样的如果列名与字段名一致,Name可以不指定。

City Table:

using System.Collections.Generic;
using System.Data.Linq;
using System.Data.Linq.Mapping; namespace ImportAreaInfoApp.Models
{
[Table(Name = "City")]
class City
{
[Column(IsPrimaryKey = true, Name = "Id", IsDbGenerated = true, CanBeNull = false)]
public int Id { get; set; } [Column(Name = "Name")]
public string Name { get; set; }
}
}

Area Table:

using System.Collections.Generic;
using System.Data.Linq;
using System.Data.Linq.Mapping; namespace ImportAreaInfoApp.Models
{
[Table(Name = "Area")]
class Area
{
[Column(IsPrimaryKey = true, Name = "Id", IsDbGenerated = true, CanBeNull = false)]
public int Id { get; set; } [Column(Name = "Name")]
public string Name { get; set; }
}
}

到这里,数据表就创建完了。下面创建数据库

using System.Data.Linq;
using System.Data.Linq.Mapping; namespace ImportAreaInfoApp.Models
{
[Database(Name = "ExpressDb")]
class ExpressDbContext : DataContext
{
private const string ConnectionString = @"Data Source=HW-WPF-SER\SQLEXPRESS;Initial Catalog=ExpressDb;Integrated Security=True;"; public Table<Province> Provinces; public Table<City> Cities; public Table<Area> Areas; public ExpressDbContext()
: base(ConnectionString)
{ }
}
}

1). 数据库类需要继承DataContext,并且类名需要添加Database属性,如果数据库名称与类名不一致,需要制定Name值;

2). 数据库所关联的表需要通过Table<Table Class> Tables指出来;

3). 在程序中我们可以通过ExpressDbContext类来操作所属的数据表完成CRUD操作。

创建数据库,

using (ExpressDbContext dbContext = new ExpressDbContext())
{
if (dbContext.DatabaseExists())
{
dbContext.DeleteDatabase();
} dbContext.CreateDatabase();
}

但是数据表之间的关系没有映射。以Province和City为例,对City类做如下修改,

using System.Collections.Generic;
using System.Data.Linq;
using System.Data.Linq.Mapping; namespace ImportAreaInfoApp.Models
{
[Table(Name = "City")]
class City
{
[Column(IsPrimaryKey = true, Name = "Id", IsDbGenerated = true, CanBeNull = false)]
public int Id { get; set; } [Column(Name = "Name")]
public string Name { get; set; } [Column(Name = "Province")]
private int? _provinceId; private EntityRef<Province> _province = new EntityRef<Province>
(); [Association(Name = "FK_City_Province", IsForeignKey = true, Storage = "_province", ThisKey = "_provinceId")]
public Province Province
{
get { return _province.Entity; }
set { _province.Entity =
value; }
}

}
}

1). 创建一个int?型的私有变量来保存ProvinceId;

2). 创建EntityRef<Province>私有变量来保存City关联的Province;

3). 通过Association来标识关联性;

相应的,对Province类也要做修改,

using System.Collections.Generic;
using System.Data.Linq;
using System.Data.Linq.Mapping; namespace ImportAreaInfoApp.Models
{
[Table(Name = "Province")]
class Province
{
[Column(IsPrimaryKey = true, Name = "Id", IsDbGenerated = true, CanBeNull = false)]
public int Id { get; set; } [Column]
public string Name { get; set; } private EntitySet<City> _cities = new EntitySet<City>(); [Association(Name= "FK_City_Province", Storage = "_cities", OtherKey = "_provinceId", ThisKey = "Id")]
public ICollection<City> Cities
{
get { return _cities; }
set
{ _cities.Assign(value); }
}

}
}

1). 添加EntitySet<City>私有变量来持有Province相关联的City;

2). 通过Association来完成外键关系匹配;

经过上述代码的修改Province与City之间的1:M关系就建立了。

感谢您的阅读。

[LINQ TO SQL]使用LINQ TO SQL创建数据库的更多相关文章

  1. ASP.NET实现二维码 ASP.Net上传文件 SQL基础语法 C# 动态创建数据库三(MySQL) Net Core 实现谷歌翻译ApI 免费版 C#发布和调试WebService ajax调用WebService实现数据库操作 C# 实体类转json数据过滤掉字段为null的字段

    ASP.NET实现二维码 using System;using System.Collections.Generic;using System.Drawing;using System.Linq;us ...

  2. Sql语句在SqlServer中创建数据库、表格并添加约束

    通过Sql语句来创建数据库与架构 创建数据库 数据库的创建首先是要引用主数据库的,需要在master数据库的环境下进行创建.大致的语法如下: -- 使用master数据库 use master -- ...

  3. PL/SQL Developer图形化窗口创建数据库(表空间和用户)以及相关查询sql

    前言:上一篇安装好oracle和pl/sql后,这篇主要讲如何创建数据库,因为接下来我的项目会连接数据库进行开发. 第一步.先用系统管理员登录pl/sql 我这里系统管理员用户名为system,密码为 ...

  4. 必须会的SQL语句(一) 创建数据库与删除数据库

    1.创建数据库   Create database 名称 on primary {    name ='名称',    filename ='c:\xx\名称.mdf',    size = 10mb ...

  5. 【SQL server基础】手动创建数据库和表格

    use master go if exists(select * from sysdatabases where name='learning') drop database learning go ...

  6. sql server2008中怎样用sql语句创建数据库和数据表

    这是简单用代码实现创建数据库和数据表的sql语句,如下: --调用系统数据库-- use master go /***防止你要创建的数据库同名,先把它删除掉****/ if Exists(select ...

  7. 使用动态SQL创建数据库

    /*其实我也搞不懂为什么要用SQL来创建,明明SQL Server有图形化创建数据库多省事啊!*/USE master; ​DECLARE @sqlstr nvarchar(max)/*定义一个变量* ...

  8. C# 读取文件中的sql语句 创建数据库以及表结构

    大概思路是: 读取文件 根据文件中行内容为GO 作为分割  一条条放到list中 然后在程序中逐条执行sql语句; 值得一提的是 创建数据库的语句是不允许放到程序事务中执行的 所以目前我是分了两个文本 ...

  9. Mysql常用sql语句(一)- 操作数据库

    21篇测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html ...

随机推荐

  1. 15 个实用的 PHP 正则表达式

    1:验证域名检验一个字符串是否是个有效域名 2:从一个字符串中 突出某个单词 3:从HTML文档中获得全部图片 如果你曾经希望去获得某个网页上的全部图片,这段代码就是你需要的,你可以轻松的建立一个图片 ...

  2. Python PIP安装

    https://zhidao.baidu.com/question/550936793.html 按图做

  3. 转载:MySQL 语句大全:创建、授权、查询、修改等

    本文转载>这里 一.用户创建.权限.删除 1.连接MySql操作 连接:mysql -h 主机地址 -u 用户名 -p 用户密码 (注:u与root可以不用加空格,其它也一样)断开:exit ( ...

  4. PJAX的实现与应用

    一.前言 web发展经历了一个漫长的周期,最开始很多人认为Javascript这们语言是前端开发的累赘,是个鸡肋,那个时候人们还享受着从一个a链接蹦 到另一个页面的web神奇魔术.后来随着JavaSc ...

  5. [从产品角度学EXCEL 01]-EXCEL是怎样运作的

    这是<从产品角度学EXCEL>系列第二篇. 前言请看:从产品角度学EXCEL-系列0-为什么要关注EXCEL的本质 本文不接受无授权转载,如需转载,请先联系我,非常感谢. 1.EXCEL是 ...

  6. poi2015 bzoj4377-4386训练

    就按时间顺序写吧 完成度:10/10 3.30 bzoj4385 首先一定是删去连续d个数,然后枚举终点,起点显然有单调性,用单调队列乱搞搞就可以啦 bzoj4378 首先才结论:可行当且仅当把所有大 ...

  7. getComputedStyle/currentStyle/style之间的爱恨情仇

    getComputedStyle是? getComputedStyle是一个可以获取当前元素所有最终使用的CSS属性值.返回的是一个CSS样式声明对象([object CSSStyleDeclarat ...

  8. 【Winform】使用BackgroundWorker控制进度条显示进度

    许多开发者看见一些软件有进度条显示进度,自己想弄,项目建好后发现并没有自己想象中的那么简单...看了网上很多教程后,写了一个小Demo供网友们参考~~,Demo的网址:http://pan.baidu ...

  9. yii2 登录用户和未登录用户使用不同的 layout

    可以在配置文件中增加一个 “beforeRequest” 事件: 'on beforeRequest' => function () { Yii::$app->layout = Yii:: ...

  10. C#数字日期装换为中文日期

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...