zoukankan      html  css  js  c++  java
  • Linq to Oracle 使用教程(九)ALinq 的扩展

     

    点击这里返回目录

    ALinq 在 Linq to SQL 的基本,做了一些扩展,使得它更为好用。

    获取实体类的 DataContext 对象

    选择Category 实体类,将 DataContext 设为 True 。

     

    运行下面的代码:

    static void Main(string[] args)
    {
    var dc
    = new NorthwindDataContext() { Log = Console.Out };
    var category
    = dc.Categories.First();
    Console.WriteLine(category.DataContext);
    }

    运行结果:

    很明显,可以看到 category.DataContext 对象不为空,但是我们并没有在代码中给 category.DataContext 赋值,它怎么会不为空呢?我来看一下代码生成器生成的代码。

    代码
    // This method is called by the dataContext when the entity is created.
    private void SetDataContext(ALinq.DataContext dataContext)
    {
    this.DataContext = ((NorthwindDataContext)(dataContext));
    }

    public NorthwindDataContext DataContext
    {
    get
    {
    return this._DataContext;
    }
    private set
    {
    this._DataContext = value;
    }
    }

    我们主意到 SetDataContext 这个方法,当一个实体被 DataContext 创建后,DataContext 便会通反射检索名称 SetDataContext 的方法,如果存在,则调用该方法。所以,尽管我闪并没有对 category.DataContext 赋值,但 DataContext 却通过调用 SetDataContext 对它进行了赋值。

    批量更新、删除

    代码
    static void Main(string[] args)
    {
    var dc
    = new NorthwindDataContext() { Log = Console.Out };
    dc.Categories.Update(o
    => new Category { Categoryname = "New Name" }, o => o.Categoryid == -1);
    dc.Categories.Delete(o
    => o.Categoryid == -1);
    }

    运行结果:

      

    使用 Linq 表达式插入数据

    代码
    static void Main(string[] args)
    {
    var dc
    = new NorthwindDataContext() { Log = Console.Out };
    var categoryID
    = dc.Categories.Max(c => c.Categoryid) + 1;
    dc.Categories.Insert(o
    => new Category
    {
    Categoryid
    = categoryID,
    Categoryname
    = "Category Name",
    Description
    = "Description"
    });
    }

    运行结果:

    点击这里返回目录

  • 相关阅读:
    洛谷 P1521 求逆序对
    火柴棒等式(2008年NOIP全国联赛提高组)
    扫雷游戏
    数字统计(2010年NOIP全国联赛普及组)
    祖瑪
    巧克力棒&&新年的巧克力棒
    关押罪犯(2010年NOIP全国联赛提高组)
    大整数运算||高精度运算
    國王遊戲(2012年NOIP全国联赛提高组)
    谁拿了最多奖学金(2005提高组第一题)
  • 原文地址:https://www.cnblogs.com/ansiboy/p/1894794.html
Copyright © 2011-2022 走看看