ADO编程模型之VB数据库操作小结

时间:2019-05-12 16:12:20下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《ADO编程模型之VB数据库操作小结》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《ADO编程模型之VB数据库操作小结》。

第一篇:ADO编程模型之VB数据库操作小结

ADO编程模型之VB数据库操作小结

使用ADO编程模型需添加ADO对象类库的“引用”----“Microsoft ActiveX Data Objects 2.x Library” ADO之VB数据库操作主要包括读、写、修改及删除等操作,不论是进行什么数据库操作都必须首先连接到数据库。

一、连接到数据库

1、连接到SQL数据库:

通过ADO的Connection对象可实现VB与SQL数据库的连接。一般方法如下:

Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象

cnn.ConnectionString = “Provider=SQLOLEDB.1;Password=密码;User ID=用户名;Initial Catalog=SQL数据库文件;Data Source= localhost;”

'指定提供者,设置数据源 cnn.Open

‘打开到数据库的连接 ……..cnn.Close

‘关闭到数据库的连接 或者:

Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象

cnn.Open “Provider=SQLOLEDB.1;Password=密码;User ID=用户名;Initial Catalog=SQL数据库文件;Data Source= localhost;”

‘打开到数据库的连接 ……..cnn.Close

‘关闭到数据库的连接

2、连接到ACCESS数据库:

通过ADO的Connection对象可实现VB与ACCESS数据库的连接。一般方法如下:

Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象

cnn.ConnectionString = “Provider=Microsoft.Jet.OLEDB.4.0;Data Source=ACCESS数据库文件.MDB” '指定提供者,设置数据源

cnn.Open

‘打开到数据库的连接 ……..cnn.Close

‘关闭到数据库的连接 或者: Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB”

‘打开到数据库的连接 ……..cnn.Close

‘关闭到数据库的连接

二、读数据库操作

读数据库操作一般可通过recordset对象实现。方法如下—以ACCESS数据库为例:

Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB”

‘打开到数据库的连接

Dim rs As New Recordset

'声明一个记录集对象

rs.Open [记录源, cnn, 游标类型, 锁定类型, 命令类型]

‘也可先设置记录集相关属性

text1.text= rs(“字段名称1或索引”)

‘假设读取出来的字段信息显示在文本框中,三种读取方法等价 text2.text=rs.fields(“字段名称2或索引”)text3.text= rs!字段名称3 …….rs.close

‘关闭记录集对象 cnn.Close

‘关闭与数据库的连接 set rs=Nothing

‘释放rs对象实例 set cnn=Nothing ‘释放Connection对象实例

 记录源一般为一条SQL查询语句,以实现查询目的。

 Recordset对象还保持查询返回的记录的位置,它返回第一个检索到的记录,并允许你一次一项逐步扫描其他结果。Recordset对象的部分属性及方法如下 Rs(i): 读取第i个字段的数据,i从0开始 Rs(字段名): 读取指定字段的数据 Rs.EOF:记录指针指到记录的尾部 Rs.BOF:记录指针指到记录的头部 Rs.RecordCount: 游标中的数据记录总数

Rs.PageSize:当对象设有分页时,用于指定逻辑页中的记录个数 Rs.PageCount:返回记录集中的逻辑分页数 Rs.MoveNext: 将记录指针移到下一个记录 Rs.MovePrev: 将记录指针移到上一个记录 Rs.MoveFirst: 将记录指针移到第一个记录 Rs.MoveLast: 将记录指针移到最后一个记录 rs.Delete:将当前记录删除 rs.addnew:添加一条新记录(行)

 如果要读取满足条件的数据库记录,只要在SELECT语句中增加WHERE子句即可(例如:WHERE 性别=”男”),如果要读取多条满足条件的数据库记录,可通过循环语句来实现,并且每读取一条记录后使用Rs.MoveNext移动记录指针以读取下一条记录。

三、写数据库操作

方法1:使用recordset对象(此方法一般初学者使用较多)。方法如下—以ACCESS数据库为例: Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB”

‘打开到数据库的连接

Dim rs As New Recordset

'声明一个记录集对象

rs.Open [记录源, cnn, 游标类型, 锁定类型, 命令类型]

‘也可先设置记录集相关属性 rs.addnew ‘告诉rs我们要添加一行

rs(“字段名称1或索引”)=值1

