基于Stylet框架的SQLite数据库增删改查的WPF程序

基于Stylet框架的SQLite数据库增删改查的WPF程序

项目结构

在这里插入图片描述

重要代码部分(个人遇见的问题)

 public ObservableCollection<SqlMainModel> sqlmainmodels { get; set; } = new ObservableCollection<SqlMainModel>();

使用ObservableCollection数组来作为Datagrid的数据源,ObservableCollection可以自动更新数据 实时反馈到界面上,不需要手动刷新,直接绑定即可

<DataGridTextColumn 
                    Header="性别" 
                    Binding="{Binding Gender, Converter={StaticResource converterToGender}}"/>
    public class ConverterToGender : IValueConverter
    {
        public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
        {
            if (value != null && (Int32)value == 1)
            {
                return "男";
            }
            else if (value != null && (Int32)value == 2)
            {
                return "女";
            }
            return "未知";
        }

        public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
        {
            if (value != null && value.ToString() == "男")
            {
                return 1;
            }
            else if (value != null && value.ToString() == "女")
            {
                return 2;
            }
            return 0;
        }
    }

编写值转换器来显示自己想要的数据 而不是显示原始数据

       <Button Content="{Binding btnContent}"
                    Height="35" Width="120" FontSize="16"
                    s:View.ActionTarget="{StaticResource SqlChangeViewModel}"
                    Click="{s:Action btn_Click}" />

s:View.ActionTarget="{StaticResource SqlChangeViewModel}"可以指定接收按钮数据的cs文件是哪个,当不同页面的同一个按钮事件时 可以更少的编写代码来实现功能的复用

 public SqlChangeView()
        {
            InitializeComponent();
            this.DataContext = SqlChangeViewModel.sqlchangemodel;
        }

当前端View与后端ViewModel进行数据源绑定时,如果数据绑定成功但是数据无法更新传递,则有可能是数据上下文的数据源并不是同一个数据源,这里使用的是静态数据源,也可以使用单例模式创建数据源,避免这个问题

程序源码

https://download.csdn.net/download/qq1084517825/85449463

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF(Windows Presentation Foundation)是一种用于创建Windows应用程序的UI框架,而Stylet是一个轻量级的MVVM(Model-View-ViewModel)框架,提供了一种组织和管理应用程序代码的方式。SQLite是一种嵌入式数据库引擎,可以用于存储和管理数据。 在基于Stylet框架WPF应用程序中使用SQLite进行增删改查操作,可以按照以下步骤进行: 1. 添加SQLite NuGet包:在Visual Studio中,右击项目名称,选择"管理NuGet程序包"。在NuGet包管理器中搜索并安装SQLite包。 2. 创建SQLite数据库连接:在代码中使用SQLiteConnection对象创建与数据库的连接。可以指定数据库文件的路径,如果数据库不存在,会自动创建。 3. 定义表结构和数据模型:使用SQLite提供的SQL语句在数据库中创建表,并定义与之对应的数据模型类。可以使用类属性来映射表的字段。 4. 实现增删改查功能:在ViewModel中,使用SQLiteConnection对象进行增删改查操作。可以编写SQL语句,也可以使用SQLite提供的ORM工具(如Dapper)进行操作。 示例代码如下: ```csharp using Stylet; using Dapper; using System.Collections.Generic; using System.Data.SQLite; using System.Linq; namespace MyNamespace { public class MyViewModel : Screen { private SQLiteConnection connection; // 构造函数中初始化SQLite连接 public MyViewModel() { string databasePath = "path_to_your_database_file"; connection = new SQLiteConnection($"Data Source={databasePath};Version=3;"); } // 查询操作 public IEnumerable<MyDataModel> GetMyData() { string sql = "SELECT * FROM MyTable"; return connection.Query<MyDataModel>(sql); } // 插入操作 public void InsertData(MyDataModel data) { string sql = "INSERT INTO MyTable (Name, Age) VALUES (@Name, @Age)"; connection.Execute(sql, data); } // 更新操作 public void UpdateData(MyDataModel data) { string sql = "UPDATE MyTable SET Name = @Name, Age = @Age WHERE Id = @Id"; connection.Execute(sql, data); } // 删除操作 public void DeleteData(int id) { string sql = "DELETE FROM MyTable WHERE Id = @Id"; connection.Execute(sql, new { Id = id }); } } public class MyDataModel { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } } ``` 以上是基于Stylet框架WPF应用程序使用SQLite进行增删改查操作的简单示例。根据实际需求,可以根据这个示例进行扩展和修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值