WPF DataGrid顯示MySQL查詢信息,且可刪除、修改、插入 (原發佈 csdn 2018-10-13 20:07:28)

来源:https://www.cnblogs.com/njit-77/archive/2019/09/05/11469089.html
-Advertisement-
Play Games

1、入行好幾年了,工作中使用資料庫幾率很小(傳統行業)。藉著十一假期回家機會,學習下資料庫。 2、初次瞭解資料庫相關知識,如果本文有誤,還望告知。 3、本文主要目的,記錄下wpf界面顯示資料庫信息,且可進行刪除、修改、插入命令。並反饋數據到MySQL。做個記錄,以便以後工作中使用到時沒個頭緒。 4、 ...


1、入行好幾年了,工作中使用資料庫幾率很小(傳統行業)。藉著十一假期回家機會,學習下資料庫。

2、初次瞭解資料庫相關知識,如果本文有誤,還望告知。

3、本文主要目的,記錄下wpf界面顯示資料庫信息,且可進行刪除、修改、插入命令。並反饋數據到MySQL。做個記錄,以便以後工作中使用到時沒個頭緒。

4、MySQL的基本講解不再介紹,安裝過程什麼的,我也是按照網上教程一步一步進行的,假定MySQL已安裝成功,且新建有資料庫,見下圖:

在這裡插入圖片描述

廢話不多說,直接上代碼

界面代碼xaml

    <Grid>
        <DataGrid x:Name="DataGrid1" HorizontalAlignment="Left" Height="400" Margin="10,10,0,0" VerticalAlignment="Top" Width="537" LoadingRow="DataGrid_LoadingRow">
            <DataGrid.Columns>
                <DataGridTextColumn Header="id" Width="50" Binding="{Binding Path=id}"/>
                <DataGridTextColumn Header="name" Width="*" Binding="{Binding Path=name}"/>
                <DataGridTextColumn Header="phone" Width="*" Binding="{Binding Path=phone}"/>
                <DataGridTextColumn Header="email" Width="*" Binding="{Binding Path=email}"/>
            </DataGrid.Columns>
        </DataGrid>
        <Button x:Name="DeleteButton" Content="刪除" Margin="0,40,10,0" VerticalAlignment="Top" Click="DeleteButton_Click" HorizontalAlignment="Right" Width="75"/>
        <Button x:Name="UpdateButton" Content="修改" Margin="0,80,10,0" VerticalAlignment="Top" Click="UpdateButton_Click" HorizontalAlignment="Right" Width="75"/>
        <Button x:Name="InsertButton" Content="插入" Margin="0,120,10,0" VerticalAlignment="Top" Click="InsertButton_Click" HorizontalAlignment="Right" Width="75"/>
    </Grid>

後端代碼cs

    public partial class MainWindow : Window
    {
        //SQLBulkCopy
        Random rd = new Random();
        string sqlstr = "Data Source=127.0.0.1;User ID=root;Password=root;DataBase=test;Charset=utf8;";
        MySql.Data.MySqlClient.MySqlConnection con;
        MySql.Data.MySqlClient.MySqlDataAdapter adapter;
        System.Data.DataSet ds;
        System.Data.DataTable dt;


        public MainWindow()
        {
            InitializeComponent();

            UpdateMySQLData();
        }

        private void DataGrid_LoadingRow(object sender, System.Windows.Controls.DataGridRowEventArgs e)
        {
            e.Row.Header = e.Row.GetIndex() + 1;
        }

        private void UpdateMySQLData()
        {
            if (con == null)
            {
                con = new MySql.Data.MySqlClient.MySqlConnection(sqlstr);
                con.Open();
            }
            if (adapter == null)
            {
                adapter = new MySql.Data.MySqlClient.MySqlDataAdapter("select * from user", con);
            }
            if (ds == null)
            {
                ds = new System.Data.DataSet();
            }
            ds.Clear();
            adapter.Fill(ds, "user");
            if (dt == null)
            {
                dt = ds.Tables["user"];
            }
            DataGrid1.ItemsSource = dt.DefaultView;
        }

        private void DeleteButton_Click(object sender, RoutedEventArgs e)
        {
            int index = DataGrid1.SelectedIndex;
            if (index == -1) return;
#if MySQLCommand
            string DeleteSqlCommand = string.Format("delete from user where id = '{0}'", dt.Rows[index]["id"]);
            MySql.Data.MySqlClient.MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand(DeleteSqlCommand, con);
            cmd.ExecuteNonQuery();

            UpdateMySQLData();
#else
            dt.Rows[index].Delete();
            //dt.Rows.RemoveAt(index);==dt.Rows[index].Delete() + dt.AcceptChanges()
            MySql.Data.MySqlClient.MySqlCommandBuilder builder = new MySql.Data.MySqlClient.MySqlCommandBuilder(adapter);
            adapter.Update(dt);
            dt.AcceptChanges();
#endif
        }

        private void UpdateButton_Click(object sender, RoutedEventArgs e)
        {
#if MySQLCommand
            int index = DataGrid1.SelectedIndex;
            string UpdateSqlCommand = string.Format("update user set id = '{0}', name = '{1}', phone = '{2}', email = '{3}' where id = '{0}'",
                dt.Rows[index]["id"], dt.Rows[index]["name"], dt.Rows[index]["phone"], dt.Rows[index]["email"]);
            MySql.Data.MySqlClient.MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand(UpdateSqlCommand, con);
            cmd.ExecuteNonQuery();

            UpdateMySQLData();
#else
            MySql.Data.MySqlClient.MySqlCommandBuilder builder = new MySql.Data.MySqlClient.MySqlCommandBuilder(adapter);
            adapter.Update(dt);
            dt.AcceptChanges();
#endif
        }

        private void InsertButton_Click(object sender, RoutedEventArgs e)
        {
#if MySQLCommand
            string InsertSqlCommand = string.Format("insert into user(id, name, phone,email) values('{0}','{1}','{2}','{3}')", rd.Next(100), "ZhangSan", 12332112345, "[email protected]");
            MySql.Data.MySqlClient.MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand(InsertSqlCommand, con);
            cmd.ExecuteNonQuery();

            string InsertSqlCommand2 = string.Format("insert into user(id, name, phone,email) values('{0}','{1}','{2}','{3}')", rd.Next(100), "LiSi", 12332112345, "[email protected]");
            MySql.Data.MySqlClient.MySqlCommand cmd2 = new MySql.Data.MySqlClient.MySqlCommand(InsertSqlCommand2, con);
            cmd2.ExecuteNonQuery();

            UpdateMySQLData();
#else
            System.Data.DataRow dr = dt.NewRow();
            dr[0] = rd.Next(100);
            dr[1] = "ZhangSan";
            dr[2] = "12332112345";
            dr[3] = "[email protected]";
            dt.Rows.Add(dr);

            System.Data.DataRow dr2 = dt.NewRow();
            dr2[0] = rd.Next(100);
            dr2[1] = "LiSi";
            dr2[2] = "12332154321";
            dr2[3] = "[email protected]";
            dt.Rows.Add(dr2);

            MySql.Data.MySqlClient.MySqlCommandBuilder builder = new MySql.Data.MySqlClient.MySqlCommandBuilder(adapter);
            adapter.Update(ds, "user");
            dt.AcceptChanges();
#endif
        }

    }

