C#如何在窗体程序中操作数据库数据

目录
  • 一、界面布局
  • 二、定义数据库操作的公共类
  • 三、在界面中操作数据库方法

一、界面布局

界面中有一个dataGridview、两个Button、两个Label和两个TextBox。

二、定义数据库操作的公共类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
using System.Windows.Forms;
using System.Data;
using MySql.Data.MySqlClient;
namespace TemSys
{
   public  class DBCtrl
   {
        private MySqlConnection m_ClientsqlConn;
        public DBCtrl()                                                                          //    连接类型
        {
            m_ClientsqlConn = new MySqlConnection();
            try
            {
                m_ClientsqlConn.Dispose();
                m_ClientsqlConn.Close();
                m_ClientsqlConn.ConnectionString = "Database=dbName;Data Source=localhost;User Id=root;Password=123;charset=utf8";
                m_ClientsqlConn.Open();
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.Message);
            }
        }
        public DBCtrl(string IP, string DBname, string Uname, string Pword)                     //    创建连接
        {
            m_ClientsqlConn = new MySqlConnection();
            try
            {
                m_ClientsqlConn.Dispose();
                m_ClientsqlConn.Close();
                m_ClientsqlConn.ConnectionString = string.Format("Database={0};Data Source={1};User Id={2};Password={3};charset=utf8", DBname, IP, Uname, Pword);
                m_ClientsqlConn.Open();
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.Message);
            }
        }
        public void DBConn(string connStr)                                                         //    重载  创建连接
        {
            try
            {
                m_ClientsqlConn.Close();
                m_ClientsqlConn.ConnectionString = connStr;
                m_ClientsqlConn.Open();
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.Message);
            }
        }
        public DataTable GetDataTable(string SQLstr)                                     //    获取DataTable 一个表
        {
            Console.Write("zcn==获取数据库连接,打开数据库");
            try
            {
                if (m_ClientsqlConn.State == ConnectionState.Open)
                    m_ClientsqlConn.Close();
                m_ClientsqlConn.Open();
                MySqlDataAdapter da = new MySqlDataAdapter(SQLstr, m_ClientsqlConn);
                DataTable resultDS = new DataTable();
                da.Fill(resultDS);
                return resultDS;
            }
            catch (Exception ee)
            {
                Console.Write("zcn==获取数据库连接,打开数据库异常异常");
                //MessageBox.Show( ee.Message);
                m_logclass.WriteLogFilein(ee.Message, "GetDataTable.txt");
                return null;
            }
            finally
            {
                m_ClientsqlConn.Close();
            }
        }
        public DataTable GetDataTableUsing(string SQLstr)                                     //    获取DataTable 一个表
        {
            using (MySqlConnection m_ClientsqlConn = new MySqlConnection())
            {
            }
            try
            {
                if (m_ClientsqlConn.State == ConnectionState.Open)
                    m_ClientsqlConn.Close();
                m_ClientsqlConn.Open();
                MySqlDataAdapter da = new MySqlDataAdapter(SQLstr, m_ClientsqlConn);
                DataTable resultDS = new DataTable();
                da.Fill(resultDS);
                return resultDS;
            }
            catch (Exception ee)
            {
                //MessageBox.Show( ee.Message);
                return null;
            }
        }
        public List<string> GetStringListfor(string lineName,DataTable dt)    //根据某一列的名字  获取某个集合中该列的所有值
        {
            List<string> list = new List<string>();
            foreach (DataRow dr in dt.Rows)
            {
                list.Add((string)dr[lineName]);
            }
            return list;
        }
        public List<DataRow> GetDataRowfor(DataTable dt)   //根据 datatable  获取每一行的数据的datarow
        {
            List<DataRow> list = new List<DataRow>();
            foreach (DataRow dr in dt.Rows)
            {
                list.Add(dr);
            }
            return list;
        }
