WPF 实现可视化操作数据库的程序全解析

news2025/1/21 1:12:37

在软件开发中,实现对数据库的可视化操作能极大提升开发效率和用户体验。借助 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 与数据库交互开发方面提供有益的参考,帮助大家快速掌握这一重要的开发技能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2279585.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Vue2+OpenLayers实现车辆开始、暂停、重置行驶轨迹动画(提供Gitee源码)

前言&#xff1a;根据经纬度信息绘制一个完整的行驶路线&#xff0c;车辆根据绘制好的路线从开始点位行驶到结束点位&#xff0c;可以通过开始、暂停、重置按钮控制车辆状态。 目录 一、案例截图 二、安装OpenLayers库 三、​安装Element-UI ​ 四、代码实现 4.1、初始化…

使用傅里叶变换进行图像边缘检测

使用傅里叶变换进行图像边缘检测 今天我们介绍通过傅里叶变换求得图像的边缘 什么是傅立叶变换&#xff1f; 简单来说&#xff0c;傅里叶变换是将输入的信号分解成指定样式的构造块。例如&#xff0c;首先通过叠加具有不同频率的两个或更多个正弦函数而生成信号f&#xff08;x…

基础vue3前端登陆注册界面以及主页面设计

1.下载依赖 "element-plus/icons": "^0.0.11", "element-plus/icons-vue": "^2.3.1", "fortawesome/fontawesome-svg-core": "^6.7.2", "fortawesome/free-solid-svg-icons": "^6.7.2", &quo…

中国数字安全产业年度报告(2024)

数字安全是指&#xff0c;在全球数字化背景下&#xff0c;合理控制个人、组织、国家在各种活动中面临的数字风险&#xff0c;保障数字社会可持续发展的政策法规、管理措施、技术方法等安全手段的总和。 数字安全领域可从三个方面对应新质生产力的三大内涵:一是基于大型语言模型…

从CRUD到高级功能:EF Core在.NET Core中全面应用(三)

目录 IQueryable使用 原生SQL使用 实体状态跟踪 全局查询筛选器 并发控制使用 IQueryable使用 在EFCore中IQueryable是一个接口用于表示可查询的集合&#xff0c;它继承自IEnumerable但具有一些关键的区别&#xff0c;使得它在处理数据库查询时非常有用&#xff0c;普通集…

【VRChat · 改模】Unity2019、2022的版本选择哪个如何决策,功能有何区别;

总览 1.Unity2019、2022的版本的选择 2.Unity添加着色器教程 一、Unity2019、2022的版本的选择 1.Unity2019 和 Unity2022 的区别&#xff0c;VRChat SDK 为何要区分两个版本 我是外行&#xff0c;最开始以为的是&#xff0c;2019 和 2022 的变化是基于这个模型本身的。 也…

人工智能之深度学习-[1]-了解深度学习

文章目录 深度学习1. 神经网络的基础2. 深度学习中的重要概念3. 深度学习的工作流程4. 深度学习的应用5. 深度学习的挑战6. 深度学习与传统机器学习的比较7.深度学习的特点 8. 常见的深度学习模型9.深度学习发展史[了解] 深度学习 深度学习&#xff08;Deep Learning&#xff…

彻底理解JVM类加载机制

文章目录 一、类加载器和双亲委派机制1.1、类加载器1.2、双亲委派机制1.3、自定义类加载器1.4、打破双亲委派机制 二、类的加载 图片来源&#xff1a;图灵学院   由上图可知&#xff0c;创建对象&#xff0c;执行其中的方法&#xff0c;在java层面&#xff0c;最重要的有获取…

第148场双周赛:循环数组中相邻元素的最大差值、将数组变相同的最小代价、最长特殊路径、所有安放棋子方案的曼哈顿距离

Q1、循环数组中相邻元素的最大差值 1、题目描述 给你一个 循环 数组 nums &#xff0c;请你找出相邻元素之间的 最大 绝对差值。 **注意&#xff1a;**一个循环数组中&#xff0c;第一个元素和最后一个元素是相邻的。 2、解题思路 这个问题的核心是遍历循环数组并计算相邻…

电脑换固态硬盘

参考&#xff1a; https://baijiahao.baidu.com/s?id1724377623311611247 一、根据尺寸和缺口可以分为以下几种&#xff1a; 1、M.2 NVME协议的固态 大部分笔记本是22x42MM和22x80MM nvme固态。 在京东直接搜&#xff1a; M.2 2242 M.2 2280 2、msata接口固态 3、NGFF M.…