軟體打開界面
在這裡插入圖片描述

刪除時一直不失敗,網上找了好久才找到答案
參考資料
https://blog.csdn.net/sz101/article/details/5837950
https://bbs.csdn.net/wap/topics/390845652
http://www.cnblogs.com/perfect/archive/2007/08/06/844634.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • #include <cstdio> #include <cmath> using namespace std; void dg(int n) { int a; if(n==0) return; for(int i=0;i<=15;i++) //求出n以內2最大的a次方 { a=i; if(pow(2... ...
  • 過濾器的位置是在用戶提交之後,攔截器攔截的位置是在handlermapping之後,攔截器需要在springmvc的配置文件中進行配置,攔截的那些文件 一、springmvc配置 <bean class="com.zhiyou100.zj.inter.Myinter"></bean>定義的過濾器的全 ...
  • jdk 安裝包 https://pan.baidu.com/s/1cKnUQGU2Sk2nsARAzzVAHw [root@localhost ~]# tar -zxvf jdk-8u152-linux-x64.tar.gz [root@localhost ~]# mv jdk1.8.0_152/ ...
  • 在 上一篇 中講到了在NetCore項目中如何進行全局的請求模型驗證,只要在請求模型中加了驗證特性,介面使用時只用將數據拿來使用,而不用去關係數據是否符合業務需求。 這篇中將講些個人對於JWT的看法和使用,在網上也能找到很多相關資料和如何使用,基本都是直接嵌到 Startup 類中來單獨使用。而博主 ...
  • 場景 新手入門,看見大神們在VS中只用鍵盤就可以完成一系列操作。 整理一些常用的能提高效率的快捷鍵。 關註公眾號霸道的程式猿獲取編程相關電子書、教程推送與免費下載。 大量編程視頻教程:https://space.bilibili.com/164396311 實現 F12 :跳到代碼定義 F1:查看微 ...
  • 場景 打開VS,輸入Path,我們可以看到其定義。 都是靜態方法,所以我們可以使用類名直接調用。 實現 新建命令行程式,編碼如下: 效果 關註公眾號霸道的程式猿獲取編程相關電子書、教程推送與免費下載。 大量編程視頻教程:https://space.bilibili.com/164396311 ...
  • 一、封裝 下麵我設計了一個空調類,對於要使用這個空調類的其他類我可以稱它們為用戶。用戶需要瞭解空調類的使用方法,才能更好的使用空調。空調類如下: 用戶使用我設計的空調類,如果他對使用方法不太熟,它可能給空調上下方向設置成5或者其它數字;或者今天天氣特別熱,它把空調溫度設置成0度甚至更低,或者失誤設置 ...
  • 1、FileStream FileStream 詳細介紹參考 "msdn" 寫數據: c using (FileStream fs = new FileStream("File.FileStream", FileMode.Create, FileAccess.Write)) { for (int i ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...