‘给要添加的行的一个字段赋值,三种方法等价 rs.fields(“字段名称2或索引”)=值2 rs!字段名称3 =值3 …….rs.update

‘通知rs我们要把这个行写入数据库 rs.close

‘关闭记录集对象 cnn.Close

‘关闭与数据库的连接 set rs=Nothing

‘释放rs对象实例 set cnn=Nothing ‘释放Connection对象实例

 addnew使用方法后,如果要放弃添加的结果,应调用记录集的CancelUpdate方法放弃。

方法2:使用Connection对象的Execute方法对表进行SQL记录插入操作(要求要熟悉SQL命令)Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB”

‘打开到数据库的连接

strSQL = “Insert Into 数据表(字段1, 字段2…..)Values(值1, 值2…..)

‘拼写Insert插入语句 cnn.Execute strSQL

'执行Insert语句实现添加 …….cnn.Close

‘关闭与数据库的连接

set cnn=Nothing ‘释放Connection对象实例

四、修改数据库操作

方法1:使用recordset对象(此方法一般初学者使用较多)。方法如下—以ACCESS数据库为例: Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open ”Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB“

‘打开到数据库的连接

Dim rs As New Recordset

'声明一个记录集对象

rs.Open [记录源, cnn, 游标类型, 锁定类型, 命令类型]

‘也可先设置记录集相关属性 …….rs(”字段名称1或索引“)=新值1

‘‘给要修改的行的一个字段赋一个新值,三种方法等价 rs.fields(”字段名称2或索引“)=新值2 rs!字段名称3 =新值3 …….rs.update

‘通知rs,我们要把修改好的记录行写入数据库 rs.close

‘关闭记录集对象 cnn.Close

‘关闭与数据库的连接 set rs=Nothing

‘释放rs对象实例 set cnn=Nothing ‘释放Connection对象实例

 如果放弃修改结果,应调用记录集的CancelUpdate方法放弃更新数据库。

方法2:使用Connection对象的Execute方法对表进行SQL记录更新操作(要求要熟悉SQL命令)Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open ”Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB“

‘打开到数据库的连接

strSQL = ”Update 数据表 Set 字段1=新值1, 字段2=新值2…..‘拼写Update语句,以便进行修改 cnn.Execute strSQL

'执行Insert语句实现添加 …….cnn.Close

‘关闭与数据库的连接

set cnn=Nothing ‘释放Connection对象实例

五、删除数据库操作

方法1:使用recordset对象(此方法一般初学者使用较多)。方法如下—以ACCESS数据库为例方法1:通过 Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB”

‘打开到数据库的连接

Dim rs As New Recordset

'声明一个记录集对象

rs.Open [记录源, cnn, 游标类型, 锁定类型, 命令类型]

‘也可先设置记录集相关属性 …….rs.Delete

‘删除当前记录 …….rs.update

‘通知rs,我们要把修改好的记录行写入数据库 rs.close

‘关闭记录集对象 cnn.Close

‘关闭与数据库的连接 set rs=Nothing

‘释放rs对象实例 set cnn=Nothing ‘释放Connection对象实例

 删除数据库记录前应先找到(查询)待删除的记录项(通过rs.Open来实现)。

方法2:使用Connection对象的Execute方法(要求使用者要熟悉SQL命令)例如:如果要将数据库“成绩.mdb”中的名字为“学生情况表”的数据表中,学号为'07001'的记录删除,可通过下列方法来实现。

Dim cnn As New ADODB.Connection ‘创建Connection对象cnn,关键字new用于创建新对象 cnn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Data

Source=ACCESS

数据库文件.MDB”

‘打开到数据库的连接

sql=“delete from学生情况表where 学号='07001'”

‘拼写delete语句,以便进行删除

cnn.Execute strSQL

'执行elete语句实现删除 …….cnn.Close

‘关闭与数据库的连接

set cnn=Nothing ‘释放Connection对象实例

附:分页简介---使用记录集

一、.原理:

分页其实是将数据库中的记录分割成若干段,并将各段记录放在同一个“逻辑页面”上“分屏显示”出来,其实显示的“逻辑页面”只有1页,只是每次显示的页面记录不同罢了。通过控制各页中数据库显示记录的不同,来刷新页面的显示内容。

二、用到的几个记录集属性

