小编mir*_*han的帖子

使用EntityFramework获取有序范围的最有效方法是什么?

困境

我有一个大型数据集,我需要在其中的一部分执行复杂的计算.对于我的计算,我需要根据输入参数从大型集合中获取一大块有序数据.

我的方法签名如下所示:

double Process(Entity e, DateTimeOffset? start, DateTimeOffset? end)
Run Code Online (Sandbox Code Playgroud)

潜在解决方案

我想到以下两种方法:

方法1 - WHERE子句

double result = 0d;
IEnumerable<Quote> items = from item in e.Items
                           where (!start.HasValue || item.Date >= start.Value)
                              && (!end.HasValue || item.Date <= end.Value)
                           orderby item.Date ascending
                           select item;
...
return result;
Run Code Online (Sandbox Code Playgroud)

方法2 - 跳过并采取

double result = 0d;
IEnumerable<Item> items = e.Items.OrderBy(i => i.Date);
if (start.HasValue)
    items = items.SkipWhile(i => i.Date < start.Value);
if (end.HasValue)
    items = items.TakeWhile(i => i.Date <= end.Value);
... …
Run Code Online (Sandbox Code Playgroud)

c# linq entity-framework entity-framework-6

9
推荐指数
1
解决办法
154
查看次数

使用可变元素类型创建指令

我正在尝试创建一个指令,通过使用"大","中","小"的下拉选择器来更改html元素类型(h1/h2/h3).我希望它也保留元素的属性.我创建了一个这个例子的小提琴:http: //jsfiddle.net/H63Z3/1/

角度:

angular.module('app', [])
        .controller('example', function ($scope) {
            $scope.type = 'h2';
        })
        .directive('changeType', function ($compile) {
            return {
                restrict: 'A',
                link: function (scope, element, attributes) {
                    scope.$watch('type', function () {
                        var attrs = element[0].attributes;
                        var newElement = $('<' + scope.type + '>').text(element.text());
                        for (var i = 0; i < attrs.length; i++) {
                            newElement.attr(attrs.item(i).name, attrs.item(i).value);
                        }
                        element.replaceWith(newElement);
                        $compile(element.contents())(scope);
                    });
                }
            };
        });
Run Code Online (Sandbox Code Playgroud)

HTM&L:

<div ng-app="app" ng-controller="example">
    <select ng-model="type" ng-options="k as v for (k,v) in { h1: 'Large', h2: …
Run Code Online (Sandbox Code Playgroud)

angularjs angularjs-directive

5
推荐指数
1
解决办法
2770
查看次数