opengrok_windows_环境搭建

软件列表 软件名下载地址用途JDKhttps://download.java.net/openjdk/jdk16/ri/openjdk-1636_windows-x64_bin.zipindex 使用java工具tomcathttps://dlcdn.apache.org/tomcat/tomcat-9/v9.0.98/bin/apache-tomcat-9.0.98-windows-x64.zipweb服务器opengrokhttps://github.com/o…

《offer 来了:Java 面试核心知识点精讲 -- 原理篇》

在 Java 面试的战场上,只知皮毛可不行,面试官们越来越看重对原理的理解。今天就给大家分享一本能让你在面试中脱颖而出的 “武林秘籍”——《offer 来了:Java 面试核心知识点精讲 -- 原理篇》。 本书详细介绍了Java架构师在BAT和移动互联网公司面试中常被问及的核心知识,内…

Linux之网络套接字

Linux之网络套接字 一.IP地址和端口号二.TCP和UDP协议2.1网络字节序 三.socket编程的常见API四.模拟实现UDP服务器和客户端五.模拟实现TCP服务器和客户端 一.IP地址和端口号 在了解了网络相关的基础知识之后我们知道了数据在计算机中传输的流程并且发现IP地址在其中占据了确定…

迈向 “全能管家” 之路:机器人距离终极蜕变还需几步?

【图片来源于网络&#xff0c;侵删】 这是2024年初Figure公司展示的人形机器人Figure 01&#xff0c;他可以通过观看人类的示范视频&#xff0c;在10小时内经过训练学会煮咖啡&#xff0c;并且这个过程是完全自主没有人为干涉的&#xff01; 【图片来源于网络&#xff0c;侵删】…

几何数据结构之四叉树与八叉树

几何数据结构之四叉树与八叉树 四叉树的定义四叉树深度的计算公式推导假设&#xff1a;计算过程&#xff1a;1. 划分空间&#xff1a;2. 节点容纳的最小距离&#xff1a;3. 解出深度&#xff1a;4. 考虑常数项&#xff1a; 总结&#xff1a; 八叉树 四叉树的定义 四叉树&#…

(一)相机标定——四大坐标系的介绍、对应转换、畸变原理以及OpenCV完整代码实战(C++版)

一、四大坐标系介绍 1&#xff0c;世界坐标系 从这个世界&#xff08;world&#xff09;的视角来看物体 世界坐标系是3D空间坐标&#xff0c;每个点的位置用 ( X w , Y w , Z w ) (X_w,Y_w,Z_w) (Xw​,Yw​,Zw​)表示 2&#xff0c;相机坐标系 相机本身具有一个坐标系&…

嵌入式知识点总结 C/C++ 专题提升(一)-关键字

针对于嵌入式软件杂乱的知识点总结起来&#xff0c;提供给读者学习复习对下述内容的强化。 目录 1.C语言宏中"#“和"##"的用法 1.1.(#)字符串化操作符 1.2.(##)符号连接操作符 2.关键字volatile有什么含意?并举出三个不同的例子? 2.1.并行设备的硬件寄存…

重塑商业智能:大数据改变商业的十种方式

在过去几年间&#xff0c;大数据一直在改变许多公司的运营方式。大数据指的是大量且多样的数据集&#xff0c;当这些数据被妥善收集和分析时&#xff0c;人们能够从中获取有价值的洞察信息。随着大数据逐渐应用于中小型企业&#xff0c;它有望彻底变革企业运营模式。以下将介绍…

基于Spring Boot的车间调度管理系统

基于 Spring Boot 的车间调度管理系统 一、系统概述 基于 Spring Boot 的车间调度管理系统是一个为制造企业车间生产活动提供智能化调度和管理解决方案的软件系统。它利用 Spring Boot 框架的便捷性和高效性&#xff0c;整合车间内的人员、设备、物料、任务等资源&#xff0c…

Ubuntu 24.04 LTS 安装 tailscale 并访问 SMB共享文件夹

Ubuntu 24.04 LTS 安装 tailscale 安装 Tailscale 官方仓库 首先&#xff0c;确保系统包列表是最新的&#xff1a; sudo apt update接下来&#xff0c;安装 Tailscale 所需的仓库和密钥&#xff1a; curl -fsSL https://tailscale.com/install.sh | sh这会自动下载并安装 …