rs.pagesize:定义一页显示记录的条数; rs.recordcount:统计数据库记录总数; rs.pagecount:统计总页数;

rs.absolutepage:将数据库指针移动到当前页要显示的数据记录的第一条记录;比如有20条记录的一个数据库,我们分为一页显示5条记录,如将AbsolutePage属性设为2,则当前记录指针移至第2页第1条记录,也即将指针移动到第6条记录处,依次类推....(AbsolutePage 属性是以 1 为起始的)

第二篇:操作数据库小结

一.查询操作

对数据进行查询操作时,有两种情况:一是查询单个值,二是 查询若干条记录。

1、查询单个值

需要使用Command对象的ExecuteScalar()方法:步骤如下:(1)、创建Connection对象(数据库连接对象)。(2)、创建查询用的SQL语句。(3)、利用SQL语句和Connection对象创建Command对象。(4)、打开数据库连接,调用Connection对象的Open()方法。(5)、调用Command对象的ExecuteScalar()方法,返回一个标量值。(6)、操作完成后关闭数据库连接,调用Connection对象的Close()方法。

2、查询若干条记录

需要使用Command对象的ExecuteReader()方法:步骤如下:(1)、创建Connection对象(数据库连接对象)。(2)、创建查询用的SQL语句。(3)、利用SQL语句和Connection对象创建Command对象。(4)、打开数据库连接,调用Connection对象的Open()方法。(5)、调用Command对象的ExecuteReader()方法,返回一个DataReader对象。(6)、调用DataReader对象的Read()方法逐行读取记录,如果读到记录返回Ture,否则返回False.(7)、使用(type)dataReader[列名或索引]的方式读取这一行中某一列的值。(8)、关闭DataReader对象(9)、操作完成后关闭数据路连接,调用Connection对象的Close()方法。

二、非查询操作

对数据库执行非查询操作时,包括增加,修改,删除数据,都使用Command对象的ExecuteNonQuery()方法,步骤如下:

(1)、创建Connection对象(数据库连接对象)(2)、创建增删改用的SQL语句。(3)、利用SQL语句和Connection对象创建Command对象。(4)、打开数据库连接,调用Connection对象的Open()方法。(5)、调用Command对象的ExecuteNonQuery()方法执行命令,返回受影响的行数。(6)、操作完成后关闭数据库连接,调用Connection对象的Close()方法。

本章总结

1、使用DataReader查询数据记录,通过Command对象的ExecuteReader()方法返回一个DataReader对象。

2、使用DataReader读取数据室每次调用Read()方法读取一行数据。

3、DataReader使用完后要调用它的Close()方法关闭。

4、使用Command对象的ExecuteNonQuery()方法对数据进行增删改的操作。

5、ExecuteNonQuery()方法返回受影响的行数。

6、ListView(列表视图)控件有5种视图模式,重点是Details 列表视图的Items属性表示包含在空间中的所有项的结合,每一个项都是一个ListViewItem,使用Items.Add()方法向列表视图中添加一项 调用列表视图项的SubItems.AddRange()方法添加它的子项

ListViewItem lviStudent = new ListViewItem(loginID);创建一个ListView项 lviStudent.Tag=(int)dataReader[“StudentId”];lvStudent.Items.Add(lviStudent);//向ListView中添加一个新项 lviStudent.SubItems.AddRange(new string[] {studentName,studentNo,userState});//向当前项中添加子项

7、ContextMenuStrip(快捷菜单)控件可以与其他控件结合使用,通过设置控件的ContextMenuStrip属性来指定它的快捷菜单。

想鼠标右键单击文本框时出现快捷菜单,就选中文本框在属性窗口中找到它的ContextMenuStrip属性,选择已有的右键菜单控件 txtLoginId.Focus():

下拉列表:

创建Command对象调用Command对象的ExecuteReader()方法创建DataReader对象(sqlDataReader dataReader=command.ExecuteReader())使用DataReader的Reader()方法逐行读取数据(放回bool类型)读取当前行的某列的数据(cboGrade.Items.Add(dataReader[“列名”]))关闭DataReader对象,Close()方法

向数据库中添加数据:

创建Connection对象定义要执行的SQL语句创建Command对象执行ExecuteNonQuery()方法根据返回的结果进行后续的处理

