请问在Linux下面Sybase是否有C/C++的编程接口?

hehefaint 2002-02-27 09:18:21
谢谢了
...全文
147 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
BugLu 2002-03-22
  • 打赏
  • 举报
回复
//使用范例
#include "database.h"
//定义自己所需的数据结构
class MyDataProc:public DatabaseProc
{
public:
char Name[10];
char tzrq[10];
double balance;
DECLARE_DATAPROC(MyDataProc)
virtual void DataExchange();
virtual void DataProc();
};
//数据交换,DatabaseProc定义DataExchange为虚拟函数,必须写出自己的实例
void MyDataProc::DataExchange()
{
_DDE(NTBSTRINGBIND,Name); //数据绑定到成员变量
_DDE(FLT8BIND,&balance);
_DDE(NTBSTRINGBIND,tzrq);
}
//对数据的处理
void MyDataProc::DataProc()
{
printf("%s %12.2f %s\n",Name,balance,tzrq);
}

void main()
{
Database db("xykdbo","passwd");//库名,密码
MyDataProc dbp(db);
//准备sql语句
dbp.SetSqlCmd("select name,current_balance,convert(char(12),transaction_date,112) from account_line_item where card='5359180770192306'");
//执行sql语句
dbp.Exec();
}
tobyzhu 2002-03-22
  • 打赏
  • 举报
回复
to:BugLu() 你说自己封装的就不奇怪拉~~~~~~~谢谢拉~~~有机会多交流
BugLu 2002-03-22
  • 打赏
  • 举报
回复
//database.C
#include "database.h"

int err_handler(DBPROCESS *dbproc,int Serverity,int dberr,int oserr,char *dberrstr,char *oserrstr)
{
if((dbproc==NULL)||(DBDEAD(dbproc)))
return(-1);
else{
if(dberr!=DBNOERR)
fprintf(stderr,"DB_Library error:\n\t%s\n",dberrstr);
if(oserr!=DBNOERR)
fprintf(stderr,"Operating_system error:\n\t%s\n",oserrstr);
printf("Serverity=%d\n",Serverity);
return(0);
}
}

int msg_handler(DBPROCESS *dbproc,DBINT msgno,int msgstate,int Serverity,char *msgtext,char *srvname,char *procname,DBUSMALLINT line)
{
if((dbproc==NULL)||(DBDEAD(dbproc)))
return(-1);
else{
fprintf(stderr,"Server=%s Procname=%d \n",srvname,procname);
fprintf(stderr,"MessageNo=%d State=%d Serverity=%d Line=%d\n",msgno,msgstate,Serverity,line);
fprintf(stderr,"Message:=%s \n",msgtext);
}
return 1;
}

Database::Database(char *usr,char *pwd)
{
LOGINREC *login;
if(dbinit()==FAIL){
printf("Database initalize error\n");exit(-1);
}
dberrhandle(err_handler);
//dbmsghandle(msg_handler);
login=dblogin();
DBSETLUSER(login,usr);
DBSETLPWD(login,pwd);
dbproc=dbopen(login,NULL);
}

Database::~Database()
{
dbclose(dbproc);
dbexit();
}

DatabaseProc::DatabaseProc(const Database &db)
{
dbproc=db.dbproc;
}

void DatabaseProc::SetSqlCmd(CString s)
{
sqlcmd=s;
}

void DatabaseProc::DataProc()
{
}

void DatabaseProc::DataExchange()
{
}

void DatabaseProc::Exec()
{
RETCODE ret;
dbfcmd(dbproc,sqlcmd);
dbsqlexec(dbproc);
while((ret=dbresults(dbproc))!=NO_MORE_RESULTS){
if(ret==SUCCEED){
bindcount=1;
DataExchange();
while(dbnextrow(dbproc)!=NO_MORE_ROWS){
DataProc();
}
}
}
}
BugLu 2002-03-22
  • 打赏
  • 举报
回复
//database.h
#if !defined(_DATABASE_H)
#define _DATABASE_H

#include <stdio.h>
#include <stdlib.h>
#include "stdafc.h"
#include "cstring.h"
#include "sybfront.h"
#include "sybdb.h"
#include "syberror.h"