/*
        public DataRow GetDataRowfor(string tablename,string ID)  //根据ID号 返回对应行的  DataRow
        {
            string ss = "select * from " + tablename + " where ID = \'"+ID +"\'";
            DataRow dr = new DataRow();
            DataTable dt = GetDataTable(ss);
            dr = dt.Rows[0];
            return dr;
        }
*/
         public DataTable GetDataTableOneLine(string SQLstr)                                     //    获取DataTable 一个表中一行
        {
            MySqlDataAdapter da = new MySqlDataAdapter(SQLstr, m_ClientsqlConn);
            DataTable resultDS = new DataTable();
            da.Fill(resultDS);
            return resultDS;
        }
        public DataTable GetDataSet_to_Table(string SQLstr)                               //    获取 dataset   多个表中  table
        {
            try
            {
                MySqlDataAdapter da = new MySqlDataAdapter(SQLstr, m_ClientsqlConn);
                DataSet ds = new DataSet();
                da.Fill(ds);
                return ds.Tables[0];
            }
            catch
            {
                return null;
            }
        }
        public Boolean InsertDBase(string insString)
        {
            try
            {
                if (m_ClientsqlConn.State == ConnectionState.Open)
                    m_ClientsqlConn.Close();
                m_ClientsqlConn.Open();
                MySqlCommand sqlcomd = new MySqlCommand(insString, m_ClientsqlConn);
                sqlcomd.ExecuteNonQuery();
                return true;
            }
            catch (Exception ee)
            {
                return false;
            }
            finally
            {
                m_ClientsqlConn.Close();
            }
        }
        public Boolean deleteRowfor(string tablename,int deleteID)  //根据 ID 删除指定行
        {
            try
            {
                string ss ="delete from "+ tablename +" where ID = "+ deleteID;
                if (m_ClientsqlConn.State == ConnectionState.Open)
                    m_ClientsqlConn.Close();
                m_ClientsqlConn.Open();
                MySqlCommand sqlcmd = new MySqlCommand(ss, m_ClientsqlConn);
                sqlcmd.ExecuteNonQuery();
                return true;
            }
            catch(Exception ee)
            {
                return false;
            }
        }
        public Boolean ModifyRowfor(string modifystr,string modifyID)         // 根据
        {
            try
            {
                string ss = modifystr + " where id = " + modifyID;
                if (m_ClientsqlConn.State == ConnectionState.Open)
                    m_ClientsqlConn.Close();
                m_ClientsqlConn.Open();
                MySqlCommand sqlcmd = new MySqlCommand(ss, m_ClientsqlConn);
                sqlcmd.ExecuteNonQuery();
                return true;
            }
            catch (Exception ee)
            {
                return false;
            }
            finally
            {
                m_ClientsqlConn.Close();
            }
        }
        public void CloseDBase()               //   参数类型  不同数据库连接
        {
            m_ClientsqlConn.Close();
        }
    }
}

三、在界面中操作数据库方法

ps:数据库的配置信息保存在Config.ini文件中,如果仅是测试用的话,可以直接在

m_DataBase = new DBCtrl(ipstr, namestr, usernamestr, passwordstr);

