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 删除一条数据

相关推荐
zzzzzz3107 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
大树8811 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
小宇宙Zz11 天前
Maven依赖冲突
java·服务器·maven
古城小栈11 天前
Unix 与 Linux 异同小叙
linux·服务器·unix
程序猿阿伟11 天前
《Chrome离线扩展安装的底层逻辑与场景落地指南》
服务器·网络·chrome
凡人叶枫11 天前
Effective C++ 条款42:了解 typename 的双重意义
java·linux·服务器·c++
AC赳赳老秦11 天前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
java_cj11 天前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
lsyeei11 天前
linux 系统目录详解
linux·运维·服务器
森G11 天前
75、服务器源码解析---------云视频服务项目
linux·服务器·网络·c++·qt