RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 720655
Accepted
epsilon
epsilon
Asked:2020-09-20 11:48:33 +0000 UTC2020-09-20 11:48:33 +0000 UTC 2020-09-20 11:48:33 +0000 UTC

c#中如何保存数据

  • 772

如何在程序中保存数据?例如,如果我有一个控制台应用程序,我要计算我的预算,每次打开程序时,我都会从我的预算中增加或减少资金。

c#
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    Casper
    2020-09-20T13:27:14Z2020-09-20T13:27:14Z

    首先,可以尝试在 XML 中进行序列化。提供了完整的代码示例。

    using System;
    using System.IO;
    using System.Xml.Serialization;
    
    namespace ConsoleApp1
    {
        class Program
        {
            static void Main(string[] args)
            {
                //string directory = Path.Combine(
                //    Environment.GetFolderPath(Environment.SpecialFolder.LocalApplicationData), "ProgramName");
                string directory = Path.Combine("D:\\", "ProgramName");
                string file = Path.Combine(directory, "data.xml");
    
                Data data = new Data
                {
                    Amount = 150m
                };
    
                Display(data, "Исходный вариант");
                try
                {
                    if (!Directory.Exists(directory))
                    {
                        Directory.CreateDirectory(directory);
                    }
                    Serializer.SaveToXml(file, data);
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex);
                }
    
                // Как будто читаем где-то в другом месте программы и не сразу же после записи
                // -----------------------------
                try
                {
                    Data fromFile = null;
                    if (File.Exists(file))
                    {
                        fromFile = Serializer.LoadXml<Data>(file);
                    }
                    else
                    {
                        fromFile = new Data();
                    }
    
                    Display(fromFile, "Прочитанный из файла");
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex);
                }
    
                Console.ReadKey();
            }
    
            private static void Display(Data data, string message)
            {
                Console.WriteLine(message + ". Amount: {0}", data.Amount);
            }
        }
    
        public class Data
        {
            public decimal Amount { get; set; }
        }
    
        public static class Serializer
        {
            public static void SaveToXml<T>(String fileName, T serializableObject)
            {
                XmlSerializer serializer = new XmlSerializer(typeof(T));
                using (TextWriter textWriter = new StreamWriter(fileName))
                {
                    serializer.Serialize(textWriter, serializableObject);
                }
            }
    
            public static T LoadXml<T>(String fileName)
            {
                XmlSerializer serializer = new XmlSerializer(typeof(T));
                using (TextReader textReader = new StreamReader(fileName))
                {
                    return (T)serializer.Deserialize(textReader);
                }
            }
        }
    }
    
    • 0
  2. Garrus_En
    2020-09-20T13:34:50Z2020-09-20T13:34:50Z

    有很多方法,但我认为最简单的方法是使用 EntityFramework 和 Code First 方法。

    CodeFirst 很方便,因为您不需要自己创建数据库,它会在您第一次进入程序时自动创建,然后您将使用它。

    创建一个类来处理预算。所有方法和必填字段(资金数量、资金操作、操作日期、描述)

    创建一个项目,通过nuget包连接EF。

    接下来,我们创建一个用于处理预算的类。在我的例子中,像这样

    class BudgetUnit
    {
        // Для работы с БД имя одного из полей должно заканчиваться на "id"
        public int Id { get; set; }
        public int changeInAmount { get; set; }
        public DateTime dt { get; set; }
        public string description { get; set; }
    
        // Также необходимо наличие пустого конструктора
        public BudgetUnit()
        { }        
    
        // Конструктор опционально
        public BudgetUnit(int changeInAmount, string description)
        {
           this.changeInAmount = changeInAmount;
           this.description = description;
    
           dt = DateTime.Now;
        }
    }
    

    接下来,要使用数据库,您需要创建一个上下文类,您可以阅读它,例如,这里:https ://msdn.microsoft.com/ru-ru/library/system.data.entity.dbcontext (v=vs.113).aspx


    我得到了这样的东西:

    using System.Data.Entity;
    
    namespace Budget
    {
      class BudgetUnitContext : DbContext
      {
        // Пустой конструктор. "DbConnection" - имя соединения настроим чуть 
        // ниже. 
        public BudgetUnitContext()
          : base("DbConnection")
        { }
    
        public DbSet<BudgetUnit> Units { get; set; }
      }
    }
    

    接下来,你需要去 App.config 那里找到结束标签

    </ConfigSections> 
    

    并在其后添加一个名为“DbConnection”的连接字符串:

    <connectionStrings>
        <add name="DBConnection" connectionString="data source=
        (localdb)\MSSQLLocalDB;Initial Catalog=userstore.mdf;Integrated 
        Security=True;"
        providerName="System.Data.SqlClient"/>
    </connectionStrings> 
    

    实际上,这就是将数据保存到数据库所需的全部内容。它仍然在程序中使用生成的机制:

    static void Main(string[] args)
    {
    
      // Внесение данных
      using (BudgetUnitContext db = new BudgetUnitContext())
      {
        BudgetUnit bu1 = new BudgetUnit(35000, "Аванс");
        BudgetUnit bu2 = new BudgetUnit(15000, "Сосед вернул долг");
        BudgetUnit bu3 = new BudgetUnit(-12000, "Покупка пароварки");
    
        db.Units.Add(bu1);
        db.Units.Add(bu2);
        db.Units.Add(bu3);
    
        db.SaveChanges();
        Console.WriteLine("Объекты добавлены");
    
        // Можно получать данные в этом же блоке, но для наглядности вынесу в отдельный
      }
    
      // Получение данных
      using (BudgetUnitContext db = new BudgetUnitContext())
      {
        var units = db.Units;
        Console.WriteLine("Список объектов");
        int money = 0;
        foreach (BudgetUnit u in units)
        {
          money += u.changeInAmount;
          Console.WriteLine("{0}: {1}, {2} - {3}, остаток средств {4}", u.Id, 
              u.dt, u.changeInAmount, u.description, money);
        }
      }
    }
    
    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5