[Database(Name="AdventureWorks")] --> 映射数据库

[Table(Name="Customers")] --> 映射表

[Column(Name="CustomerID")] --> 映射字段

ColumnAttribute有以下内容:

Name     --> 列名

DbType   --> 数据列的类型

Storage  --> 类的暂存字段或变量(对应数据列字段)

IsPrimaryKey --> 是否主键

IsDbGenerated --> 是否自增

CanBeNull --> 是否允许null值

AutoSync --> 在Insert或Update操作执行后得到当前Column值

Never: 默认值,不为插入更新操作返回值

OnUpdate: 只返回更新操作的值

OnInsert: 只返回插入操作的值

Expression --> 数据计算数据列的值

IsVersion --> 指定当前列的版本或时间戳

UpdateCheck --> 在LINQ to SQL中对乐观并发操作控制

Always, Nerver, WhenChanged IsDiscriminator --> 鉴别列是否LINQ to SQL继承关系

RelationShips: LINQ to SQL定义一个AssociationAttribute属性表示关系,这个属性与EntitySet(TEntity)和EntityRef(TEntity)类型一起使用表示在数据库中外键关系

数据库中表的关系指的是主外键,LINQ to SQL 的主键是通过IsPrimaryKey来设置的,外键关系用AssociationAttribute决定

AssociationAttribute内容:

Name  --> 关系名

Storage  --> 暂时存储的字段或变量

IsUnique --> 外键是否有唯一约束

ThisKey  --> 在实体类的成员上标识,表示本成员的联合键值

otherkey --> 在多个目标实体上标识,表示与其他成员的联合键值

EntitySet类:设置外键的实体 与EntityRef结合-->EntityRef引用外键的实体

·一对多

1在M端:以EntityRef形式出现

M在1端:以EntitySet形式出现

·一对一 在各自的类中,均以EntityRef出现

·多对多:表的主键通常还有其他两个表的外键混合在表中

Linq to sql 对非侵入式和侵入式映射都支持

有哪几种Attribute呢?

TableAttribute

ColumnAttribute

AssociationAttribute

DatabaseAttribute

ProviderAttribute

FunctionAttribute

AutoSync  --> 自动同步 是一个枚举

public enum AutoSync {  Default,  Always,  Never,  OnInsert,  OnUpdate }

解释:在执行insert和update操作后,这个类的属性如何和数据库表对应的字段进行同步

AutoSync.Default  --> 列在数据库中有默认值,IsDbGenerated属性标记为true时则同步

AutoSync.Always  --> 总是进行同步

AutoSync.Never  --> 从不进行同步

AutoSync.OnInsert --> 在执行Insert操作后同步

AutoSync.OnUpdate --> 在更新的时候同步

在执行insert时,还会看到一个select代码,但我们并没有执行select操作,其实是AutoSync的原因,默认的时候IsDbGenerated为true的列是会被查出来返回的。

CanBeNull  --> 是否允许null

DbType  --> 创建表时,使用DbType指定列的数据类型

Expression --> 表示一个计算列,数据表的列通过计算获取的

IsDbGenerated --> 是否值在数据库中自动生成

IsPrimarykey --> 是否主键

IsVersion

UpdateCheck

Name  --> 属性名和列表不一致时指定

Storage  --> 赋值给私有字段而不是直接赋值给属性

Association:用来建立实体之间的关系

ThisKey  --> 用来标识和别的对象关联的键,如果没有指明就用本类属性上标识有IsPrimaryKey的了

OtherKey --> 用来定义关联的类的键,如果没有指定就用关联的那个类的标识列了

Name --> 指定关系名,是利用映射动态创建数据库的时候建立关系用的

