ADO.NET操作MySQL数据库
前言
ADO.NET包括5大对象,分别是Connection、Command、DataReader、DataSet、DataAdapter,使用ADO.NET访问数据库有两个步骤:建立数据库连接、读取或更新数据。读取数据主要有两种方法:Command与DataReader、DataAdapter与DataSet。
连接mysql数据库准备工作
第一步:建立数据库连接
1.定义全局变量
- //创建command对象
- private MySqlCommand cmd = null;
- //创建connection连接对象
- private MySqlConnection conn = null;
2.建立数据库连接
- //数据库连接字符串
- String connstr = "server=localhost;Database =test;uid=root;pwd=1;charset=utf8";
- //建立数据库连接
- conn = new MySqlConnection(connstr);
第二步:读取数据
1.command和DataReader对象读取数据
- MySqlDataReader reader = null;
- try
- {
- conn.Open(); //②打开数据库连接
- cmd = new MySqlCommand("select * from comment", conn); //③使用指定的SQL命令和连接对象创建SqlCommand对象
- reader = cmd.ExecuteReader(); //④执行Command的ExecuteReader()方法
- //⑤将DataReader绑定到数据控件中
- DataTable dt = new DataTable();
- dt.Load(reader);
- dataGridView1.DataSource = dt;
- }catch (Exception){
- throw;
- }finally{
- //⑥关闭DataReader
- reader.Close();
- //⑦关闭连接
- conn.Close();
- }
2.DataSet和DataAdapter对象读取数据
- try
- {
- string mysqlText = "select * from comment;";
- //使用指定的SQL命令和连接对象创建SqlDataAdapter对象
- MySqlDataAdapter mysda = new MySqlDataAdapter(mysqlText, conn);
- DataSet ds = new DataSet(); //创建DataSet对象
- //使用SqlDataAdapter的Fill方法填充DataSet mysda.Fill(ds, "comment");
- //将DataSet中的表绑定到数据控件中
- BindingSource bs;
- bs = new BindingSource();
- bs.DataSource = ds.Tables["comment"];
- dataGridView1.DataSource = bs;
- }
- catch (Exception) {
- throw;
- }
第三步:更新数据
1.command对象更新数据
- //数据库连接字符串
- String connstr = "server=localhost;Database =test;uid=root;pwd=1;charset=utf8";
- //建立数据库连接
- using (conn = new MySqlConnection(connstr))
- {
- conn.Open();
- //启动一个事务
- using (MySqlTransaction transaction = conn.BeginTransaction())
- {
- using (cmd=conn.CreateCommand())
- {
- try
- {
- cmd.Transaction = transaction; //为命令指定事务
- cmd.CommandText = "insert into comment(quantity,comment) value('11','很好');";
- cmd.ExecuteNonQuery();
- cmd.CommandText = "insert into comment(quantity,comment) value('12','很好');";
- cmd.ExecuteNonQuery();
- transaction.Commit(); //事务提交
- }
- catch (Exception)
- {
- transaction.Rollback(); //事务回滚
- }
- }
- }
- }
2.DataAdapter对象更新数据
- <span style="font-size:18px;">//数据库连接字符串
- String connstr = "server=localhost;Database =test;uid=root;pwd=1;charset=utf8";
- //建立数据库连接
- conn = new MySqlConnection(connstr);
- try
- {
- //comment是表名,quantity是字段名
- string mysqlText = "select * from comment;";
- MySqlDataAdapter mysda = new MySqlDataAdapter(mysqlText, conn);
- DataSet ds = new DataSet();
- mysda.Fill(ds, "comment");
- //绑定MySqlDataAdapter对象,自动生成从DataSet更新MySql的命令
- MySqlCommandBuilder cb = new MySqlCommandBuilder(mysda);
- //更新ds中的数据
- ds.Tables["comment"].Rows[0]["quantity"] = 111;
- //更新数据库中的数据
- mysda.Update(ds, "comment");
- }
- catch (Exception)
- {
- throw;
- }</span>
总结
ADO.NET操作MySQL数据库的更多相关文章
- 以ADO形式操作mysql数据库
首先得需要一个连接mysql的helper类: public class MySqlHelper { #region [ Connection ] public static string conne ...
- Code First操作Mysql数据库
前面博客也讲了,自己做一个网站,选用的是MVC+EF Code First+MySql+EasyUI,先说下技术选型.一.为什么选择MVC? 因为之前自己做的系统大部分是webForm,MVC的之前也 ...
- C++操作Mysql数据库/Linux下
本文链接:https://blog.csdn.net/Tanswer_/article/details/72796570想用C++写项目,数据库是必须的,所以这两天学了一下C++操作Mysql数据库的 ...
- PHP操作MySQL数据库5个步骤
PHP操作MySQL数据库一般可分为5个步骤:1.连接MySQL数据库服务器:2.选择数据库:3.执行SQL语句:4.关闭结果集:5断开与MySQL数据库服务器连接. 1.用mysql_connect ...
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- 转 用C API 操作MySQL数据库
用C API 操作MySQL数据库 参考MYSQL的帮助文档整理 这里归纳了C API可使用的函数,并在下一节详细介绍了它们.请参见25.2.3节,“C API函数描述”. 函数 描述 mysql_a ...
- PHP操作mysql数据库:[2]查询数据听语音
本文主要详细讲解如何使用php语言,对mysql数据库进行查询.添加.删除.更新等操作. 工具/原料 Macromedia Dreamweaver 8 mysql数据库,php语言 一.前言 ...
- JDBC操作MySQL数据库案例
JDBC操作MySQL数据库案例 import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...
- shell脚本操作mysql数据库
shell脚本操作mysql数据库,使用mysql的-e参数可以执行各种sql的(创建,删除,增,删,改.查)等各种操作 mysql -hhostname -Pport -uusername -pp ...
随机推荐
- ZooKeeper学习之路 (六)ZooKeeper API的简单使用(二)级联删除与创建
编程思维训练 1.级联查看某节点下所有节点及节点值 2.删除一个节点,不管有有没有任何子节点 3.级联创建任意节点 4.清空子节点 ZKTest.java public class ZKTest { ...
- 【php】获取ip
addBoard.php中获取到ip $ip=$_SERVER['REMOTE_ADDR']; 通过ajax采取POST方式发送到服务器 $("#submit").on(" ...
- 【vue】父向子组件传参、子组件向父传参
1.父向子组件传参 App.vue为父,引入componetA组件之后,则可以在App.vue中使用标签(注意驼峰写法要改成componet-a写法,因为html对大小写不敏感,componenta与 ...
- 3、Android-全局大喇叭-广播机制
所谓的官博机制可以理解成为1对多的概念 即一个喇叭所有的人都能听到(统一范围内) 为了便于及逆行系统级别的消息通知 Android引入了一套广播机制 而且更容易进行实现. 3.1.广播机制的简介 再A ...
- Python 多线程 使用线程 (二)
Python中实现多线程需要使用到 threading 库,其中每一个 Thread类 的实例控制一个线程. Thread类 #类签名 def __init__(self, group=None, t ...
- myeclipse调用loadrunner函数开发测试脚本
myeclipse调用loadrunner函数开发测试脚本 一.使用myeclipse开发性能测试脚本 1.使用Eclipse新建一个Java工程,将目录%LoadRunner_Home%\class ...
- 使用Docker发布.NET CORE API
1.使用VS 2015 新建了一个Core API项目,然后把他的依赖升级到最新(我机器VS 2015默认的包都是rc版本),然后publish. 2.在publish目录的同级目录下,新建Docke ...
- 【PTA 天梯赛】L3-002 特殊堆栈(二分)
堆栈是一种经典的后进先出的线性结构,相关的操作主要有“入栈”(在堆栈顶插入一个元素)和“出栈”(将栈顶元素返回并从堆栈中删除).本题要求你实现另一个附加的操作:“取中值”——即返回所有堆栈中元素键值的 ...
- 需求:promise执行买菜做饭过程
需求:promise执行买菜做饭过程 1.买菜 2.洗菜 3.做饭 4.吃饭 <!DOCTYPE html> <html lang="en"> <he ...
- ElasticSearch优化系列六:索引过程
大家可能会遇到索引数据比较慢的过程.其实明白索引的原理就可以有针对性的进行优化.ES索引的过程到相对Lucene的索引过程多了分布式数据的扩展,而这ES主要是用tranlog进行各节点之间的数据平衡. ...