zoukankan      html  css  js  c++  java
  • 光脚丫学LINQ(030):如何让实体类成员表示主键

    视频演示:http://u.115.com/file/f28f964604


    光脚总结
    要想使实体类中的列属性表示数据表中的主键列,则可以为ColumnAttribute特性添加IsPrimaryKey属性,并将其设置为true。
    实体类如果没有指定任何主键,则数据只能读取,不能修改。是相对于数据库而言,而并非内存中的对象。
    可以同时指定多个主键,而且所指定的主键并非一定要与数据表中的主键对应。
    设置一个对应数据表主键列的属性,肯定能够正确的更新数据,这是最通常的做法。
    设置一个不对应数据表的主键,能够正确更新数据。
    设置多个主键列属性,也能够正确更新数据。
    但是,已经被设置为主键列的属性,其数据不可以被修改,更不会被更新的,否则就会引发异常。
    异常的大意上是说:无法更改定义对象标识的成员。
    也就是说,只能设置非主键列的属性值。在这种情况下数据将会被正确的更新。
    如果没有修改主键列的属性值,那么以上几种情况更新数据时,所生成SQL命令基本上是一致的,似乎没什么区别。


    示例代码

    [Column(Storage="_CustomerID", DbType="NChar(5) NOT NULL",   
        CanBeNull=false,   
        IsPrimaryKey=true)]   
    public string CustomerID   
    {   
        get  
        {   
            return this._CustomerID;   
        }   
        set  
        {   
            if ((this._CustomerID != value))   
            {   
                this.OnCustomerIDChanging(value);   
                this.SendPropertyChanging();   
                this._CustomerID = value;   
                this.SendPropertyChanged("CustomerID");   
                this.OnCustomerIDChanged();   
            }   
        }   
    }
  • 相关阅读:
    CF732 F Tourist Reform——边双连通分量
    CF36 E Two Paths——欧拉(回)路
    最小生成树()
    Bellman-Ford算法
    SPFA算法
    归并排序(Merge_Sort)
    并查集
    int(3)与int(11)的区别
    mysql应该看的blog
    mysql建立索引
  • 原文地址:https://www.cnblogs.com/GJYSK/p/1867754.html
Copyright © 2011-2022 走看看