zoukankan      html  css  js  c++  java
  • MVC里模型常用的一些操作

    学习也是做买卖,归根到底还是学习成本的问题。

    下面把微软集合类型的增删改查稍微罗列一下,大家看看它能带来的便利,和你要学的新东西,还有风险(纯粹的数据操作,不用框架,风险其实不大)相比,是否值得。来决定是跳过,还是了解,还是精研。(建议敲一遍了解一下,以后写的东西如果频繁遇到数据的小操作,可以回来翻翻,研究研究,多个选择)

    1、增删改查

     1 var a = new List<Person>();
     2             Person user;
     3             a.Add(new Person() { Name = "zs", Nl = 20 });
     4             a.Add(new Person() { Name = "ls", Nl = 18 });
     5             a.Add(new Person() { Name = "ww", Nl = 19 });
     6             user = (from x in a where x.Name == "zs" select x).Single();
     7             ////a.Remove(user);
     8             //user.Nl=25;
     9 
    10             foreach (var item in a)
    11             {
    12                 Console.WriteLine(item.Name + "	" + item.Nl);
    13 
    14             }
    15             Console.ReadKey();

    说明:

      (1)第6行括号里是一种微软筛选数据的语法,叫做Linq。Linq还是有点东西的,绝不像例子里写的那么简单。有关这种语法,可以自己搜着看看,了解一下。

      (2)single方法的作用是,从集合(由一条完全相同的记录重复构成)中转化出一条记录,有点像类型转换,从多条变一条。如果原集合含有多条不相同的数据,则报错。

      (3)第7行会删除查到的数据,第8行会修改查到的数据。如果是真正的数据模型,记得要用savechanges存入库。

      (4)批量删除可以用RemoveAll方法,和lambda表达式一起用。

      (5)批量修改可以用下面的代码:

    1 var guys = from x in a where x.Nl > 18 select x;
    2             foreach (var item in guys)
    3             {
    4                 item.Nl++;
    5             }

    2、不用Linq,这一系列有些扩展方法,比如:

          Where,Max,Select,Sum,Any,Average,All,Concat等

          都是针对IEnumerable的对象进行扩展的

          也就是说,只要实现了IEnumerable接口,就可以使用这些扩展方法(List和Dbset都实现了的)

          来看看这段代码:      

    List<int> arr = new List<int>() { 1, 2, 3, 4, 5, 6, 7 };
    var result = arr.Where(a => { return a > 3; }).Sum();
    Console.WriteLine(result);
    Console.ReadKey();

           这段代码中,用到了两个扩展方法。

          <1>

            Where扩展方法,需要传入一个Func<int,bool>类型的泛型委托

            这个泛型委托,需要一个int类型的输入参数和一个布尔类型的返回值

            我们直接把a => { return a > 3; }这个lambda表达式传递给了Where方法

            a就是int类型的输入参数,返回a是否大于3的结果。

          <2>

            Sum扩展方法计算了Where扩展方法返回的集合的和。

    另外的例子:

    var a = new List<Person>();
                a.Add(new Person() { Name = "zs", Nl = 200 });
                a.Add(new Person() { Name = "ls", Nl = 18 });
                a.Add(new Person() { Name = "ww", Nl = 19 });
                var result = a.Where(b => b.Nl > 18).Select(b=>b.Nl).Sum();//所有人18岁以上的人,年龄求和。
                Console.WriteLine(result);
                Console.WriteLine(a.Any(x => x.Nl < 20));// 如果集合中有任何一个元素满足该条件就返回true
                Console.WriteLine(a.Where(b => b.Nl > 18).All(x=>x.Nl < 20));// 如果集合中所有元素都满足该条件,返回true
                foreach (var item in a.Where(b => b.Nl > 18).Concat(a))//Concat用来连接两个集合
                {
                    Console.WriteLine(item.Name + "	" + item.Nl);
                } 
                Console.ReadKey();

    可以自己运行一下,看看效果。

    需要注意的是,any的用法以上面的注释为准,vs的提示(所有元素都满足条件才返回true)是错的。


    对于常见的数据库联合查询,如:
    表a
    xh,xm
    表b
    xh,nl
    对应的sql语句为:select a.xh,a.xm,b.nl from a,b where a.xh=b.xh
    利用c#的list也可以完成类似功能。
    基础类
    xsxm

    class Xsxm
        {
            public string Xh { get; set; }
            public string Xm { get; set; }
            public static IEnumerable<Xsxm> get_xsxms()
            {
                for (int i = 1; i <=5; i++)
                {
                    yield return new Xsxm() { Xh = "0" + i,Xm="a"+i };
                }
            }
        }

    xsnl:

    class Xsnl
        {
            public string Xh { get; set; }
            public int Nl { get; set; }
            public static IEnumerable<Xsnl> get_xsnls()
            {
                for (int i = 1; i <= 5; i++)
                {
                    yield return new Xsnl() { Xh = "0" + i,Nl=20 + i };
                }
            }
        }

    主程序:

    static void Main(string[] args)
            {
                var a =new List<Xsxm>(Xsxm.get_xsxms());
                var b =new List<Xsnl>(Xsnl.get_xsnls());
                a.ForEach(x => Console.WriteLine($"{x.Xh},{x.Xm},{b.Find(xx=>xx.Xh==x.Xh).Nl}"));
            }

     运行效果:

  • 相关阅读:
    js字符串使用占位符拼接
    C#解析json字符串总是多出双引号的原因分析及解决办法
    JS 正则验证字符串中是否含有数字
    不错的MVC文章
    Js 更换html同一父元素下子元素的位置
    团队任务个人博客--20160426
    《构建之法》阅读笔记3
    团队任务个人博客20160425
    团队任务个人博客20160424
    软件工程进度条-第八周
  • 原文地址:https://www.cnblogs.com/wanjinliu/p/11718994.html
Copyright © 2011-2022 走看看