003.LINQ在WEB API中的应用

LINQ是什么

语言整合查询(全名:Language Integrated Query )

用途

就如全名所代表的意思,各种不同的查询对象,通常都会有各自的语法,但如果每种都要学,就会花很多时间,而且少用的就学的不精,也很容易忘记

因此今天发明了LINQ,只要学习一种LINQ语法,我就可以查询各种不同的对象,大幅减少学习成本与方便性

例如:

  1. LINQ to Objects:使用LINQ 语法查询Object
  2. LINQ to SQL:使用LINQ 语法查询资料库资料
  3. LINQ to XML:使用LINQ 语法查询XML资料

等等还有各种的常见的查询对象,LINQ都有其对应的支援

这可以很有效的解决,今天特定专案刚好要查询一个很冷门的资料类型对象,此时你不用特地去学该对象的查询语法,只需要使用LINQ就可以简单查询

那背后当然是LINQ会帮你转换成对应对象的语法进行查询

你也不会事后过了很久之后要维护,还需要重新复习该冷门资料的查询语法

所以在C#这边LINQ可以说是必学的一项技术

另外这边也建议如果还在用SQL写在程式码中的人,赶快换成LINQ,不仅可以让你的程式更优雅,可以侦错,也可以有效的避免注入攻击(这之后会示范)

当然,在某些例外情况,还是有自己写SQL的必要,不过就通常的查询、新增、修改、删除用LINQ就绰绰有余了

写法

LINQ这边主要有两种不同的写法,但得到的结果是一样的

1.宣告式(Declarative)

学过SQL语法的人,可能会觉得有点像SQL叙述句的感觉,譬如说我今天要查一个新闻标题为"凯哥写程式"的新闻,可以这么写

cs 复制代码
var result = from a in NewsList
             where a.Title == "凱哥寫程式"
             select a;

其实看起来可读性相当的高,就是从NewsList中,找Title为凯哥写程式的那一笔出来

2.编程式(Imperative):(lambda)

cs 复制代码
var result = NewsList.Where(a => a.Title == "凱哥寫程式");

看起来就比较抽象一点,不过这个范例比较简单,所以还算看得清楚,但就观看性而言,变得更简洁

至于要用哪一种,其实就看个人喜好

四.以下就来简单示范一下查询、新增、修改、删除的LINQ怎么写

1.新建一个Models文件夹用于存放数据模型

2.在Models文件下新建数据类News.cs

cs 复制代码
namespace Esp32_Server.Models
{
    public class News
    {
        public int NewsId { get; set; }
        public string Title { get; set; }
        public string Content { get; set; }
    }
}

3.新将一个控制器LINQ_TEST用于测试

cs 复制代码
using Microsoft.AspNetCore.Mvc;
using Esp32_Server.Models;

namespace Esp32_Server.Controllers
{
    [Route("api/[controller]")]
    [ApiController]
    public class LINQ_TEST : ControllerBase
    {
        private static readonly List<News> NewsList = new List<News>
        {
            new News{NewsId=1,Title="陈佳鹏",Content="大帅哥"},
            new News{NewsId=2,Title="高小敏",Content="大美女"},
            new News{NewsId=3,Title="刘罗锅",Content="老男人"},
            new News{NewsId=4,Title="小米",Content="天堂车"}
        };

        //IEnumerable<T> 是一个接口,表示一个可枚举的集合。它提供了一个GetEnumerator方法,可以返回一个IEnumerator<T>对象,用于迭代集合中的元素。


        //查詢全部新聞
        [HttpGet]
        public IEnumerable<News> Get()
        {
            return NewsList;
        }

        //查詢指定新聞
        [HttpGet("{id}")]
        public IEnumerable<News> Get(int id)
        {
            var result = from a in NewsList
                         where a.NewsId == id
                         select a;

            result = NewsList.Where(a => a.NewsId == id);

            return result;
        }

        //新增一筆新聞
        [HttpPost]
        public IEnumerable<News> Post(News value)
        {
            NewsList.Add(value);//new了一个数据类对象添加给集合

            return NewsList;
        }

        //修改一筆新聞
        [HttpPut("{id}")]
        public IEnumerable<News> Put(int id, News value)
        {
            var update = (from a in NewsList
                          where a.NewsId == id
                          select a).SingleOrDefault();

            update = NewsList.SingleOrDefault(a => a.NewsId == id);

            if (update != null)
            {
                update.Title = value.Title;
                update.Content = value.Content;
            }

            return NewsList;
        }

        //刪除一筆新聞
        [HttpDelete("{id}")]
        public IEnumerable<News> Delete(int id)
        {
            var delete = (from a in NewsList
                          where a.NewsId == id
                          select a).SingleOrDefault();

            delete = NewsList.SingleOrDefault(a => a.NewsId == id);

            if (delete != null)
            {
                NewsList.Remove(delete);
            }

            return NewsList;
        }
    }
}

4.增删改查示例

4.1.get所有

4.2 GET指定id

4.3. POST 注册增加一条数据

4.4 PUT 修改一条数据

4.5 Delete 删除一条数据

相关推荐
周小码2 小时前
10分钟搭建私有Git服务器:Soft Serve实战
运维·服务器·git
知无不研2 小时前
对套接字的深入理解
linux·服务器·网络·c++·socket·网络套接字
ZStack开发者社区3 小时前
VMware替代:从POC通过到生产可用,差距在哪里
服务器·云计算·gpu算力
AI创界者4 小时前
运维进阶:如何使用 Medusa 进行企业内部服务器密码合规性审计?
运维·服务器
|_⊙5 小时前
Linux 信号
运维·服务器·前端
快乐肚皮6 小时前
【无标题】
服务器·网络·tcp/ip
似水এ᭄往昔7 小时前
【Linux系统编程】--进程概念
linux·运维·服务器
小徐敲java7 小时前
Linux读取串口实时数据
linux·运维·服务器
zhangfeng11338 小时前
车载gpu 飞地 只保存密钥 不保存 权重 Orin确实有TEE安全飞地(TSEC/OP-TEE)
服务器·网络·人工智能·安全·transformer·芯片