草庐IT

C# - MySql - 将数据从 MySqlDataReader 转换为不同模型的最佳方式

coder 2023-10-20 原文

我在处理和修复实现 MySql 代码的现有代码库的错误方面有经验,但在我的新工作中必须从头开始设计一个新程序。我不确定将数据从 MySqlDataReader 返回到我的自定义模型的最佳方式是什么。请指教!

这是我的,

文件夹结构:

  • 模型(文件夹)

    1. 元数据.cs
    2. 用户.cs
  • MySqlDb.cs

Metadata.cs:从 metadata 表中重新发送数据

public class Metadata
{
    public int Id { get; set; }
    public string Title { get; set; }
    public string Sku { get; set; }
    public bool IsLive { get; set; }
}

User.cs:表示来自user

的数据
public class User
{
    public int Id { get; set; }
    public string UserName { get; set; }
    public int Age { get; set; }
    public string Address { get; set; }
}

MySqlDb.cs

using MySql.Data;
using MySql.Data.MySqlClient;
public class MySqlDb
{
    public MySqlConnection Connection { get; set;} 
    public MySqlDb(string connectionString)
    {
        Connection = new MySqlConnection(connectionString);
    }

    public List<Metadata> RunSelectQueryForMetadata(string query)
    {
        var rdr = new MySqlCommand(query, Connection).ExecuteReader();
        var metadata = new List<Metadata>();
        using (rdr)
        {
            while(rdr.Read())
            {
                metadata.Add(
                    new Metadata {
                        Id = rdr["id"],
                        Title = rdr["title"],
                        Sku = rdr["sku"],
                        IsLive = rdr["islive"],
                    });
            } // while
        } // using 

        return metadata;

    } // public void RunSelectQuery(string query)

} // public class MySqlDb

如果我尝试获取用户数据,我正在考虑编写另一种方法 (RunSelectQueryForUsers)。我想避免为不同的表编写不同的方法。我不确定如何使用一种方法从具有不同数据结构的不同表中检索数据并将它们转换为我想要的模型。

非常感谢任何帮助!!

最佳答案

一种方法是使用像 Dapper 这样的微型 orm这是一个为 .Net 构建的简单对象映射器。 Dapper 通过提供有用的扩展方法来查询您的数据库来扩展 IDbConnection。

在您当前的方法中实现 dapper 的示例:

public List<Metadata> RunSelectQueryForMetadata(string query)
{
    var metadata = new List<Metadata>();
    try // implement proper error handling
    {
        Connection.Open();
        metadata = Connection.Query<Metadata>(query).ToList();
        Connection.Close();
    }
    catch(Exception ex)
    {
        // error here
    }
    return metadata;
}

一些有用的链接:

将其转换为通用方法:(现在未测试)

public List<T> RunSelectQuery<T>(string query)
{
    try // implement proper error handling
    {
        Connection.Open();
        metadata = Connection.Query<T>(query).ToList();
        Connection.Close();
    }
    catch(Exception ex)
    {
        // error here
    }
    return metadata;
}

并使用下面这样的东西:

List<Metadata> myMetadata = RunSelectQuery<Metadata>(query);

关于C# - MySql - 将数据从 MySqlDataReader 转换为不同模型的最佳方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49020274/

有关C# - MySql - 将数据从 MySqlDataReader 转换为不同模型的最佳方式的更多相关文章

  1. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  2. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  3. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  4. ruby - 使用 ruby​​ 将 HTML 转换为纯文本并维护结构/格式 - 2

    我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h

  5. ruby - 如何以所有可能的方式将字符串拆分为长度最多为 3 的连续子字符串? - 2

    我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123

  6. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  7. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  8. ruby-on-rails - Rails - 一个 View 中的多个模型 - 2

    我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何

  9. ruby - 将散列转换为嵌套散列 - 2

    这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[

  10. ruby-on-rails - 在混合/模块中覆盖模型的属性访问器 - 2

    我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah

随机推荐