int err_handler(DBPROCESS *,int,int,int,char*,char*);
int msg_handler(DBPROCESS *,DBINT,int,int,char*,char*,char*,DBUSMALLINT);

class Database
{
private:
char ServerName[10];
char Passwd[10];
char UsrName[10];
public:
DBPROCESS *dbproc;
Database(char *UsrName,char *Passwd);
~Database();
BOOL Connect();
void Disconect();
};

class DatabaseProc
{
public:
DBPROCESS *dbproc;
int bindcount;
CString sqlcmd;
DatabaseProc(const Database &db);
void SetSqlCmd(CString cmd);
void Exec();
virtual void DataExchange();//数据交换
virtual void DataProc(); //数据处理
};

#define DECLARE_DATAPROC(dp_class) \
dp_class(const Database &db):DatabaseProc(db)\
{\
bindcount=1;dbproc=db.dbproc;\
}
#define _DDE(bmode,v) dbbind(dbproc,bindcount++,bmode,(DBINT)0,(CS_BYTE*)(v));
#endif //end of _DATABASE_H
BugLu 2002-03-22
  • 打赏
  • 举报
回复
我自己把DB-LIBRARY用C++封装了一下,写数据库程序可以快很多,
只不过SYBASE原来的DB_Library的头文件是针对c定义的,不能用在
C++下,需要改动一下.
tobyzhu 2002-03-21
  • 打赏
  • 举报
回复
To:BugLu() 你有LINUX下的SYBASE的c++的DB-LIBRARY/CT-LIBRARY?

什么地方找到的呀,可否共享一个给我?
tobyzhu@126.com
BugLu 2002-03-21
  • 打赏
  • 举报
回复
TO::tobyzhu(yaba) 有标准的C的接口,没有C++的接口~~~????????、
乱说!我明明写了一个。

hehefaint 2002-03-07
  • 打赏
  • 举报
回复
已经搞定,谢谢了
hehefaint 2002-03-07
  • 打赏
  • 举报
回复
老大,救命啊。
mylilo@263.net
tobyzhu 2002-03-05
  • 打赏
  • 举报
回复
有标准的C的接口,没有C++的接口~~~
你如果要的话,我可以给你~~~
wwwunix 2002-03-05
  • 打赏
  • 举报
回复
有呀,就是Clib
  Eclipse最初由OTI和IBM两家公司的IDE产品开发组创建,起始于1999年4月。IBM提供了最初的Eclipse代码基础,包括Platform、JDT和PDE。目前由IBM牵头,围绕着Eclipse项目已经发展成为了一个庞大的Eclipse联盟,有150多家软件公司参与到Eclipse项目中,其中包括Borland、Rational Software、Red Hat及Sybase等。 Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括 Java 开发工具(Java Development Tools,JDT)。 虽然大多数用户很乐于将 Eclipse 当作 Java IDE 来使用,但 Eclipse 的目标不仅限于此。Eclipse 还包括插件开发环境(Plug-in Development Environment,PDE),这个组件主要针对希望扩展 Eclipse 的软件开发人员,因为它允许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每样东西都是插件,对于给 Eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工具开发人员都具有同等的发挥场所。 这种平等和一致性并不仅限于 Java 开发工具。尽管 Eclipse 是使用 Java 语言开发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C++、COBOL 和 Eiffel 等编程语言的插件已经可用,或预计会推出。Eclipse 框架还可用来作为与软件开发无关的其他应用程序类型的基础,比如内容管理系统。 Eclipse还可以为Adobe Flex 2提供编程的平台和可视化界面。
  Eclipse最初由OTI和IBM两家公司的IDE产品开发组创建,起始于1999年4月。IBM提供了最初的Eclipse代码基础,包括Platform、JDT和PDE。目前由IBM牵头,围绕着Eclipse项目已经发展成为了一个庞大的Eclipse联盟,有150多家软件公司参与到Eclipse项目中,其中包括Borland、Rational Software、Red Hat及Sybase等。 Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括 Java 开发工具(Java Development Tools,JDT)。 虽然大多数用户很乐于将 Eclipse 当作 Java IDE 来使用,但 Eclipse 的目标不仅限于此。Eclipse 还包括插件开发环境(Plug-in Development Environment,PDE),这个组件主要针对希望扩展 Eclipse 的软件开发人员,因为它允许他们构建与 Eclipse 环境无缝集成的工具。由于 Eclipse 中的每样东西都是插件,对于给 Eclipse 提供插件,以及给用户提供一致和统一的集成开发环境而言,所有工具开发人员都具有同等的发挥场所。 这种平等和一致性并不仅限于 Java 开发工具。尽管 Eclipse 是使用 Java 语言开发的,但它的用途并不限于 Java 语言;例如,支持诸如 C/C++、COBOL 和 Eiffel 等编程语言的插件已经可用,或预计会推出。Eclipse 框架还可用来作为与软件开发无关的其他应用程序类型的基础,比如内容管理系统。 Eclipse还可以为Adobe Flex 2提供编程的平台和可视化界面。
