Asp.netMVC模型
Model负责在View和控制器之间进行数据的传递:用户输入的内容封装为Model对象,发给Controller;要显示的数据有Controller放到Model中,然后扔给View去显示。Controller不直接和View进行交互。
查询id>1的狗有如下两种方法:
lambda写法:var r=dogs.where(d=>d.id>1)
Linq写法:var r2=from d in dogs where d.id>1 select d;
Linq基本语法:以from item in items开始,items为待处理的集合,item为每一项的变量名;最后要加上select,表示结果的数据;记得select一定要放在最后
All---------Grouped
List<Product>products=GetProductList();
var productGroups=from p in products
group p by p.Category into g
where g.All(p=>p.UnitsInStock>0)
select new { Category =g.Key, Products = g };
Count-----Simple
获取列表中没有重复的元素数量
int []factors={ 2, 2, 3, 5, 5};
int unique=factors.Distinct().Count();
Console.WriteLine("There are {0} unique factors",unique);
Count---Nested
List<Customer> customers=GetCustomerList();
var orderCounts=from c in customers
select new{ c.CustomerID,OrderCount=c.Orders.Count() };
Count --------Grouped
List<Product>products=GetProductList();
var categoryCounts=from p in products
group p by p.Category into g
select new { Category=g.Key,ProductCount=g.Count() };
Sum----Grouped
List<Product>products=GetProductList();
var categories=from p in products
group p by p.Category into g
select new { Category=g.Key, TotalUnitsInstock=g.Sum(p=>p.UnitsInStock) };
ObjectDumper.Write(categories);
Min-----Projection
string[]words={"cherry","apple","blueberry"};
int shortestWord=words.Min(w=>w.Length);
Console.WriteLine("The shortest word is {0} characters long.",shortestWord);
Min-----Grouped
List<Product>products=GetProductList();
var categories=from p in products
group p by p.Category into g
select new { Category=g.Key , CheapestPrice=g.Min(p=>p.UnitPrice) };
ObjectDumper.Write(categories);
Min------Elements
List<Product>prodducts=GetProductList();
var categories=from p in products
group p by p.Category into g
let minPrice=g.Min(p=>p.UnitPrice)
select new { Category=g.Key,CheapestProducts=g.Where(p=>p.UnitPrice==minPrice) };
Max----Projection
string [ ] words={ "cherry", "apple", "blueberry" };
int longestLength=words.Max(w=>w.Length);
Console.WriteLine("The longest word is {0} characters long",longestLength);
Max-----Grouped
List<Product>products=GetProductList();
var categories=from p in products
group p by p.Category into g
select new {Category=g.Key,MostExpensivePrice=g.Max(p=>p.UnitPrice) };
Max------Elements
List<Product>products=GetProductList();
var categories=from p in products
group p by p.Category into g
let maxPrice=g.Max(p=>p.UnitPrice)
select new { Category=g.Key, MostExpensiveProducts=g.Where(p=>p.UnitPrice==maxPrice) };
ObjectDumper.Write(categories,1);
Average ---Projection
string[] words={"cherry", "apple", "blueberry"};
double averageLength=words.Average(w=>w.Length);
Console.WriteLine("The average word length is {0} characters.",averageLength);
Average----Grouped
List<Product>products=GetProductList();
var categories=from p in products
group p by p.Category into g
select new {Category=g.Key, AveragePrice=g.Average(p=>p.UnitPrice) };
Aggregate----Simple
这个例子是数组中所有的元素相乘,求出最终的积
double[] doubles={1.7, 2.3, 1.9, 4.1, 2.9};
double product=doubles.Aggregate((runningProduct,nextFactor)=>runningProduct*nextFactor);
Console.WriteLine("Total product of all numbers:{0}",product);
Concat----1
求两个集合的合集
int[] numbersA={0,2,4,5,6,8,9};
int[] numbersB={1,3,5,7,8};
var allNumbers=numbersA.Concat(numbersB);
Console.WriteLine("All numbers from both arrays:");
foreach(var n in allNumbers){
Console.WriteLine(n);
}
Concat---2
List<Customer>customers=GetCustomerList();
List<Product>products=GetProductList();
var customerNames=from c in customers
select c.CompanyName;
var productNames=from p in products
select p.ProductName;
var allNames=customerNames.Concat(productNames);
Console.WriteLine("Customer and product names:");
foreach(var n in allNames){
Console.WriteLine(n);
}
SequenceEqual--1
var wordA=new string[]{ "cherry", "apple", "blueberry"};
var wordB=new string[]{"cherry", "apple", "blueberry"};
bool match=wordsA.SequenceEqual(wordsB);
Console.WriteLine("The sequences match: {0} ",match);
SequenceEqual--2
var wordsA=new string[]{"cherry", "apple", "blueberry"};
var wordsB=new string[]{"apple","blueberry","cherry"};
bool match=wordsA.SequenceEqual(wordsB);
Console.WriteLine("The sequences match:{0}", match);
List集合Group by 查询
var groupList=chRCheckConfirmList.GroupBy(x=>new {x.CompanyId, x.Type, x.ChRCheckItemConfigId}).select(group=>new { Keys=group.Key, TotalScore=group.Sum(p=>p.Score)})
Asp.netMVC模型的更多相关文章
- .NET/ASP.NETMVC 大型站点架构设计—迁移Model元数据设置项(自定义元数据提供程序)
阅读目录: 1.需求背景介绍(Model元数据设置项应该与View绑定而非ViewModel) 1.1.确定问题域范围(可以使用DSL管理问题域前提是锁定领域模型) 2.迁移ViewModel设置到外 ...
- .NET/ASP.NETMVC 深入剖析 Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(三)
阅读目录: 7.HtmlHelper.HtmlHelper<T>中的ViewModel的类型推断 8.控制ViewModel中的某个属性的呈现(使用PartialView部分视图细粒度控制 ...
- .NET/ASP.NETMVC Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(一)
.NET/ASP.NETMVC Model元数据.HtmlHelper.自定义模板.模板的装饰者模式(一) 阅读目录: 1.开篇介绍 2.Model与View的使用关系(数据上下文DataContex ...
- WCF、WebAPI、WCFREST和Web服务的差异 ASP.NETMVC和ASP.NETWebAPI的差异
WCF.WebAPI.WCFREST和Web服务的差异: Web服务 它是基于SOAP和XML的形式返回数据. 它仅支持HTTP协议. 它是开放源,但是不消耗任何客户端可以同时理解XML. 它可以仅在 ...
- 一步一步搭框架(asp.netmvc+easyui+sqlserver)-03
一步一步搭框架(asp.netmvc+easyui+sqlserver)-03 我们期望简洁的后台代码,如下: using System; using System.Collections.Gener ...
- 一步一步搭框架(asp.netmvc+easyui+sqlserver)-02
一步一步搭框架(asp.netmvc+easyui+sqlserver)-02 我们期望简洁带前台代码,如下: <table id="dataGrid" class=&quo ...
- 一步一步搭框架(asp.netmvc+easyui+sqlserver)-01
一步一步搭框架(asp.netmvc+easyui+sqlserver)-01 要搭建的框架是企业级开发框架,适用用企业管理信息系统的开发,如:OA.HR等 1.框架名称:sampleFrame. 2 ...
- Winserver2008R2 .netframework4.5 asp.netmvc 访问出现的是文件列表。
Winserver2008R2 .netframework4.5 asp.netmvc 访问出现的是文件列表,服务器需要安装如下的补丁,才可正常访问. http://www.microsoft.com ...
- 利用Advanced Installer将asp.netMVC连同IIS服务和mysql数据库一块打包成exe安装包
因为业务需要,项目中需要把asp.netmvc项目打包成exe安装程序给客户,让客户直接可以点下一步下一步安装部署web程序,并且同时要将IIS服务和mysql一同安装到服务器上,因为客户的电脑可能是 ...
随机推荐
- 3.JavaScript-语法、关键保留字及变量
语法构成区分大小写标识符注释直接量字面量literal关键字保留字变量语法构成JavaScript 的语言核心 ECMAScript. 区分大小写ECMAScript 中的一切,包括变量.函数名和操作 ...
- W3C 代码标准规范
W3C通过设立领域(Domains)和标准计划(Activities)来组织W3C的标准活动,围绕每个标准计划,会设立相关的W3C工作组织(包括工作组.社区组.商务组等).W3C会根据产业界的标准需求 ...
- 获取元素CSS样式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- FineReport数据库连接(oracle+plsql)(1)
一. 数据库建表 数据库是Oracle12c,工具是plsql.具体操作百度即可,此处不赘述.(图1) 图1 二. FineReport中建立数据库连接 在上方选项卡中单击服务器,选择定义数据连接 ...
- MIUI12系统怎么样开启Root超级权限的流程
MIUI12系统能有啥方法开启root超级权限?各位都清楚,Android机器有root超级权限,如果手机开启root相关权限,可以实现更好的功能,举例子,各位公司的营销部门,使用某些营销软件都需要在 ...
- C++ 子类继承父类纯虚函数、虚函数和普通函数的区别
C++三大特性:封装.继承.多态,今天给大家好好说说继承的奥妙 1.虚函数: C++的虚函数主要作用是“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现.子类可以重写父类的虚函数实现子类 ...
- 工具资源系列之给虚拟机装个centos
前文我们已经讲解了如何在 mac 系统上安装虚拟机软件,这节我们接着讲解如何利用虚拟机安装 centos 镜像. 安装镜像的大致步骤基本相同,只不过是配置项略显不同而已,如果需要安装其他系统镜像,请参 ...
- DVWA 黑客攻防演练(十)反射型 XSS 攻击 Reflected Cross Site Scripting
XSS (Cross-site scripting) 攻击,为和 CSS 有所区分,所以叫 XSS.又是一种防不胜防的攻击,应该算是一种 "HTML注入攻击",原本开发者想的是显示 ...
- Oracle dblink的连接模式的关系测试总结
这篇主要介绍一下database link由于连接数据库的方式不同遇到的一些问题,我们知道连接ORACLE服务器的模式一般有两种方式:专用服务器连接(dedicated server)和共享服务器连接 ...
- 电梯调度编写(oo-java编程)
第二单元的问题是写一个关于电梯调度的程序. 需要模拟一个多线程实时电梯系统,从标准输入中输入请求信息,程序进行接收和处理,模拟电梯运行,将必要的运行信息通过输出接口进行输出. 主要锻炼学生的多线程程序 ...