双击显示出ID:

MessageBox.show(dataGridView1.SelectedRows[0].cells[“ColID”].value.ToString());

刷新:

1,BindStudentByLoginID(txtBox.Text)2,listView.Items.RemoveAt(Listview1.SelectedIndices[0])//只能删除选中的行(选中第几个)

第三篇:VC++中MFC用Ado连接数据库小结

VC++中MFC用Ado连接数据库小结

VC++中使用MFC通过ADO连接数据库方法小结(不包括异常的捕捉)这里主要讲MFC与SQL2000数据库的连接。1.在StdAfx.h头文件中加入此句子

#import “c:program filescommon filessystemadomsado15.dll” no_namespace rename(“EOF”,“adoEOF”)2.在App类的InitInstance()函数中加入 ::CoInitialize(NULL);//表示com库的初始化

鼠标右键点击App类名添加虚函数ExitInstance(),在其中加入代码 ::CoUninitialize();//释放com库。3.获取连接字符串。

最简单的方法就是新建一个.txt文件,将其后缀名改为.udl,双击它,在“提供程序”标签页中选择“Microsoft OLE DB Provide fo Sql Server”,然后在“连接”标签页选择填写服务器、数据库、登陆方式等信息,最后按“确定”。连接完成之后,将其用写字板打开,第三行信息,如“Provider=SQLOLEDB.1;Integrated

Security=SSPI;Persist

Security Info=False;Initial Catalog=RuleDB_Data;Data Source=PYE”即为连接字符串。注意,若数据库位于本机,在选择填写服务器一栏可直接填写(local),记得一定要加括号。4.连接数据库

在这里引入一个编写好的封装类:ADOConn。该类封装了连接数据库,对数据库进行添加、删除、修改操作及获取查询记录集操作的方法。用户可直接使用,这个类的头文件和cpp文件内容将在本文最后给出。

在一个工程里加入该类的方法为:把该类的头文件和cpp文件拷贝到工程所在的文件夹里。然后在工程的工作区选择Project->Add to Project->Files,将这两个文件选择加入。之后,就可以在程序里应用这个类了。

首先在要用到数据库的类的头文件里设一个该类的对象,即加入代码:ADOConn m_Ado;注意:记得要先在最前面加入#include “ADOConn.h”。

在应用这个对象对数据库进行操作之前,先对其初始化: m_Ado.OnInitADOConn(strConnect);其中strConnect即为上面获取的连接字符串。

若要获取数据库中的部分记录集,用m_Ado.GetRecordSet(strSql);其中strSql中存放查询语句,查询结果存放于m_Ado.m_pRecordset中,然后可用GetCollect()函数挨个获取所有符合条件的记录的各个字段的值。用完后记得用m_Ado.m_pRecordset.Close()关闭记录集。

添加、修改、删除操作,均用 m_Ado.ExecuteSQL(strSql);语句完成。

此外,若同时需要多种记录集,则还需在要用到数据库的类的头文件里添加记录集的对象,即_RecordsetPtr m_pRecordset;m_pRecordset在用之前也需初始化,初始化语句为: m_pRecordset.CreateInstance(__uuidof(Recordset));,同样的,每回记录集用完之后也得用Close()函数关闭。5.若在数据库应用程序编译时遇到102个错误,则可把Debug文件夹删了重新编译即可。ADOConn类的头文件:

#if!defined(AFX_ADOCONN_H__2B491720_FA04_4800_B616_219E55ABEA46__INCLUDED_)#define AFX_ADOCONN_H__2B491720_FA04_4800_B616_219E55ABEA46__INCLUDED_ #if _MSC_VER > 1000 #pragma once #endif // _MSC_VER > 1000 class ADOConn : public CObject { public: //添加一个指向Connection对象的指针: _ConnectionPtr m_pConnection;//添加一个指向Recordset对象的指针: _RecordsetPtr m_pRecordset;char error[1024];public: _ConnectionPtr& GetConnPtr(){return m_pConnection;} _RecordsetPtr& GetRecoPtr(){return m_pRecordset;} public: //事务回滚

BOOL RollbackTrans();//递交 事务 BOOL CommitTrans();//事务开始 BOOL BeginTrans();BOOL adoBOF();//头 BOOL adoEOF();//尾 BOOL MoveNext();//下一个 BOOL CloseTable();//关闭表

