码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C# 根据前台传入实体名称,动态查询数据


    前言:

    项目中时不时遇到查字典表等数据,只需要返回数据,不需要写其他业务,每个字典表可能都需要写一个接口给前端调用,比较麻烦,所以采用下面这种方式,前端只需传入实体名称即可,例如:SysUser

    1、获取实体类型

    var entityType=Assembly.Load("XXX.Entity").GetTypes().Where(a =>a.Name == entityName).FirstOrDefault();
    
    如果需要加载多个类库(以下是其中一种方式)
    1、先获取DBContext里面的对象来匹配实体名称得到他的命名空间
    var name = DBContext.Model.GetEntityTypes().Where(a => a.ClrType.Name == "传入的实体名称").Select(a => a.ClrType.Namespace).FirstOrDefault();
    
    2、根据命名空间匹配到程序集
    var assemblyName = AppDomain.CurrentDomain.GetAssemblies().Where(a => a.FullName.Contains(name)).Select(a => a.FullName).FirstOrDefault();
    
    3、获取实体类型
    var entityType = Assembly.Load(assemblyName).GetTypes().Where(a => a.Name == "传入的实体名称").FirstOrDefault();
    

    2、创建动态仓储

    var repositoryType = typeof(Repository<>).MakeGenericType(entityType);//Repository<> 一般项目会封装仓储层放一些CRUD的公共方法
    var repository = Activator.CreateInstance(repositoryType, DBContext);
    var queryMethod = repositoryType.GetMethod("GetList"); //这里写需要调用的方法名称
    

    3、设置查询参数

    1、拼接lambda
    var parameterExpression=Expression.Parameter(entityType,"x");
    var propertyExpression = Expression.Property(parameterExpression, "字段名称");
    var constantExpression = Expression.Constant(ConvertFieldValue("字段的值", propertyExpression.Type));
    var equalExpression = Expression.Equal(propertyExpression,constantExpression);
    var lambdaExpression = Expression.Lambda(equalExpression, parameterExpression);
    
    private object ConvertFieldValue(string fieldValue, Type type)
    {
     		    if (type == typeof(DateTime))
               {
                   return DateTime.ParseExact(fieldValue, "dd/MM/yyyy HH:mm:ss",CultureInfo.InvariantCulture);
               }
               else if (type == typeof(bool))
               {
                   return Convert.ToBoolean(fieldValue);
               }
               else if (type == typeof(int))
               {
                   return Convert.ToInt32(fieldValue);
               }
               else if (type == typeof(long))
               {
                   return Convert.ToInt64(fieldValue);
               }
               else
               {
                   return fieldValue;
               }
    }
    
    2、设置参数
    //获取参数列表
    var parameters = queryMethod.GetParameters();
    var arguments = new List();
    for (int i = 0; i < parameters.Length; i++)
    {
       if (i == 0)
       {
          //如果不需要根据条件查询可以直接设置为默认值
          arguments.Add(lambdaExpression); 
       }
       else
       {
          //设置其他参数为默认值
          arguments.Add(Missing.Value);
       }
    }
    
    
    

    4、调用方法

    var list = queryMethod.Invoke(repository, arguments.ToArray());
    

    结尾

    以上就是所有实现的代码,如果有更好的实现方式,可以在评论区留言,谢谢大家

  • 相关阅读:
    两种解法解决LCR 008. 长度最小的子数组【C++】
    STM32内部Flash的使用
    systemverilog学习 ---随机化(2)
    JDK21下载和安装
    Excel VSTO开发2 -建立Excel VSTO项目
    从统计语言模型到预训练语言模型---预训练语言模型(BERT,GPT,BART系列)
    【面经】什么是回表?
    JVM学习总结笔记2
    mac Network: use --host to expose
    基于Java的宠物医院管理系统设计与实现(源码+lw+部署文档+讲解等)
  • 原文地址:https://www.cnblogs.com/xrxfirst/p/17314670.html
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号