WPF 实现可视化操作数据库的程序全解析
在软件开发中,实现对数据库的可视化操作能极大提升开发效率和用户体验。借助 WPF(Windows Presentation Foundation)强大的界面开发能力,我们可以打造出功能丰富、交互友好的数据库操作程序。本文将详细介绍如何使用 WPF 搭建一个可视化操作数据库的程序,帮助大家掌握这一实用的开发技巧。
一、前期准备
(一)开发环境搭建
确保你已经安装了 Visual Studio,这是开发 WPF 应用的主要工具。同时,根据你要操作的数据库类型,准备相应的数据库驱动。例如,若使用 SQL Server,需要安装 Microsoft.Data.SqlClient 库;若使用 MySQL,则需要安装 MySql.Data 库。
(二)数据库设计
在开始编写代码前,先设计好数据库结构。假设我们要创建一个简单的学生信息管理系统,数据库中至少包含一张名为 “Students” 的表,表结构如下:
| 字段名 | 数据类型 | 描述 |
| Id | int | 学生 ID,主键,自增长 |
| Name | nvarchar(50) | 学生姓名 |
| Age | int | 学生年龄 |
| Grade | nvarchar(10) | 学生年级 |
二、创建 WPF 项目
打开 Visual Studio,创建一个新的 WPF 应用项目。在项目创建向导中,为项目命名并选择合适的存储位置。创建完成后,项目结构中会包含App.xaml(应用程序的入口和资源定义文件)、MainWindow.xaml(主窗口文件,用于设计界面)以及MainWindow.xaml.cs(主窗口的代码后端文件,用于编写逻辑代码)。
三、连接数据库
在MainWindow.xaml.cs文件中,添加数据库连接代码。以 SQL Server 为例:
using Microsoft.Data.SqlClient;namespace WpfDatabaseApp{public partial class MainWindow : Window{private string connectionString = "Data Source=YOUR_SERVER_NAME;Initial Catalog=YOUR_DATABASE_NAME;User ID=YOUR_USERNAME;Password=YOUR_PASSWORD";public MainWindow(){InitializeComponent();LoadData();}private void LoadData(){using (SqlConnection connection = new SqlConnection(connectionString)){string query = "SELECT * FROM Students";SqlDataAdapter adapter = new SqlDataAdapter(query, connection);System.Data.DataTable dataTable = new System.Data.DataTable();adapter.Fill(dataTable);// 这里假设界面上有一个名为dataGrid的DataGrid控件,用于显示数据dataGrid.ItemsSource = dataTable.DefaultView;}}}}
上述代码中,connectionString定义了数据库连接字符串,LoadData方法用于从数据库中读取数据并填充到界面的DataGrid控件中。
四、数据展示与编辑
(一)数据展示
在MainWindow.xaml中,添加一个DataGrid控件用于展示数据:
<Grid><DataGrid x:Name="dataGrid" AutoGenerateColumns="True" Margin="10"></DataGrid></Grid>
AutoGenerateColumns="True"表示DataGrid会根据数据源自动生成列。
(二)数据编辑
为了实现数据编辑功能,我们需要在DataGrid中启用编辑模式,并处理数据更新操作。在MainWindow.xaml.cs中添加以下代码:
private void dataGrid_CellEditEnding(object sender, DataGridCellEditEndingEventArgs e){DataGrid dataGrid = sender as DataGrid;DataRowView rowView = dataGrid.SelectedItem as DataRowView;if (rowView!= null){using (SqlConnection connection = new SqlConnection(connectionString)){string updateQuery = "UPDATE Students SET Name = @Name, Age = @Age, Grade = @Grade WHERE Id = @Id";SqlCommand command = new SqlCommand(updateQuery, connection);command.Parameters.AddWithValue("@Name", rowView["Name"]);command.Parameters.AddWithValue("@Age", rowView["Age"]);command.Parameters.AddWithValue("@Grade", rowView["Grade"]);command.Parameters.AddWithValue("@Id", rowView["Id"]);connection.Open();command.ExecuteNonQuery();}}}
同时,在MainWindow.xaml中为DataGrid添加CellEditEnding事件绑定:
<DataGrid x:Name="dataGrid" AutoGenerateColumns="True" Margin="10" CellEditEnding="dataGrid_CellEditEnding"></DataGrid>
这样,当用户在DataGrid中编辑完数据并离开单元格时,数据会自动更新到数据库中。
五、添加数据与删除数据
(一)添加数据
在界面上添加一个 “添加” 按钮,在MainWindow.xaml中:
<Button Content="添加" Margin="10" Click="Button_Add_Click" />
在MainWindow.xaml.cs中实现按钮点击事件:
private void Button_Add_Click(object sender, RoutedEventArgs e){using (SqlConnection connection = new SqlConnection(connectionString)){string insertQuery = "INSERT INTO Students (Name, Age, Grade) VALUES (@Name, @Age, @Grade)";SqlCommand command = new SqlCommand(insertQuery, connection);command.Parameters.AddWithValue("@Name", "新学生"); // 这里可以替换为用户输入的值command.Parameters.AddWithValue("@Age", 18); // 这里可以替换为用户输入的值command.Parameters.AddWithValue("@Grade", "一年级"); // 这里可以替换为用户输入的值connection.Open();command.ExecuteNonQuery();LoadData(); // 重新加载数据,刷新界面}}
(二)删除数据
在界面上添加一个 “删除” 按钮,在MainWindow.xaml中:
<Button Content="删除" Margin="10" Click="Button_Delete_Click" />
在MainWindow.xaml.cs中实现按钮点击事件:
private void Button_Delete_Click(object sender, RoutedEventArgs e){DataGrid dataGrid = dataGrid;DataRowView rowView = dataGrid.SelectedItem as DataRowView;if (rowView!= null){using (SqlConnection connection = new SqlConnection(connectionString)){string deleteQuery = "DELETE FROM Students WHERE Id = @Id";SqlCommand command = new SqlCommand(deleteQuery, connection);command.Parameters.AddWithValue("@Id", rowView["Id"]);connection.Open();command.ExecuteNonQuery();LoadData(); // 重新加载数据,刷新界面}}}
六、总结
通过以上步骤,我们成功地使用 WPF 实现了一个可视化操作数据库的程序。从数据库连接、数据展示与编辑,到数据的添加和删除,每一步都充分利用了 WPF 的特性和数据库操作的基本原理。在实际项目中,还可以进一步优化界面设计、添加数据验证等功能,提升程序的实用性和稳定性。希望本文能为大家在 WPF 与数据库交互开发方面提供有益的参考,帮助大家快速掌握这一重要的开发技能。
相关文章:
WPF 实现可视化操作数据库的程序全解析
在软件开发中,实现对数据库的可视化操作能极大提升开发效率和用户体验。借助 WPF(Windows Presentation Foundation)强大的界面开发能力,我们可以打造出功能丰富、交互友好的数据库操作程序。本文将详细介绍如何使用 WPF 搭建一个…...
python mysql库的三个库mysqlclient mysql-connector-python pymysql如何选择,他们之间的区别
三者的区别 1. mysqlclient 特点: 是一个用于Python的MySQL数据库驱动程序,用于与MySQL数据库进行交互。 依赖于MySQL的本地库,因此在安装时需要确保系统上已安装了必要的依赖项,如libmysqlclient-dev等。 性能较好,…...
如何将数据库字符集改为中文,让今后所有的数据库都支持中文
最后一行有我自己的my.ini文件 数据库输入中文数据时会变为乱码, 这个时候,我们为每个数据库设置字符集,太过于麻烦,为数据库单独设置重启后又会消失 Set character_set_database’utf8’; Set character_set_server’utf8’; …...
Low-Level 大一统:如何使用Diffusion Models完成视频超分、去雨、去雾、降噪等所有Low-Level 任务?
Diffusion Models专栏文章汇总:入门与实战 前言:视频在传输过程中常常因为各种因素(如恶劣天气、噪声、压缩和传感器分辨率限制)而出现质量下降,这会严重影响计算机视觉任务(如目标检测和视频监控)的性能。现有的视频修复方法虽然取得了一些进展,但通常只能针对特定的退…...
EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成
EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成 1所有的材料都可以在EAMM: One-Shot Emotional Talking Face via Audio-Based Emotion-Aware Motion Model网站上找到。 摘要 尽管音频驱动的对话人脸生成技术已取得显著进展,但现有方法要么忽…...
Docker Compose的使用
文章首发于我的博客:https://blog.liuzijian.com/post/docker-compose.html 目录 Docker Compose是什么Docker Compose安装Docker Compose文件Docker Compose常用命令案例:部署WordPress博客系统 Docker Compose是什么 Docker Compose是Docker官方的开源…...
[STM32 HAL库]串口空闲中断+DMA接收不定长数据
一、空闲中断 STM32的串口具有空闲中断,什么叫做空闲呢?如何触发空闲中断呢? 空闲:串口发送的两个字符之间间隔非常短,所以在两个字符之间不叫空闲。空闲的定义是总线上在一个字节的时间内没有再接收到数据。触发条件…...
三、华为交换机 Hybrid
一、Hybrid功能 Hybrid口既可以连接普通终端的接入链路(类似于Access接口),又可以连接交换机间的干道链路(类似于Trunk接口)。它允许多个VLAN的帧通过,并可以在出接口方向将某些VLAN帧的标签剥掉࿰…...
如何通过 Apache Airflow 将数据导入 Elasticsearch
作者:来自 Elastic Andre Luiz 了解如何通过 Apache Airflow 将数据导入 Elasticsearch。 Apache Airflow Apache Airflow 是一个旨在创建、安排(schedule)和监控工作流的平台。它用于编排 ETL(Extract-Transform-Load࿰…...
Android Studio:Linux环境下安装与配置
更多内容:XiaoJ的知识星球 Android Studio:Linux环境下安装与配置 1.安装JDK2.安装Android Studio2.1 获取安装包2.2 安装(1)配置环境变量:(2)运行安装:(3)配…...
token是用来鉴权的,那session是用来干什么的?
在Web应用和API设计中,鉴权与会话管理是两个核心概念,它们对于确保用户身份的安全性和维护用户会话状态至关重要。Token和Session是两种常用的鉴权与会话管理机制,它们各自具有独特的工作原理和适用场景。下面是对Token和Session的详细解析及…...
基于 WEB 开发的二手车辆销售管理系统设计与实现
标题:基于 WEB 开发的二手车辆销售管理系统设计与实现 内容:1.摘要 摘要:随着互联网技术的不断发展,电子商务在各个领域得到了广泛的应用。本文以二手车辆销售管理系统为例,探讨了基于 WEB 开发的销售管理系统的设计与实现。通过对系统需求的…...
wordpress的火车头商品发布接口
<?php require ../wp-load.php; ini_set(memory_limit, 1024M); set_time_limit(180);$top_cat ; # 图片链接域名替换 $image_host ;$start_time microtime(true);$counter 0; // 临时缓存 $products $skus $categories []; $var_sku_index 1;$rowData$_POST;// if…...
浙江安吉成新照明电器:Acrel-1000DP 分布式光伏监控系统应用探索
安科瑞吕梦怡 18706162527 摘 要:分布式光伏发电站是指将光伏发电组件安装在用户的建筑物屋顶、空地或其他适合的场地上,利用太阳能进行发电的一种可再生能源利用方式,与传统的大型集中式光伏电站相比,分布式光伏发电具有更灵活…...
总结3..
#include<stdio.h> int n,m; int a[1002][1002]; int b[1002][1002];//判断该空的八连通图是否被走过 int gg0; int dd0; int xz[8]{-1,-1,-1,0,0,1,1,1},yz[8]{-1,0,1,-1,1,-1,0,1};//八个方向 void dfs(int x,int y) { int dx,dy; for(int i0;i<8;i) { …...
信息奥赛一本通 1168:大整数加法
这道题是一道大整数加法,涉及到高精度的算法,比如说有两个数要进行相加,1111111111111111111111111111111111111112222222222222222222222222222222,那么如果这两个数很大的话我们常用的数据类型是不能进行计算的,那么…...
3.3 OpenAI GPT-4, GPT-3.5, GPT-3 模型调用:开发者指南
OpenAI GPT-4, GPT-3.5, GPT-3 模型调用:开发者指南 OpenAI 的 GPT 系列语言模型,包括 GPT-4、GPT-3.5 和 GPT-3,已经成为自然语言处理领域的标杆。无论是文本生成、对话系统,还是自动化任务,开发者都可以通过 API 调用这些强大的模型来增强他们的应用。本文将为您详细介…...
横盘出击的三种经典走势形态,买点以及需要注意的问题技术详解
龙头股在横盘整理过程中,也会出现几种不同的形态,比如矩形整理形态,或者在某一趋势线下方运行。 第一种形态:突破横盘趋势线 突破横盘趋势线时识别横盘龙头启动的关键点位。股价经过一段时间的横盘后,突然出现快速上…...
处理没有提示的字符串、计算相隔天数应用题
正常情况下,小云每天跑 1 千米。如果某天是周一或者月初(1 日),为了激励自己,小云要跑 2 千米。如果同时是周一或月初,小云也是跑 2 千米。 小云跑步已经坚持了很长时间,从 1990 年 1 月 1 日周…...
【LeetCode】力扣刷题热题100道(31-35题)附源码 搜索二维矩阵 岛屿数量 腐烂的橙子 课程表 实现 Trie (前缀树)(C++)
一、搜索二维矩阵 编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性: 每行的元素从左到右升序排列。每列的元素从上到下升序排列。 可以使用 从右上角开始搜索 的方法来有效地找到目标值。 选择起始位置: 从矩…...
docker详细操作--未完待续
docker介绍 docker官网: Docker:加速容器应用程序开发 harbor官网:Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台,用于将应用程序及其依赖项(如库、运行时环…...
【WiFi帧结构】
文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成:MAC头部frame bodyFCS,其中MAC是固定格式的,frame body是可变长度。 MAC头部有frame control,duration,address1,address2,addre…...
无法与IP建立连接,未能下载VSCode服务器
如题,在远程连接服务器的时候突然遇到了这个提示。 查阅了一圈,发现是VSCode版本自动更新惹的祸!!! 在VSCode的帮助->关于这里发现前几天VSCode自动更新了,我的版本号变成了1.100.3 才导致了远程连接出…...
visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...
蓝桥杯 2024 15届国赛 A组 儿童节快乐
P10576 [蓝桥杯 2024 国 A] 儿童节快乐 题目描述 五彩斑斓的气球在蓝天下悠然飘荡,轻快的音乐在耳边持续回荡,小朋友们手牵着手一同畅快欢笑。在这样一片安乐祥和的氛围下,六一来了。 今天是六一儿童节,小蓝老师为了让大家在节…...
鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序
一、开发准备 环境搭建: 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 项目创建: File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...
django filter 统计数量 按属性去重
在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...
抖音增长新引擎:品融电商,一站式全案代运营领跑者
抖音增长新引擎:品融电商,一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中,品牌如何破浪前行?自建团队成本高、效果难控;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...
[ICLR 2022]How Much Can CLIP Benefit Vision-and-Language Tasks?
论文网址:pdf 英文是纯手打的!论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误,若有发现欢迎评论指正!文章偏向于笔记,谨慎食用 目录 1. 心得 2. 论文逐段精读 2.1. Abstract 2…...
Qt Http Server模块功能及架构
Qt Http Server 是 Qt 6.0 中引入的一个新模块,它提供了一个轻量级的 HTTP 服务器实现,主要用于构建基于 HTTP 的应用程序和服务。 功能介绍: 主要功能 HTTP服务器功能: 支持 HTTP/1.1 协议 简单的请求/响应处理模型 支持 GET…...