BOOL CloseADOConnection();//关闭连接

BOOL GetCollect(LPCTSTR Name,CString &lpDest);//获取某个字段的值 //执行SQL语句 包含update delete insert BOOL ExecuteSQL(LPCTSTR lpszSQL);//初始化连接数据库

BOOL OnInitADOConn(LPCTSTR ConnStr);// 执行select语句 获取记录集

_RecordsetPtr& GetRecordSet(LPCTSTR lpszSQL);ADOConn();virtual ~ADOConn();};#endif //!defined(AFX_ADOCONN_H__2B491720_FA04_4800_B616_219E55ABEA46__INCLUDED_)class CADOException : public CException { public: // Constructor CADOException(char* pchMessage);public: ~CADOException(){} CString m_strMessage;virtual BOOL GetErrorMessage(LPTSTR lpstrError, UINT nMaxError, PUINT pnHelpContext = NULL);private: int m_nError;};ADOConn类的cpp文件: #include “stdafx.h” #include “ADOConn.h” #ifdef _DEBUG #undef THIS_FILE static char THIS_FILE[]=__FILE__;#define new DEBUG_NEW #endif ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// ADOConn::ADOConn(){ memset(error,0,1024);} ADOConn::~ADOConn(){ } ////////////////////////////////////////////////////////////////////// // CADOException Class ////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////// // Construction/Destruction ////////////////////////////////////////////////////////////////////// CADOException::CADOException(char* pchMessage){ m_strMessage = pchMessage;m_nError = GetLastError();} BOOL CADOException::GetErrorMessage(LPTSTR