JAVA相关基础知识 1、面向对象的特征有哪些方面 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。 2.继承: 继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。 3.封装: 封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 4. 多态性: 多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。 2、String是最基本的数据类型吗? 基本数据类型包括byte、int、char、long、float、double、boolean和short。 java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类 3、int 和 Integer 有什么区别 Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。 原始类型封装类 booleanBoolean charCharacter byteByte shortShort intInteger longLong floatFloat doubleDouble 引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。 4、String 和StringBuffer的区别 JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用StringBuffers来动态构造字符数据。 5、运行时异常与一般异常有何异同? 异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。 6、说出Servlet的生命周期,并说出Servlet和CGI的区别。 Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。 7、说出ArrayList,Vector, LinkedList的存储性能和特性 ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。 8、EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别。 EJB包括Session Bean、Entity Bean、Message Driven Bea
超级有影响力的Java面试题大全文档 1.抽象: 抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。 2.继承:  继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。 3.封装:  封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面向对象计算始于这个基本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受保护的接口访问其他对象。 4. 多态性:  多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有灵活、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。 5、String是最基本的数据类型吗?  基本数据类型包括byte、int、char、long、float、double、boolean和short。  java.lang.String类是final类型的,因此不可以继承这个类、不能修改这个类。为了提高效率节省空间,我们应该用StringBuffer类 6、int 和 Integer 有什么区别  Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。Int是java的原始数据类型,Integer是java为int提供的封装类。Java为每个原始类型提供了封装类。 原始类型 封装类 boolean Boolean char Character byte Byte short Short int Integer long Long float Float double Double  引用类型和原始类型的行为完全不同,并且它们具有不同的语义。引用类型和原始类型具有不同的特征和用法,它们包括:大小和速度问题,这种类型以哪种类型的数据结构存储,当引用类型和原始类型用作某个类的实例数据时所指定的缺省值。对象引用实例变量的缺省值为 null,而原始类型实例变量的缺省值与它们的类型有关。 7、String 和StringBuffer的区别  JAVA平台提供了两个类:String和StringBuffer,它们可以储存和操作字符串,即包含多个字符的字符数据。这个String类提供了数值不可改变的字符串。而这个StringBuffer类提供的字符串进行修改。当你知道字符数据要改变的时候你就可以使用StringBuffer。典型地,你可以使用 StringBuffers来动态构造字符数据。 8、运行时异常与一般异常有何异同?  异常表示程序运行过程中可能出现的非正常状态,运行时异常表示虚拟机的通常操作中可能遇到的异常,是一种常见运行错误。java编译器要求方法必须声明抛出可能发生的非运行时异常,但是并不要求必须声明抛出未被捕获的运行时异常。 9、说出Servlet的生命周期,并说出Servlet和CGI的区别。  Servlet被服务器实例化后,容器运行其init方法,请求到达时运行其service方法,service方法自动派遣运行与请求对应的doXXX方法(doGet,doPost)等,当服务器决定将实例销毁的时候调用其destroy方法。 与cgi的区别在于servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet。 10、说出ArrayList,Vector, LinkedList的存储性能和特性  ArrayList 和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据需要进行前向或后向遍历,但是插入数据时只需要记录本项的前后项即可,所以插入速度较快。 11、EJB是基于哪些技术实现的?并说出SessionBean和EntityBean的区别,StatefulBean和StatelessBean的区别。 EJB包括Ses

2,596

社区成员

发帖
与我相关
我的任务
社区描述
Sybase相关技术讨论区
社区管理员
  • Sybase社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