处输入ip地址、数据库名、数据库用户名和密码即可

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Runtime.InteropServices;
namespace TemSys
{
    public partial class ModifyDevice : Form
    {
        [DllImport("kernel32")]                                        //读写ini文件函数
        private static extern long WritePrivateProfileString(string section, string key, string val, string filePath);
        [DllImport("kernel32")]
        private static extern long GetPrivateProfileString(string section, string key, string def, StringBuilder retVal, int size, string filePath);
        DataTable dt = new DataTable();
        private DBCtrl m_DataBase;
        public ModifyDevice()
        {
            InitializeComponent();
        }
        //将所有的textBox值设为空
        private void TextBoxNull()
        {
            textBox1.Text = "";
            textBox2.Text = "";
        }
        //设置Lab值
        private void labelshow()
        {
            label1.Text = dataGridView1.Columns[0].HeaderText;
            label2.Text = dataGridView1.Columns[12].HeaderText;
        }
        //初始化界面
        private void ModifyDevice_Load(object sender, EventArgs e)
        {
            StringBuilder retval = new StringBuilder();
            GetPrivateProfileString("DBConfig", "dbip", "", retval, 20, AppDomain.CurrentDomain.BaseDirectory + "Config.ini");
            string ipstr = retval.ToString();
            GetPrivateProfileString("DBConfig", "dbname", "", retval, 20, AppDomain.CurrentDomain.BaseDirectory + "Config.ini");
            string namestr = retval.ToString();
            GetPrivateProfileString("DBConfig", "dbusername", "", retval, 20, AppDomain.CurrentDomain.BaseDirectory + "Config.ini");
            string usernamestr = retval.ToString();
            GetPrivateProfileString("DBConfig", "dbpassword", "", retval, 20, AppDomain.CurrentDomain.BaseDirectory + "Config.ini");
            string passwordstr = retval.ToString();
            m_DataBase = new DBCtrl(ipstr, namestr, usernamestr, passwordstr);
            initDataTable();
        }
        private void initDataTable()
        {
            string ssp = string.Format("select * from device_info1");
            dt = m_DataBase.GetDataTable(ssp);
            dataGridView1.DataSource = dt;
            labelshow();
        }
        //双击dataGridView响应事件
        private void dataGridView1_CellDoubleClick(object sender, DataGridViewCellEventArgs e)
        {
            string index = dataGridView1.CurrentRow.Cells[0].Value.ToString();
            if (label1.Text == "id")
            {
                string ssp = string.Format("select * from device_info1 where id='" + index + "'");
                dt = m_DataBase.GetDataTable(ssp);
                //DataRow row = dt.Rows[0];
                textBox1.Text = dt.Rows[0]["id"].ToString();
                textBox2.Text = dt.Rows[0]["number"].ToString();
            }
        }
        //点击修改按钮响应事件
        private void btnModify_Click(object sender, EventArgs e)
        {
            bool flag = false;
            string ssp = string.Format("update device_info1 set number='" + textBox2.Text + "'");
            flag = m_DataBase.ModifyRowfor(ssp, textBox1.Text);
            if (flag)
            {
                MessageBox.Show("修改成功!");
                initDataTable();
            }
            else
            {
                MessageBox.Show("修改失败!");
            }
        }
        private void btnDelete_Click(object sender, EventArgs e)
        {
             bool flag = false;
            int currentIndex = (int)dataGridView1.CurrentRow.Cells[0].Value;
            Console.WriteLine("输出当前选中数据行:" + currentIndex);
            flag = m_DataBase.deleteRowfor("device_info1", currentIndex);
            if (flag)
            {
                MessageBox.Show("删除成功!");
                initDataTable();
            }
            else
            {
                MessageBox.Show("删除失败!");
            }
        }
    }
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • C# 制作PictureBox圆形头像框并从数据库中读取头像

    现在只要是有关头像的框基本都是圆形的了,C#提供的PictureBox控键默认情况下是方形的非常大的影响美观 PictureBox默认情况下 比起上面的还是有一点不太好看的- 使用C#提供的类进行圆形: 工具箱拉出PictureBox 设置图片的显示模式为ZOOM 特别注意: 框的比例必须为一样不然会变椭圆的 窗体加载时: pictureBox1.Image = Image.FromFile(@"C:\Users\Administrator\Desktop\1.png"); 为了方便演

  • C#利用反射实现多数据库访问

    在上一篇文章中讲解了什么是反射,以及利用反射可以获取程序集里面的哪些内容.在平时的项目中,可能会遇到项目需要使用多种数据库,这篇文章中将会讲解如何利用反射实现访问多种数据库. 项目整体结构如下图所示: 1.Database.Instance是一个类库文件,IDBHelper是一个接口,封装的访问数据库数据的CURD方法,OracleDBHelper和SQLServerDBHelper类实现IDBHelper接口,分别用来访问Oracle数据库和SQL Server数据库,接口和类的定义如下: I

