这几天狂看关于读写XML文件方面的资料,虽然XML比MSSQL方便,不用安装数据库服务软件,也不用附加数据库等操作,但XML毕竟不适合做大的数据存储,因为每当查询读取XML文件时都要先读取它到数据集然后再进行查询...在.NET中很好得提供了对XML的支持,除了二进制读取方式和DOM方式之外还有ADO.NET,通过DataSet载入XML并利用XML的“SQL语句”——Xpath查询可以很方便得进行一些操作。...现在要读取特定节点的值,在VS2008里面新建一个控制台程序,敲入如下代码: using System; using System.Collections.Generic; using System.Linq...static void Main(string[] args) { DataSet ds = new DataSet(); //建一个DataSet对象用来读取...注:有纰漏错误的地方请指正,谢谢!
DataReader读取数据的原理 DataReader读取数据数据采用循环的方式检查并读取数据,数据是一条一条被拿出的。...执行查询方法,返回DataReader对象 SqlDataReader objRader = sqlCommand.ExecuteReader(); //读取数据...StudentName"].ToString() + "\t" + objRader["Gender"].ToString() + "\t"); } //关闭读取器..."\t" + objRader["ClassName"].ToString() + "\t" ); } } //关闭读取器...7.跳转下一结果集 8.逐行读取查询结果 9.关闭读取器 10.关闭连接
读取:主要是要读取数据库中的数据,但平时操作数据库还经常会需要读取表名、字段信息,所以这2个功能也做了,就是简单的输出前面得到的TableInfo结构体信息即可: '输出所有表名 Sub rbbtnOutTableName...(control As IRibbonControl) If DB_Info.TablesCount = 0 Then MsgBox "请先点击[读取表名]" Else...Dim i As Long If DB_Info.ActiveTable.FieldsCount = 0 Then MsgBox "请先点击[读取字段名
目录: 1、数据库的基础知识以及创建Access数据库 2、数据库的接口 3、使用ADO或ADO控件访问数据库 上篇文章,为大家讲解了数据库的接口,大家对ADO也有了较为基础的了解...VB为用户提供了很多访问数据库的方式: 【方法一】使用ADO对象,通过编写代码访问数据库 【方法二】使用ADO Data控件和数据环境设计器创建数据库连接,不编写代码访问数据库 一、首先我还是以Access...数据库为例,介绍ADO对象访问数据库。...ADO对象是连接应用程序和数据库的桥梁。...二、使用ADO Data控件和数据绑定设计器访问数据库 1、先介绍ADO Data控件访问数据库 在“工程”/“部件”中选中Microsoft ADO Data
ADO的Connection对象有一个OpenSchema方法,能够获取数据库的很多信息,比如表的名称等信息、字段的名称等信息,具体可以查看SchemaEnum枚举类型。...在操作数据库的过程中,很多时候会需要得到一些数据库的信息,这个时候就可以使用OpenSchema,在CADO里面增加一个最基础的获取表的名称的函数: Function GetTablesName(ret...errHandle: StrErr = Err.Description GetTablesName = RetCode.RetErr End Function 上面的方法是通过循环读取...这个函数可以很好的获取Access数据库的表名、Excel表格的Sheet名等,但sqlite数据库似乎不能够获取到,这可能是驱动程序的原因。...不过sqlite数据库可以使用其他方式来读取所需要的信息,并不一定要使用OpenSchema。 至于其他的数据库类型,因为个人较少使用,所以也没有去测试。
#import "C://program files//commonfiles//system//ado//msado15.dll" no_namespacerename ("EOF","adoEOF"...) 2、链接数据库 CoInitialize(NULL); //初始化Com组件 _ConnectionPtr conPtr...//Connection用于与数据库服务器的链接 conPtr.CreateInstance(__uuidof(Connection)); //Connection用于与数据库服务器的链接另一种方式... /******************连接数据库********************/ try { conPtr->ConnectionTimeout...//数据库链接指针 //conPtr.CreateInstance("ADODB.Connection"); //Connection用于与数据库服务器的链接
读取字段信息:这个和读取表名是一样,也是为了避免不必要的浪费时间,做成手动来读取。 ADO读取字段信息也可以使用OpenSchema,但是有的数据库也不一定支持。...像读取表名那样,很多数据库都有特定的sql语句,但是又存在返回的信息不统一的问题,特别是对字段类型的描述,不同数据库之间差异较大。...个人目前是读取表的数据,使用Recordset返回的字段信息: Function GetFieldsInfo(sTableName As String, ret() As FieldInfo) As RetCode
这里以自己的理解简单说说ADO: Conection 操作数据库和操作文件类似,像Open读取文件里那样,首先就是要打开文件,获取一个指向文件的指针。...操作数据库也差不多,首先也得打开数据库,ADO里叫做连接数据库,首先New一个Connection类,然后调用Open方法来连接数据库,只有连接成功了才能去操作数据库。...Recordset ADO读取数据库的数据,不管是使用Connection的Excute、Recordset的Open、Command的Excute,都是读取到Recordset这个类中,之后才能在VBA...所以,想对数据库读取到的数据进行更多的操作,必须要了解一下这个对象,Recordset的数据也可以想象是一个Excel表格,仍然是有行、列的,但是它不是直接使用行的索引来读取数据,而是内部有一个指针(这个指针我们无法直接操作...Excel VBA为了方便操作,在Range对象上实现了CopyFromRecordset 方法,方便使用者直接从Recordset对象中读取数据到单元格,这是Excel VBA使用ADO来操作数据库的一个方便之处
一、提交单条SQL语句 下面以一次数据库插入为例 1.定义连接字符串:Server=....;DataBase=StudentManageDB;Uid=sa;Pwd=admin,如果是连接非本机的数据库,在Server之后填写IP地址,Server服务器地址,DataBase数据库名,Uid用户名...ExecuteNonQuery方法int result = cmd.ExecuteNonQuery(); result的值为受影响的行数 7.关闭连接conn.Close(); namespace ADO.NETDemo...} Console.ReadKey(); } } } 二、提交多条Sql语句 将多条sql语句中间通过分号连接“;”,例子如下 namespace ADO.NETDemo...cmd.ExecuteScalar();ExecuteScalar方法的返回值是Object型 3.转换类型取得标识列的值Convert.ToInt32(result) 代码如下: namespace ADO.NETDemo
连接第一步(要仔细看)对于小白来讲,这里的教程最详细,连接ADO数据库第一步,要添加什么部件呢?全称是Microsoft ADO Data Control 6.0 (SP6) (OLEDB) 部件。...在Microsoft ADO Data Control 6.0 (SP6) (OLEDB)部件里有一个名叫:Adodc数据控件,要将它添加。在Adodc数据控件数据位置中找到ACCES。..."值").Value Adodc1.Recordset.MovenextEnd IfNext i该代码引用的编写者是ydl890406大大,在VB群中写这东西时,让我借用了,后来我发现有很多错误...,y大神修改几次后的还是有错误,干脆重写了一遍,这就是后来的代码。...寻找Microsoft ADO Data Control 6.0 (SP6) (OLEDB) 部件VB用ADO连接SQLServer数据库'数据源信息常量 Public Const conn As String
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/hotqin888/article/det...
添加数据:尝试过使用Recordset的Update功能,并不是所有数据库都支持,所以还是启用事物,逐条添加: '插入数据 Function InsertDB() As RetCode '选择数据源
DB信息:就是手动记录历史DB用的按钮,开始是想打开一个新的数据库就自动记录,后来发现更多的都是临时操作一下,不值得记录,所以干脆做成一个按钮来记录。...End If End Sub 这里做了一个这样的处理:因为直接记录数据库的文件名或者udl文件名,可能不大好记忆,所以需要在customUI的comboBox(scbInput)里先输入一个描述。...保存sql语句也是一样,先在scbInput输入sql语句,再保存,使用InputBox来输入sql的描述,这里做了一个不超过255个字符的处理,InputBox不能显示超过255个字符,报类型不匹配错误...MsgBox "请选择数据库。"...sql语句 Sub rbDelSQL(control As IRibbonControl) If DB_Info.db Is Nothing Then MsgBox "请选择数据库
摘要:接下来的几篇博客将要讲到如何使用ado.net实现简单的数据库操作,包括增删改等内容。...首先会介绍基础的数据库操作,然后以一个实例来进行讲解,这个实例会把一个数据表读取到winform上,然后在winform上有一些按钮和文本框,通过这些实现对数据库里的内容的增删改的操作。...,详细的说一下ado.net的简单数据库操作。...false { while (reader.Read()) //reader.Read()把光标读取的光标放在表的第一行...好了,关于ado.net数据库的操作今天就说到这里啊,剩下的晚上再写啊。 写的东西比较浅,没什么含量,太菜了,有什么失误的地方,希望看到的同学可以留言告知,谢谢! QQ:3074596466
在前面介绍的一些操作数据库的代码中,可以看到,主要的操作逻辑基本上是打开数据库-操作-关闭数据库,很多时候改变的仅仅是操作,所以,把这些封装到一个类里面,以后调用自己写的类就会更方便。...因为ADO这个东西不仅仅只有Excel VBA可以调用,只要能调用COM组件的语言都是可以使用的,所以ADO实现的方法和属性都是通用性的,对于使用Excel VBA的人来说,有些时候为了方便在Excel...添加这个引用的目的是为了使用前期绑定,方便输代码,因为使用了VBAProject来管理代码,以后其他文件需要操作数据库都添加引用这个文件即可,不会再需要添加引用ADO。...Private Enum RetCode RetSucce = 0 RetErr End Enum Private AdoConn As ADODB.Connection '用来返回错误...实现OpenDB 打开数据库就是调用ADO的Open方法,在打开的时候,主要是需要写好Provider字符串,前面基本上是使用Excel来做测试的,但是数据库有很多种,不同的数据库Provider字符串是不一样的
最近在学习ADO与数据库的相关知识,现在我将自己学到的东西整理写出来,也算是对学习的一种复习。...这篇文章主要说明如何遍历某台机器上所有的数据库服务,遍历某个服务中所有的数据库,遍历数据库中的所有表以及表中所有字段字段,最后再说明如何通过ADO操作数据库中的表。...entriesread: %d\n", dwEntriesRead); printf(" totalentries: %d\n", dwEntriesRead); } } else//函数执行错误...= NULL) { NetApiBufferFree(pBuf);//释放内存空间 } } 二、遍历数据库中服务器中所有数据库: 通过上一步我们可以遍历局域网中所有数据库服务,这个时候我们更进一步来遍历数据库服务中所有的数据库...,实现这个功能没有什么特殊的函数,主要是对系统表的应用,我们用的是系统表master.sys.database,该表中记录了服务中所有的数据库,通过ADO的方式来进行操作: //初始化COM组件库 CoInitialize
这里说到的对Excel进行的各种各样的操作,在数据库里就相当于是对数据库进行了很多步修改操作(像Update、Insert、Delete语句都是修改操作)。...直接百度一下数据库事务,看百度百科的解释就可以了,里面银行转账的例子还是非常好理解的。...具体在VBA里的使用就非常的简单了,直接调用ADO的方法就可以了: Function Begin() As Long AdoConn.BeginTrans End Function Function...,但是前面也说到过,仅仅是把Excel当作数据库来处理,Excel不是真正的数据库,很多数据库的特性是不支持的,其中事务就不能支持: 虽然执行了Rollback,但是insert的数据还是被保存了。...下面看下sqlite数据库: 可以看到,执行了Rollback,insert的数据没有保存到数据库。 执行了Commit,insert的数据才保存到数据库。
第十六天ADO.NET(通过C#代码对数据库操作) PS:vs所需连接的服务器名称“LYY\SQLEXPRESS” 实例化SqlConnection添加命名空间ctrl+....一.简单介绍 1.为什么学ADO.NET 之前我们所学只能在查询分析器里查看数据,操作数据,我们不能让普通用户去学sql,所以我们搭建一个界面(Web Winform)让用户方便的操作数据库中的数据... 2.什么事ADO.NET ADO.NET就是一组类库,这组类库可以让我们通过程序的方式访问数据库,就像System.IO下的类用类操作文件一样, System.Data.这组类是用来操作数据库...(不光是MSSql Server),它提供了统一的编程接口让操作其它数据库(Access、Oracle等)的方式和操作MSSqlServer一致 二.ADO内的类 1.常见类 Connection...ADO.Net中提供了数据集的机制,将查询结果填充到本地内存中,这样连接断开、服务器断开都不影响数据的读取。
学习ADO时总结的一些经验 用ADO操作数据库的方法步骤 ADO接口简介 ADO库包含三个基本接口:_ConnectionPtr接口、_CommandPtr接口和_RecordsetPtr接口。...基本流程 (1)初始化COM库,引入ADO库定义文件 (2)用Connection对象连接数据库 (3)利用建立好的连接,通过Connection、Command对象执行SQL命令,或利用Recordset...("EOF","adoEOF") 其最终作用同我们熟悉的#include类似,编译的时候系统会为我们生成msado15.tlh,ado15.tli两个C++头文件来定义ADO库。...// 错误信息 (LPCSTR) e.Source(), // 错误源 (LPCSTR) e.Description()); // 错误描述 ...m_pConnection->Open("Data Source=adotest;","","",adModeUnknown); State属性指明当前Connection对象的状态,0表示关闭,1表示已经打开,我们可以通过读取这个属性来作相应的处理
Console.ReadLine(); 使用string builder 类会更加节省内存空间 使用 stringbuilder 类会使SQL语句可读性更高 datereader 对象 从数据源中检索只读,只进数据流 每次读取一行数据...datareader对象 使用datereader检索数据步骤 创建command对象 调用executereader()创建datareader 对象 使用datareader 对象的read()方法逐行读取数据...读取某列的数据,(type)reader["列名"] exec cutenonquery() 方法 该方法执行的sql增删改语句 返回受影响的行数 使用executenonquery()的步骤 1 创建
领取专属 10元无门槛券
手把手带您无忧上云