这篇博客将介绍如何使用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. jquery1.7.2的源码分析(一)

    说到jquery可能是大家最经常用到的,在日常的编写程序中最经常使用到,在使用jquery插件的同时,深入的解读jquery源码有利于我们学到设计的思想和实现的技巧 在jquery源码的分析中,其中艾 ...

  2. Java集合之LinkedHashMap

    一.初识LinkedHashMap 上篇文章讲了HashMap.HashMap是一种非常常见.非常有用的集合,但在多线程情况下使用不当会有线程安全问题. 大多数情况下,只要不涉及线程安全问题,Map基 ...

  3. HTML5的浏览器支持方案

    现代的浏览器基本都支持 HTML5,此外还有老浏览器. 不管是旧的还是最新的,HTML5对无法识别的元素会作为内联元素自动处理. 所以,在这里教大家怎么让浏览器去处理"未知"的HT ...

  4. ruby 基础知识三 读写文件

    1.File 中参数的含义 r 只读模式.文件指针被放置在文件的开头.这是默认模式. r+ 读写模式.文件指针被放置在文件的开头. w 只写模式.如果文件存在,则重写文件.如果文件不存在,则创建一个新 ...

  5. SQL Server 2016 RC0 安装(超多图)

    微软最新版本的数据库SQL Server 2016在2016年3月9日推出了RC0版本.已经提供了包括简体中文等多种语言版本,不过联机丛书还是英文版的.对OS的要求是WIN8,WIN10, WIN20 ...

  6. 03 Yarn 原理介绍

    Yarn 原理介绍 大纲: Hadoop 架构介绍 YARN 产生的背景 YARN 基础架构及原理   Hadoop的1.X架构的介绍   在1.x中的NameNodes只可能有一个,虽然可以通过Se ...

  7. android App使用新浪微博sdk的使用总结

    问题1:注册app的key 问题2:在微博开放平台,我的应用中心中,设置应用的基本信息的时候其中有一项,是设置你的应用的签名,签名是需要在安卓设备上安装一个生成签名的app(这个app界面很丑,这点我 ...

  8. 李炎恢《PHP第二季视频教程》之总结

    课时 <面向对象工具[1]>. 语法: __autoload.  __call.__tostring.__clone 1.   autoload 自动引用类.不用包含类,call屏蔽调用类 ...

  9. JS利用取余实现toggle多函数

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  10. iOS 用户的隐私数据-privacy-sensitive data

    1  Xcode 报错:This app has crashed because it attempted to access privacy-sensitive data without a usa ...