轻轻的扩展了一下IEnumerable<T>
今天用EF写东西玩,觉得IEnumerable里面除了where()、select(),是不是能添加点其他方法呢。
想做就做,F12到方法定义:
public static IEnumerable<TSource> Where<TSource>(this IEnumerable<TSource> source, Func<TSource, bool> predicate)
我似乎知道该怎么做了。现在要实现一个功能,就是要把一个List<Hero>中HeroId小于5的对象,性别显示成女,武力显示成100(吕布不敌女汉子);
public class Hero : DateBaseModelBase
{
[Key]
[DBKey]
[IdentityKey]
public int HeroId { get; set; } public string Name { get; set; } public string Sex { get; set; } public int XiangXing { get; set; } public int WuLi { get; set; } public int ZhiLi { get; set; }
}
给IEnumerable<T>扩展一个DoSomeThing方法。
public static IEnumerable<T> DoSomething<T>(this IEnumerable<T> list, Action<T> exp)
{
foreach (var model in list)
{
exp(model);
}
return list;
} public static IEnumerable<T> DoSomething<T>(this IEnumerable<T> list, Func<T, bool> exp1, Action<T> exp2)
{
foreach (var model in list)
{
if (exp1(model))
{
exp2(model);
} }
return list;
}
然后试着用EF读取数据库
private void button8_Click(object sender, EventArgs e)
{
MyDB db = new MyDB(); var list = db.Hero.Take().DoSomething(a => a.HeroId < , b => { b.Sex = "女"; b.WuLi = ; }).ToList(); //MessageBox.Show(list.ToJson());
dgv1.DataSource = list;
}
最后得到结果
| 2 | 韩信 | 女 | 85 | 100 | 92 | 100 | 73 | 76 | 姓名:韩信 统帅:100 武力:100 智力:92 政治:73 魅力:76 | |
| 3 | 白起 | 女 | 145 | 100 | 70 | 100 | 3 | 39 | 姓名:白起 统帅:100 武力:100 智力:70 政治:3 魅力:39 | |
| 4 | 楽毅 | 女 | 75 | 100 | 92 | 98 | 91 | 92 | 姓名:楽毅 统帅:98 武力:100 智力:92 政治:91 魅力:92 | |
| 5 | 司马懿 | 男 | 31 | 63 | 96 | 98 | 93 | 87 | 姓名:司马懿 统帅:98 武力:63 智力:96 政治:93 魅力:87 | |
| 6 | 周瑜 | 男 | 125 | 71 | 96 | 97 | 86 | 93 | 姓名:周瑜 统帅:97 武力:71 智力:96 政治:86 魅力:93 | |
| 7 | 吴起 | 男 | 25 | 70 | 95 | 97 | 96 | 67 | 姓名:吴起 统帅:97 武力:70 智力:95 政治:96 魅力:67 | |
| 8 | 吕尚 | 男 | 10 | 50 | 100 | 97 | 96 | 90 | 姓名:吕尚 统帅:97 武力:50 智力:100 政治:96 魅力:90 | |
| 9 | 陆逊 | 男 | 122 | 69 | 95 | 96 | 87 | 90 | 姓名:陆逊 统帅:96 武力:69 智力:95 政治:87 魅力:90 | |
| 10 | 曹操 | 男 | 25 | 72 | 91 | 96 | 94 | 96 | 姓名:曹操 统帅:96 武力:72 智力:91 政治:94 魅力:96 | |
| 11 | 岳飞 | 男 | 75 | 91 | 78 | 95 | 31 | 98 | 姓名:岳飞 统帅:95 武力:91 智力:78 政治:31 魅力:98 |
看到前三行没有,成功了。哦也,然后看看生成的SQL代码到底是什么
SELECT TOP (10)
[c].[HeroId] AS [HeroId],
[c].[Name] AS [Name],
[c].[Sex] AS [Sex],
[c].[XiangXing] AS [XiangXing],
[c].[WuLi] AS [WuLi],
[c].[ZhiLi] AS [ZhiLi],
[c].[TongShuai] AS [TongShuai],
[c].[ZhengZhi] AS [ZhengZhi],
[c].[MeiLi] AS [MeiLi]
FROM [dbo].[Hero] AS [c]
也就是说并没有想象的那么智能。这里的扩展方法并不能代替where()的作用。
有时候我们会遇到遮掩的需求,需要对取到的属性做一下修饰,一般都是用Select()方法,但是他返回的就不是原本的类型了。这个时候可以尝试使用这种方式。我又为自己找到了一个新的偷懒方法。
楼主技术不行,不喜勿喷,欢迎高手指点。
轻轻的扩展了一下IEnumerable<T>的更多相关文章
- 扩展方法IEnumerable<T>转换为IList<SelectListItem> ,提供@Html.DropDownList使用
由于在MVC中经常会使用到@Html.DropDownList方法,而该方法接收的是List<SelectListItem> 参数,因此就想着写一个扩展方法,直接把IEnumerable转 ...
- 23.C#Queryable的扩展方法(十二章12.1-12.2)
今天要写的知识还真心有点绕呢,对于第一节的内容,其实是把原先在内存中的数据源,换成了从数据库中提取出来的数据.从代码的使用方式上是一样的,直接跳过,来看看IEnumerable和IQueryable的 ...
- IEnumerable<T>转换为IList<SelectListItem>
扩展方法IEnumerable<T>转换为IList<SelectListItem> ,提供@Html.DropDownList使用 由于在MVC中经常会使用到@Html. ...
- 【细语】C#之扩展方法原理及其使用
1.写在前面 今天群里一个小伙伴问了这样一个问题,扩展方法与实例方法的执行顺序是什么样子的,谁先谁后(这个问题会在文章结尾回答).所以写了这边文章,力图从原理角度解释扩展方法及其使用. 以下为主要内容 ...
- C#3.0新特性:隐式类型、扩展方法、自动实现属性,对象/集合初始值设定、匿名类型、Lambda,Linq,表达式树、可选参数与命名参数
一.隐式类型var 从 Visual C# 3.0 开始,在方法范围中声明的变量可以具有隐式类型var.隐式类型可以替代任何类型,编译器自动推断类型. 1.var类型的局部变量必须赋予初始值,包括匿名 ...
- Java进击C#——应用开发之Linq和EF
本章简言 上一章笔者对于WinForm开发过程用到的几个知识点做了讲解.笔者们可以以此为开端进行学习.而本章我们来讲一个跟ORM思想有关的知识点.在讲之前让我们想一下关于JAVA的hibernate知 ...
- .NET面试题系列[13] - LINQ to Object
.NET面试题系列目录 名言警句 "C# 3.0所有特性的提出都是更好地为LINQ服务的" - Learning Hard LINQ是Language Integrated Que ...
- .NET面试题系列[12] - C# 3.0 LINQ的准备工作
"为了使LINQ能够正常工作,代码必须简化到它要求的程度." - Jon Skeet 为了提高园子中诸位兄弟的英语水平,我将重要的术语后面配备了对应的英文. .NET面试题系列目录 ...
- 《C#本质论》读书笔记(15)使用查询表达式的LINQ
15.1 查询表达式的概念 简单的查询表达式 private static void ShowContextualKeywords1() { IEnumerable<string> sel ...
随机推荐
- Eclipse最有用的快捷键
编辑 Ctrl+1 快速修复(最经典的快捷键,就不用多说了,可以解决很多问题,比如import类.try catch包围等) Ctrl+Shift+F 格式化当前代码 Ctrl+Shift+M 添加类 ...
- php 连接 mssql sql2008
摘要 sql server 2008 1.下载微软提供的dll 下载地址:http://www.microsoft.com/en-us/download/details.aspx?id=20098 p ...
- 看详细的tomcat报错信息
WEB-INF/classes目录下新建一个文件叫logging.properties handlers = org.apache.juli.FileHandler, java.util.loggin ...
- struts2语法--error页面如何捕获?
如果地址栏输入了不带后缀或者action为后缀, 不存在的页面跳转到error.jsp: struts.xml配置" <package name="default" ...
- 转 android学习—— context 和 getApplicationContext()
在android中常常会遇到与context有关的内容 浅论一下context : 在语句 AlertDialog.Builder builder = new AlertDialog.Builder( ...
- i2c的时钟延展问题(转)
源:http://blog.csdn.net/zyboy2000/article/details/7636769 结论: (即在模拟i2c主:在主设置SCL为高后,要超时判断SCL是否为高,再发后面的 ...
- 关于jdk环境变量配置成了1.6.0_39 32位jdk 的路径 cmd中java -version却还是显示 64位或者其他jdk 路径的解决方法
其实是c盘或者其他盘的 jdk 安装的太多了,把其他的都卸载掉就行了
- CentOS 单用户登录&命令行、图像界面
如何单用户登录: 这是一个很简单的问题,以前没重视,每次linux服务器无法正常启动时,都找应急盘,想偷懒,反而浪费了时间. 今天备忘如下: 1.系统启动时,按光标键调出GRUB引导菜单. 2.选定一 ...
- HDU 1251 统计难题(字典树计算前缀数量)
字典树应用,每个节点上对应的cnt是以它为前缀的单词的数量 #include<stdio.h> #include<string.h> struct trie { int cnt ...
- 如何在Android中添加系统服务
一,在frameworks/base/core/java/android/content/Context.java中添加 public static final String RADIO_SERVIC ...