c++利用SqlApi访问SqlServer数据库(存储过程篇)

来源:互联网 发布:C语言经典算法实现 编辑:程序博客网 时间:2024/06/06 05:37

一、SqlApi介绍

    SqlApi++是一个为访问Sql数据库而编写的库。支持对Oracle, SQL Server, DB2, Sybase, Informix, InterBase, SQLBase, MySQL, PostgreSQL, SQLite, ODBC数据库的访问。他提供简单的访问数据库接口,开发者可以根据实际情况自行对其封装。他拥有完善的文档和编程实例,开发者可以快速入手。

二、命令解析

    1、  连接数据库函数Connect,如下:

1
2
void Connect( const SAString &sDBString , const SAString &sUserID , const SAString &sPassword , 
SAClient_t eSAClient = SA_Client_NotSpecified, saConnectionHandler_t fHandler = NULL);

 参数解析:    

sDBString:要连接的数据库

sUserID:登录用户名

sPassword:登录密码

eSAClient:用于指定连接何种数据库

fHandler:用于指定回调函数

  2  绑定sql命令函数setCommandText,如下:

1
2
void setCommandText( const SAString &sCmd,SACommandType_t eCmdType
  = SA_CmdUnknown );

 参数解析:

sCmdsql命令

eCmdType:指定命令类型

    3、  准备函数Prepare,如下:

1
virtual void Prepare();

   4、执行函数Execute,如下:

1
virtual void Execute();

 注意:如果执行存储过程中带输入参数,需要先执行 Prepare()函数。

  5  获取结果函数,如下:

1
bool FetchNext();

 三、使用方法

    1、  创建数据库的连接对象;

    2、  根据数据库连接对象,创建数据库命令对象,并绑定要执行的语句或者存储过程名;

    3、  执行语句或者存储过程;

    4、  获取返回的值。

四、使用举例

    如本机上有一SqlServer数据库。数据库名为LittleBee,登录用户名sa,密码为tiger。数据库中有一表叫dbo.DM_Runtime,表结构及数据如下:

数据库中有一存储过程sp_GetRunDate,存储过程内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
-- =============================================
-- Author:  <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
CREATE PROCEDURE [dbo].[sp_GetRunDate]
AS
BEGIN
 SELECT TOP 1 import_date FROM dbo.DM_Runtime 
END

 使用C++程序调用实例我用的是vs2010如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include "stdafx.h"
#include <stdio.h>  // for printf
#include <SQLAPI.h> // main SQLAPI++ header
#pragma comment(lib,"F:\\lib\\SQLAPI3.7.34\\lib\\sqlapi.lib")
int _tmain(int argc, _TCHAR* argv[])
{
 SAConnection con; // connection object
 SACommand cmd(&con);    // command object
 try
 {
  // connect to database (Oracle in our example)
  con.Connect("127.0.0.1@LittleBee""sa""tiger", SA_SQLServer_Client);
  cmd.setCommandText("sp_GetRunDate");
  //cmd.setCommandText("SELECT TOP 1 import_date FROM dbo.DM_Runtime");
  // Select from our test table
  cmd.Execute();
  // fetch results row by row and print results
  while(cmd.FetchNext())
  {
   printf("sp_GetRunDate'%s'\n"
    cmd.Field("import_date").asString());
  }
  // commit changes on success
  con.Commit();
  printf("Rows selected!\n");
 }
 catch(SAException &x)
 {
  // SAConnection::Rollback()
  // can also throw an exception
  // (if a network error for example),
  // we will be ready
  try
  {
   // on error rollback changes
   con.Rollback();
  }
  catch(SAException &)
  {
  }
  // print error message
  printf("%s\n", (const char*)x.ErrText());
 }
 return 0;
}

 如果无误的话,将会在命令行看到sp_GetRunDate'20130719'结果。

参考文档如下:

SqlApi的官网:http://www.sqlapi.com/index.html

SqlApi库下载地址:http://www.sqlapi.com/Download/index.html

当然SqlApi也有破解版,为了支持正版,这里就不提供破解版下载链接。亲可以自己在网上收一下。

本实例源码及文档:http://yunpan.cn/QD894ZF4gpZpk 

需要访问密码者,请发我邮箱mokimail126@126.com索取


本文转载自:http://my.oschina.net/u/1426828/blog/187417

0 0
原创粉丝点击