SqlMetal生成的DBML文件信息的更多相关文章

  1. [转]Sublime Text 新建文件快速生成Html【头部信息】和【代码补全】、【汉化】

    Sublime Text 新建文件快速生成Html[头部信息]和[代码补全].[汉化] 真心越来越喜欢sublime 这个工具,高效便捷,渐渐离不了了! 安装package control简单的安装方 ...

  2. Asp.net中存储过程拖拽至dbml文件中,提示无法获得返回值

    Asp.net中存储过程拖拽至dbml文件中,提示无法获得返回值,去属性表中设置这时候会提示你去属性表中更改返回类型. 其实存储过程返回的也是一张表,只不过有时候存储过程有点复杂或者写法不规范的话不能 ...

  3. 通过HTML5的Drag and Drop生成拓扑图片Base64信息

    HTML5 原生的 Drag and Drop是很不错的功能,网上使用例子较多如 http://html5demos.com/drag ,但这些例子大部分没实际用途,本文将搞个有点使用价值的例子,通过 ...

  4. Bitmap文件格式+生成一个BMP文件

    Bitmap的文件格式: #define UINT16 unsigned short #define DWORD unsigned int #define WORD short #define LON ...

  5. 基于MVC4+EasyUI的Web开发框架经验总结(14)--自动生成图标样式文件和图标的选择操作

    在很多Web系统中,一般都可能提供一些图标的选择,方便配置按钮,菜单等界面元素的图标,从而是Web系统界面看起来更加美观和协调.但是在系统中一般内置的图标样式相对比较有限,而且硬编码写到样式表里面,这 ...

  6. vs2008生成的各种文件

    一.sln文件     .sln(Solution)解决方案文件,表示一个项目组,他通常包含一个项目中所有的工程文件信息.   二.suo文件     suo(Solution User Option ...

  7. vs 自动生成core dump文件

    一直以来觉着core dump这个东西很神奇,在初步学习的时候也没有个大方向,最近项目需要记录程序崩溃时的日志信息,因此在网上寻找相关的信息,此时core dump也成为了我重点关注的东西. 说说我的 ...

  8. 由动态库文件dll生成lib库文件(手动生成.def文件,然后使用lib命令编译,非常牛),同理可使用dll生成.a库文件

    本文基于OpenBlas的编译和安装,来说明如何从一个dll文件生成lib库文件. 参考OpenBlas的说明“Howto generate import library for MingW”,和Mi ...

  9. Qt之生成Window资源文件(.rc 文件)

    简述 qmake 可以随意地自动生成一个适当填充的 Windows 资源文件.本节主要讲解如何用 qmake 处理一个 Windows 资源文件,并将其链接到一个可执行应用程序(EXE)或动态链接库( ...

随机推荐

  1. python之redis和memcache操作

    Redis 教程 Redis是一个开源(BSD许可),内存存储的数据结构服务器,可用作数据库,高速缓存和消息队列代理.Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据 ...

  2. css知多少(12)——目录

    <css知多少>系列就此完结了.常来光顾的朋友可能会觉得突然:css的知识点还有很多,怎么突然就完了,还没讲完呢?这样说是对的.不过凡事都有一个定位,如果盲目求多,定位模糊,那样就没有目的 ...

  3. WebStorage记录滚动条位置

    因关注公众号<HTML5学堂>看到这篇文章 "利用本地存储,记录滚动条的位置" ,便好奇敲来试试,然后又看了一些关于WebStorage的资料 附上这篇文章的地址 ht ...

  4. 【blade的UI设计】理解前端MVC与分层思想

    前言 最近校招要来了,很多大三的同学一定按捺不住心中的焦躁,其中有期待也有彷徨,或许更多的是些许担忧,最近在开始疯狂的复习了吧 这里小钗有几点建议给各位: ① 不要看得太重,关心则乱,太紧张反而表现不 ...

  5. jquery实现导航图轮播

    版权声明:作者原创,转载请注明出处! 下面的几个栗子是使用jquery实现Banner轮播的效果,直接将代码贴出来,从最初级没有任何优化和封装的写法,一直到最后一个栗子,一步步进行了优化,加大程序的可 ...

  6. 理解CSV文件以及ABAP中的相关操作

    在很多ABAP开发中,我们使用CSV文件,有时候,关于CSV文件本身的一些问题使人迷惑.它仅仅是一种被逗号分割的文本文档吗? 让我们先来看看接下来可能要处理的几个相关组件的词汇的语义. Separat ...

  7. JavaScript异步编程(1)- ECMAScript 6的Promise对象

    JavaScript的Callback机制深入人心.而ECMAScript的世界同样充斥的各种异步操作(异步IO.setTimeout等).异步和Callback的搭载很容易就衍生"回调金字 ...

  8. Html5的一些基础知识

    <!DOCTYPE html><html><head><meta charset="utf-8" /><title>页面 ...

  9. iOS之加密的三种方法

    //需要导入   #import <CommonCrypto/CommonCryptor.h> ==============MD5加密============ NSString *str ...

  10. Menu创建菜单

    菜单是用户界面中最常见的元素之一,使用非常频繁,在Android中,菜单被分为如下三种,选项菜单(OptionsMenu).上下文菜单(ContextMenu)和子菜单(SubMenu),今天这讲是O ...