  • C# 连接本地数据库的实现示例

    目录 使用环境 1. 安装MySQL 2. 连接本地MySQL 3. C# 连接本地MySQL 使用环境 C#VSCodeM1 1. 安装MySQL 下载MySQL软件,傻瓜式安装即可,安装完之后,在系统偏好号设置里会出现一个MySQL的图标. 在安装的时候会让用户输入密码,这个自己看着输就行了,但是别忘记了. 建议别用终端命令行安装了,对初学者来说学习成本比较大. 2. 连接本地MySQL 安装完MySQL之后,点击MySQL图标,开启MySQL,如下我已开启 我本地已安装了Navicate,

  • 使用C#连接并读取MongoDB数据库

    在上篇文章中,讲解了MongoDB的基本操作,包括增.删.改.查,但是这些操作都是在命令行模式下进行的,这篇文章中讲解如何使用C#程序连接到MongoDB数据库,并且读取里面的文档. 一.新建项目 新建控制台程序,命名为“MongoDBDemo” 二.使用NuGet添加MongoDB 1.在项目上右键,选择“管理NuGet程序包” 2.在弹出的对话框中输入“MongoDB”并搜索 3.这里选择安装MongoDB.Driver,安装过程如下: 4.查看引用 安装完成以后,查看项目的引用,发现Mon

  • C#获取微信小程序的云数据库中数据的示例代码

    目录 0 背景说明 0.1 获取AccessToken 0.2 数据库查询 0.3 文件下载 2. 简单的封装 3. 简单测试 4. 参考文档 0 背景说明 试水小程序,实现访客登记,现有.NET程序需要获取该小程序的数据 0.1 获取AccessToken 调用绝大多数后台接口时都需使用 access_token 参考小程序文档:auth.getAccessToken 发送Get请求,获取AccessToken 接口: https://api.weixin.qq.com/cgi-bin/tok

  • c#如何利用定时器自动备份数据库详解

    目录 引用dll 静态类 定时器启动 备份代码 总结 引用dll mysql.data.dll是MySQL数据库中一款必备的驱动文件,主要用于.net编程和MySQL数据库的连接,包含不同版本的mysql.data.dll,支持32位和64位系统 MySqlBackup快速备份或还原 MySql数据库,原理是使用MySqlBackup.dll 中的备份和还原方法,将数据库的信息转换为对应的sql语句,然后进行处理. MySql.Data.dll MySqlbackup.dll 静态类 新建一个连

  • C#如何在窗体程序中操作数据库数据

    目录 一.界面布局 二.定义数据库操作的公共类 三.在界面中操作数据库方法 一.界面布局 界面中有一个dataGridview.两个Button.两个Label和两个TextBox. 二.定义数据库操作的公共类 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.SqlClient; using System.Windows.Forms; u

  • YII2框架中操作数据库的方式实例分析

    本文实例讲述了YII2框架中操作数据库的方式.分享给大家供大家参考,具体如下: 一.以createCommand方式: // YII2中通过createCommand来处理数据库 // 查询多条记录 // {{%user}} 表示如果设置了表前缀,YII会自动帮你替换 $data1 = YII::$app->db->createCommand('select * from {{%user}}')->queryAll(); // 查询一条记录 // createCommand的第二个参数可

  • 小程序中实现excel数据的批量导入的示例代码

    目录 1 建立数据源 2 编制入库的代码 2.1 创建低码方法 2.2 低码中调用连接器 3 最终的代码 4 总结 我们上一篇介绍了如何利用微搭的自定义连接器接入腾讯文档的数据,光有接入是不够的,更重要的是我们需要将采集的数据积累下来,变成企业的数字资产. 积累数据最好的方式就是把数据存入数据库,低码工具除了有可视化编程的便利外,还提供了线上的文档型数据库.文档数据库比传统数据库的优势是,文档数据库的返回结构是JSON格式,直接就可以在前端进行渲染.关系型数据库还得通过代码进行转译. 另外一个方