lpstrError,UINT nMaxError,PUINT pnHelpContext /*= NULL*/){

char text[200];if(m_nError == 0){ wsprintf(text, “%s error”,(const char*)m_strMessage);} else { wsprintf(text, “%s error #%d”,(const char*)m_strMessage, m_nError);} strncpy(lpstrError, text, nMaxError-1);return TRUE;} BOOL ADOConn::OnInitADOConn(LPCTSTR ConnStr){ ::CoInitialize(NULL);try { // 创建Connection对象

m_pConnection.CreateInstance(“ADODB.Connection”);// 设置连接字符串,必须是BSTR型或者_bstr_t类型 _bstr_t strConnect

=

_bstr_t(ConnStr);//“Provider=SQLOLEDB;Server=127.0.0.1;Database=EventLogg;uid=event;pwd=event;”;m_pConnection->Open(strConnect,“",”“,adModeUnknown);return TRUE;} // 捕捉异常 catch(_com_error e){ // 显示错误信息 TRACE(e.Description());// sprintf(error,”连接数据库失败 请检查连接字符串rn当前连接字符串为:%s“,ConnStr);// throw new CADOException(error);throw new CADOException(”连接数据库失败“);} } //执行SQL语句 包含update delete insert BOOL ADOConn::ExecuteSQL(LPCTSTR lpszSQL){ // _variant_t RecordsAffected;try { // Connection对象的Execute方法:(_bstr_t CommandText, // VARIANT * RecordsAffected, long Options)

// 其中CommandText是命令字串,通常是SQL命令。// 参数RecordsAffected是操作完成后所影响的行数,// 参数Options表示CommandText的类型:adCmdText-文本命令;adCmdTable-表名

// adCmdProc-存储过程;adCmdUnknown-未知

m_pConnection->Execute(_bstr_t(lpszSQL),NULL,adCmdText);return true;} catch(_com_error e){ TRACE(e.Description());// sprintf(error,”t执行SQL语句失败rn SQL语句为:%s“,lpszSQL);// throw new CADOException(error);throw new CADOException(”执行SQL语句失败“);} } //执行SELECT语句,获得结果集,结果集放在m_pRecordset中 _RecordsetPtr& ADOConn::GetRecordSet(LPCTSTR lpszSQL){ try { // 创建记录集对象

m_pRecordset.CreateInstance(__uuidof(Recordset));// 取得表中的记录

m_pRecordset->Open(_bstr_t(lpszSQL),m_pConnection.GetInterfacePtr(),adOpenDynamic,adLockOptimistic,adCmdText);} // 捕捉异常 catch(_com_error e){ // 显示错误信息 TRACE(e.Description());// sprintf(error,”t执行SELECT语句失败rnSELECT语句为:%s“,lpszSQL);// throw new CADOException(error);throw new CADOException(”执行SELECT语句失败“);} // 返回记录集 return m_pRecordset;} //获取某个字段的值

BOOL ADOConn::GetCollect(LPCTSTR Name,CString &lpDest){ VARIANT vt;try { vt = m_pRecordset->GetCollect(Name);/* _bstr_t bstr =(_bstr_t)vt;if(lpDest!= ”“){ strcpy(lpDest,bstr);}*/ if(vt.vt!=VT_NULL)lpDest=(LPCSTR)_bstr_t(vt);else lpDest=”“;} catch(_com_error e){ TRACE(e.Description());sprintf(error,”获取字段:%s值失败“,Name);throw new CADOException(error);} return TRUE;} //关闭数据库

BOOL ADOConn::CloseADOConnection(){ try { m_pConnection->Close();} catch(_com_error e){ TRACE(e.Description());sprintf(error,e.Description());throw new CADOException(”关闭数据库失败“);} return TRUE;} //关表

BOOL ADOConn::CloseTable(){ try { m_pRecordset->Close();} catch(_com_error e){ TRACE(e.Description());sprintf(error,e.Description());throw new CADOException(”关闭表失败“);} return TRUE;} //下一个

BOOL ADOConn::MoveNext(){ try { m_pRecordset->MoveNext();} catch(_com_error e){ TRACE(e.Description());sprintf(error,e.Description());throw new CADOException(”结果集移向下一个失败“);} return TRUE;} //尾

BOOL ADOConn::adoEOF(){ return m_pRecordset->adoEOF;} //头

BOOL ADOConn::adoBOF(){ return m_pRecordset->BOF;} //事务开始

BOOL ADOConn::BeginTrans(){ try { m_pConnection->BeginTrans();} catch(_com_error e){ TRACE(e.Description());sprintf(error,e.Description());throw new CADOException(”事务开始失败“);}

return TRUE;} //递交事务

BOOL ADOConn::CommitTrans(){ try { m_pConnection->CommitTrans();} catch(_com_error e){ TRACE(e.Description());sprintf(error,e.Description());throw new CADOException(”递交事务失败“);} return TRUE;} //事务回滚

BOOL ADOConn::RollbackTrans(){ try { m_pConnection->RollbackTrans();} catch(_com_error e){ TRACE(e.Description());sprintf(error,e.Description());throw new CADOException(”回滚事务失败");} return TRUE;}

第四篇:《数控车削编程与操作训练》之G70、G71指令教案

《数控车削编程与操作训练》

------G71、G70复合固定循环指令教案

授课章节: G71、G70复合固定循环指令 教学重点:G71、G70指令

教学难点:G71、G70指令格式、粗精加工轮廓定义 使用教材:《数控车削编程与操作训练》高等教育出版社、机械工程部《数控车削与编程》集体教案

一、复习旧识:

G90简单固定循环指令:用于单一形状固定指令 格式:

圆柱面车削循环:G90X(U)-----Z(W)-------F------;

圆锥面车削循环:G90 X(U)-----Z(W)-------R-----F------;

(各参数含义)

优点:对于加工余量较大的毛坯,刀具反复执行相同的动作,用G90指令简化了许多相同或相似的程序段,缩短了编程时间,提高了工作效率。

缺点:车削过渡尺寸较大的阶梯轴时,有些多次重复进行的动作,使用G90指令编程仍然比较麻烦。

如图1:(P33 例2—7)(请同学们思考用G90指令编写该零件的程序)

二、导入新课:

车削过渡尺寸较大的阶梯轴时,有些多次重复进行的动作,使用G90指令编程仍然比较麻烦,用G71、G70等复合循环指令更能简化编程,数控系统能自动地计算出加工路线和进给路线,控制机床自动完成工件的加工。

三、新课讲解:

1.分析G71、G70指令格式: A.G71 外圆粗车循环指令

指令格式:

G71 UΔd Re F S T ; G71 Pns Qnf UΔu WΔw;

式中:△d-背吃刀量;

e--退刀量;

ns--精加工轮廓程序段中开始程序段的段号; nf--精加工轮廓程序段中结束程序段的段号;

△u--X轴向精加工余量; △w--Z轴向精加工余量; 2.分析与G90的区别:

G90粗车循环留X向余量,Z向不留余量;

G71外圆粗车循环X向、Z向均留余量,精加工与粗加工偏移X向Δu/2,Z向△w余量。

图2-21外圆粗车循环

A为刀具循环起点;A’---B为精加工路线

B.G70 精加工循环指令

G70 P(ns)Q(nf)

3.教学难点分析:

分析G70、G71指令格式

G71 U(Δd)R(e)F S T ; ⑴

G71 P(ns)Q(nf)U(Δu)W(Δw); ⑵ N(ns).....; ........; ....F; ....S; .... ⑶

N(nf).....; G70 P(ns)Q(nf); 【难点分散一】

由指令的第⑶部分(ns~nf程序段)给出的工件精加工轨迹,精加工轨迹的起点(即ns程序段的起点)与G71的起点、终点相同,简称A点; 【难点分散二】

粗车轮廓:精车轨迹按精车余量(Δu、Δw)偏移后的轨迹,是执行G71形成的轨迹轮廓。精加工轨迹的第一段(ns程序段)只能是X轴的快速移动或切削进给,ns程序段的终点简称B点;精加工轨迹的终点(nf程序段的终点)简称C点。精车轨迹为A点→B点→C点。4.示例讲解: 教材P33 例2—7(分析粗加工、精加工走刀路线)5.课堂练习:

P56 2.6(视学生掌握情况可再多作讲解)四.作业布置:

斯沃仿真练习:P56 2.6、2.7、2.8(将毛坯改为Φ60的棒料)五.课堂小结: 在复合固定循环中,对零件的轮廓定义之后,即可完成从粗加工到精加工的全过程,使程序得到进一步简化。

1.这些复合循环指令的精车轨迹的功能有哪些? 2.G70指令的是怎么执行的?

3.这些复合循环指令各参数的含义是什么?

第五篇:数据库应用基础(第二版)第二章数据库的基本操作实验2.2之实验报告

四、实验2-2报告

1.通过上述实验,请回答下列问题

(1)LIST ____RECORD____=DISPLAY,而DISPLAY____ALL____=LIST。

(2)执行了LIST命令后,EOF()=___T__。

(3)执行了GOTOP命令后,BOF()=.T.,对吗?为什么?

答:不对,因为执行了GO TOP命令后,记录指针移动到表文件的第一条记录上,尔BOF()是测试记录指针是否在文件头的函数,首记录和文件头并不是同一个位置。

(4)如何用LIST/DISPLAY命令显示备注字段内容?

答:LIST是是滚动显示当前表中的指定记录,如果要显示备注型字段的内容,则必须在LIST命令中指定备注型字段名;DISPLAY分屏显示当前表中的指定数据。

(5)你认为用REPLACE对表文件记录进行修改,与用BROWSE命令修改有什么不同?

答:REPLACE命令是成批修改表字段值的非全屏幕编辑命令;而BROWSE命令具有现实和修改表内容的功能。

(6)SET DELETED ON/OFF语句对被逻辑删除的记录有何影响?

答:此语句制定标有删除的记录是否参与其他命令的处理。SET DELETED ON表示逻辑删除标志有效,既有删除标记的记录不参与处理;SET DELETED OFF表示逻辑删除标志无效,既有删除标记的记录参与处理。

(7)通过实验,请你归纳当EOF()为.T.时,RECNO()为多少?当BOF()为.T.时,RECNO()为多少?

答:当EOF()为.T.时,RECNO()为末记录;当BOF()为.T.时,RECNO()为文件头。

(8)用SORT命令建立排序文件后,紧接着用LIST命令却看不到排序结果,为什么?

答:因为还没有使用use打开对应文件

(9)建立索引文件时,有一个可选参数[UNIQUE],它有什么意义?你能举例说明吗?

答:[UNIQUE],当多个记录的<索引表达式>值相同时,只有其中第一个记录的值记入索引文件。

(10)请总结一下表的排序与表索引有什么不同。

答:索引是表记录排序的一种方法,同时生成一张索引表,而表的排序没有生成其他文件。

2.实验完成情况及存在问题

下载ADO编程模型之VB数据库操作小结word格式文档
下载ADO编程模型之VB数据库操作小结.doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