  • ASP.NET中操作数据库的基本步骤分享

    1.ASP.NET操作数据库的基本步骤: ASP.NET数据操作常用方法: a. ExecuteReader() 返回的是一个SqlDataReader对象或OleDbDataReader对象,每次返回或操作指引一个记录保存在服务器的内存中. 相对 DataSet而言,具体较快的访问能力,通常用来进行查询操作. b.ExecuteNonQuery() c.ExecuteScalar()返回的是Object类型.如果执行的是SELECT,则返回结果是查询后的第一行第一列 返回数据库中影响的行数,进

  • 在Python程序中操作MySQL的基本方法

    Python操作Mysql 最近在学习python,这种脚本语言毫无疑问的会跟数据库产生关联,因此这里介绍一下如何使用python操作mysql数据库.我python也是零基础学起,所以本篇博客针对的是python初学者,大牛可以选择绕道. 另外,本篇基于的环境是Ubuntu13.10,使用的python版本是2.7.5. MYSQL数据库 MYSQL是一个全球领先的开源数据库管理系统.它是一个支持多用户.多线程的数据库管理系统,与Apache.PHP.Linux共同组成LAMP平台,在web应

  • 在Java程序中使用数据库的新方法

    Java 8终于到来了! 经过几年的等待, java程序员终于能在java中得到函数式编程的支持了. 函数式编程的支持能流程化现有的代码并且为java提供强大的能力.在这些新特性中最瞩目的是java程序员对数据库的操作方式.函数式编程带来了令人激动的简便高效的数据库API. Java 8 将会支持可与像C#的LINQ等语言竞争的新的数据库访问方式. 处理数据的函数式方式 Java 8 不仅仅添加了函数式支持,它也通过新的函数式处理数据的方式扩展了集合(Collection)类. 而通常情况下ja

  • 在Java的Hibernate框架中对数据库数据进行查询操作

    Hibernate查询语言(HQL)是一种面向对象的查询语言,类似于SQL,但不是对表和列操作,HQL适用于持久对象和它们的属性. HQL查询由Hibernate转换成传统的SQL查询,这在圈上的数据库执行操作. 虽然可以直接使用SQL语句和Hibernate使用原生SQL,但建议使用HQL尽可能避免数据库可移植性的麻烦,并采取Hibernate的SQL生成和缓存策略的优势. 都像SELECT,FROM和WHERE等关键字不区分大小写,但如表名和列名的属性是区分在HQL敏感. FROM 语句 使

  • JSP中操作数据库的常用SQL标签用法总结

    <sql:setDataSource> 标签设定数据源 语法结构: 复制代码 代码如下: <sql:setDataSource url="jdbcUrl" driver="driverClassName" user="userName" password="password" [var = "varName"][scope="{page | request | session |

  • 在Python程序中操作文件之flush()方法的使用教程

    flush()方法刷新内部缓冲区,像标准输入输出的fflush.这类似文件的对象,无操作. Python关闭时自动刷新文件.但是可能要关闭任何文件之前刷新数据. 语法 以下是flush()方法的语法: fileObject.flush(); 参数 NA 返回值 此方法不返回任何值. 例子 下面的例子显示了flush()方法的使用. #!/usr/bin/python # Open a file fo = open("foo.txt", "wb") print &qu

  • 在Python程序中操作文件之isatty()方法的使用教程

    如果文件已连接(与终端设备相关联)到一个tty(状)的设备,isatty()方法返回True,否则返回False. 语法 以下是isatty()方法的语法: fileObject.isatty(); 参数 NA 返回值 如果该文件被连接(与终端设备相关联)到一个tty(类似终端)设备此方法返回true,否则返回false. 例子 下面的例子显示了isatty()方法的使用. #!/usr/bin/python # Open a file fo = open("foo.txt", &qu

随机推荐