Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码)

http://blog.csdn.net/helonsy/article/details/7207497

Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码)

(1)安装freeTDS

FreeTDS为Linux系统提供了TDS协议的开源客户端。由于MS SQL和Sybase使用的恰是TDS协议,所以在Linux中可以用FreeTDS连接MS SQL。

官网:http://www.freetds.org

下载:wget http://ibiblio.org/pub/Linux/ALPHA/freetds/stable/freetds-stable.tgz

安装:
[root@vm01 ~]# tar -zxvf freetds-stable.tgz
[root@vm01 ~]# cd freetds-0.91
[root@vm01 freetds-0.91]# ./configure --prefix=/usr/local/freetds --with-tdsver=8.0 --enable-msdblib
[root@vm01 freetds-0.91]# make
[root@vm01 freetds-0.91]# make install

修改环境变量:
FREETDS_HOME=/usr/local/freetds
export PATH=$FREETDS_HOME/bin:$PATH

库文件加载:
[root@vm01 freetds-0.91]# vim /etc/ld.so.conf.d/freetds.conf
/usr/local/freetds/lib
[root@vm01 freetds-0.91]# ldconfig

(2) 修改配置文件,连接数据库
(i) 添加数据源
[root@vm01 test]# vim /usr/local/freetds/etc/freetds.conf 
#zkl add
[SQL2005]
        host = 192.168.232.133
        port = 1433
        tds version=8.0
#client charset = ISO-8859-1
完成后,使用如下命令即可连接到 SQL Server 2005 .
[root@vm01 test]# tsql -S SQL2005 -U sa -P zkl
locale is "zh_CN.GB18030"
locale charset is "GB18030"
using default charset "GB18030"
1> use test  [使用test数据库]
2> go
1> select * from StuInfo [查询表信息]
2> go
StuID Name
 Age
001 zyh
 24
002 zkl
 21
003 Jim
 24
(3 rows affected)

(ii) 修改协议版本以正常连接SQL Server 2005
修改 freetds 配置文件
[root@vm01 test]# vim /usr/local/freetds/etc/freetds.conf 
[global]
        # TDS protocol version
#;      tds version = 4.2

         tds version=8.0   (这个前面不能有逗号)

连接 SQL SERVER 2005 需要使用的协议版本为 8.0,而使用 4.2 时,连接将会失败。使用 tsql 命令连接时,如果不像步骤(2)中那样配置数据源,则同样需要修改协议,然后才能使用如下命令正常连接数据库:
[root@vm01 test]# tsql -H 192.168.232.133 -p 1433 -U sa -P zkl

注意:第一个p为小写,后面的P是大写。

(3) 使用C++代码连接数据库
首先,确保协议版本是 8.0,然后编译以下C代码,测试与数据库的连接。

test.c:

     #include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h> #include <sybfront.h> //freetds头文件
#include <sybdb.h> //freetds int main(void)
{
char szUsername[] = "sa";
char szPassword[] = "zkl";
char szDBName[] = "test"; //数据库名
char szServer[] = "192.168.232.133:1433";//数据库服务器:端口 //初始化db-library
dbinit(); //连接数据库
LOGINREC *loginrec = dblogin();
DBSETLUSER(loginrec, szUsername);
DBSETLPWD(loginrec, szPassword);
DBPROCESS *dbprocess = dbopen(loginrec, szServer);//连接数据库
if(dbprocess == FAIL)
{
printf("Conect to MS SQL SERVER fail, exit!\n");
return -;
}
printf("Connect to MS SQL SERVER success!\n"); if(dbuse(dbprocess, szDBName) == FAIL)
printf("Open database failed!\n");
else
printf("Open database success!\n"); //查询数据库
printf("[查询数据库表]\n");
dbcmd(dbprocess, "select StuID, Name, Age from StuInfo");
if(dbsqlexec(dbprocess) == FAIL)
{
printf("Query table 'StuInfo' error.\n");
return -;
} DBINT result_code;
char szStuID[]={};
char szName[]={};
char szAge[]={};
int rows = ;
while ((result_code = dbresults(dbprocess)) != NO_MORE_RESULTS){
if (result_code == SUCCEED){
dbbind(dbprocess, , CHARBIND, (DBINT), (BYTE*)szStuID);
dbbind(dbprocess, , CHARBIND, (DBCHAR), (BYTE*)szName);
dbbind(dbprocess, , CHARBIND, (DBCHAR), (BYTE*)szAge);
printf("StuID\tName\tAge\n", szStuID);
while (dbnextrow(dbprocess) != NO_MORE_ROWS){
printf("%s\t", szStuID);
printf("%s\t", szName);
printf("%s\n", szAge);
}
}
} printf("[插入数据到数据库表]\n");
dbcmd(dbprocess, "insert into StuInfo(StuID, Name, Age) values(888,'James',28)");
if(dbsqlexec(dbprocess) == FAIL)
{
printf("insert into table 'StuInfo' error.\n");
return -;
}
printf("insert into table 'StuInfo' success.\n"); printf("[删除数据库表中的记录]\n");
dbcmd(dbprocess, "delete from StuInfo where StuID=888");
if(dbsqlexec(dbprocess) == FAIL)
{
printf("delete from table 'StuInfo' error.\n");
return -;
}
printf("delete from table 'StuInfo' success.\n"); //关闭数据库连接
dbclose(dbprocess); return ;
}
     #include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h> #include <sybfront.h> //freetds头文件
#include <sybdb.h> //freetds int main(void)
{
char szUsername[] = "sa";
char szPassword[] = "zkl";
char szDBName[] = "test"; //数据库名
char szServer[] = "192.168.232.133:1433";//数据库服务器:端口 //初始化db-library
dbinit(); //连接数据库
LOGINREC *loginrec = dblogin();
DBSETLUSER(loginrec, szUsername);
DBSETLPWD(loginrec, szPassword);
DBPROCESS *dbprocess = dbopen(loginrec, szServer);//连接数据库
if(dbprocess == FAIL)
{
printf("Conect to MS SQL SERVER fail, exit!\n");
return -;
}
printf("Connect to MS SQL SERVER success!\n"); if(dbuse(dbprocess, szDBName) == FAIL)
printf("Open database failed!\n");
else
printf("Open database success!\n"); //查询数据库
printf("[查询数据库表]\n");
dbcmd(dbprocess, "select StuID, Name, Age from StuInfo");
if(dbsqlexec(dbprocess) == FAIL)
{
printf("Query table 'StuInfo' error.\n");
return -;
} DBINT result_code;
char szStuID[]={};
char szName[]={};
char szAge[]={};
int rows = ;
while ((result_code = dbresults(dbprocess)) != NO_MORE_RESULTS){
if (result_code == SUCCEED){
dbbind(dbprocess, , CHARBIND, (DBINT), (BYTE*)szStuID);
dbbind(dbprocess, , CHARBIND, (DBCHAR), (BYTE*)szName);
dbbind(dbprocess, , CHARBIND, (DBCHAR), (BYTE*)szAge);
printf("StuID\tName\tAge\n", szStuID);
while (dbnextrow(dbprocess) != NO_MORE_ROWS){
printf("%s\t", szStuID);
printf("%s\t", szName);
printf("%s\n", szAge);
}
}
} printf("[插入数据到数据库表]\n");
dbcmd(dbprocess, "insert into StuInfo(StuID, Name, Age) values(888,'James',28)");
if(dbsqlexec(dbprocess) == FAIL)
{
printf("insert into table 'StuInfo' error.\n");
return -;
}
printf("insert into table 'StuInfo' success.\n"); printf("[删除数据库表中的记录]\n");
dbcmd(dbprocess, "delete from StuInfo where StuID=888");
if(dbsqlexec(dbprocess) == FAIL)
{
printf("delete from table 'StuInfo' error.\n");
return -;
}
printf("delete from table 'StuInfo' success.\n"); //关闭数据库连接
dbclose(dbprocess); return ;
}

Makefile:
-----------------------------------------------
default:
gcc test.c -o test -L/usr/local/freetds/lib -lsybdb -I/usr/local/freetds/include

Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码)的更多相关文章

  1. 下载-MS SQL Server 2005(大全版)含开发人员版、企业版、标准版【转】

    中文名称:微软SQL Server 2005 英文名称:MS SQL Server 2005资源类型:ISO版本:开发人员版.企业版.标准版发行时间:2006年制作发行:微软公司地区:大陆语言:普通话 ...

  2. 烂泥:SQL Server 2005数据库备份与恢复

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 服务器的迁移,因为业务使用的数据库是SQL Server 2005,所以就要首先对数据库进行备份. 备份可以分为手动备份和自动备份,我们先来介绍手动备份 ...

  3. 如何创建和还原SQL Server 2005数据库?

    在还原SQL Server 2005数据库文件之前,建议先把要还原的数据库文件复制粘贴到某个盘的根目录下,这样便于一会儿找到相关的文件,比如C盘. 先打开SQL Server 2005的Microso ...

  4. SQL Server 2005数据库定期备份(非常详细)与 SQL Server 2005数据库备份定期清理

     SQL Server 2005数据库定期备份 分类: SQL Server 20052011-01-06 16:25 3320人阅读 评论(1) 收藏 举报 sql server数据库sqlserv ...

  5. Linux下用freetds执行SQL Server的sql语句和存储过程

    Linux下用freetds执行SQL Server的sql语句和存储过程 http://www.linuxidc.com/Linux/2012-06/61617.htm freetds相关 http ...

  6. SQL server 2005数据库的还原与备份

    一.SQL数据库的备份: 1.依次打开 开始菜单 → 程序 → Microsoft SQL Server 2005→SQL Server Management Studio ,这里我以UMVTEST命 ...

  7. [SQL SERVER 2005]数据库差异备份及还原

    因为之前遇到还原差异备份,最开始遇到SQLServer报错:”无法还原日志备份或差异备份,因为没有文件可用于前滚“.查阅很多资料后,终于得到解决.收集整理成这篇随笔. 问题原因:出现这种错误绝大多数是 ...

  8. 烂泥:SQL Server 2005数据库安装

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 为了能更好的利用服务器,所以打算把该业务进行迁移.因为该业务比较特殊,需要服务器上有相应的硬件支持,所以打算直接升级该服务器目前的操作系统.目前公司服务 ...

  9. 修改SQL Server 2005 数据库文件名字

    对于SQLServer 2005的数据库文件名字的修改.不多说,见图: 对于数据库名的更改直接选中要修改的数据库,F2,你懂的,不懂的可以去屎了.....0.0 下面要修改数据库的文件名 原理就是利用 ...

随机推荐

  1. 远程桌面连接 win7 主机提示“您的凭据不工作”的解决办法

    搞了大半天,找了百度N中方式操作,至少翻看10种以上解决方式,结果还是不得行 索性使用了360搜索,搜了几次就搞定了. 解决办法: “ 最重要一点, 主机上要允许用户以非guest身份登录:主机上运行 ...

  2. 大家一起Aop

    一.前言 1.在项目中无处不充斥着记录日志的代码,各种try catch,实在是有点看着不爽.这不,果断要想法子偷个懒儿. 二.摘要 鄙人不才,先总结一下个人想到的可实现AOP的几种思路: 1.通过继 ...

  3. RemoteIE 开发者可跨平台使用IE测试网页

    RemoteIE,这是一个基于微软Azure的服务,它允许开发者在最新版本的IE(Windows 10技术预览版)中测试他们的网页,而不需要安装或在虚拟机中设置对应的系统.要想使用这项服务,开发者需要 ...

  4. node基本理念(事件、多线程、进程)

    关于node的几点理解: 1.所谓的node单线程,是指node的event loop,也就是我们的业务脚本是跑在一个单线程中的,可以理解为主线程: 2.若存在IO操作,例如文件.网络,是单独在线程里 ...

  5. Javascript本质第二篇:执行上下文

    在上一篇文章<Javascript本质第一篇:核心概念>中,对Javascript执行上下文做了解释,但是这些都是基于Javascript标准中对执行上下文的定义,也就是说理论上的东西,本 ...

  6. eclipse下打包实践

    前提: 配置好打包相关的插件,看打包的结果分别添加不同的plugin,装好m2eclipse. 以下步骤以war包的packing为例. 步骤: 如下图:右键,选择Run As 或者 Debug As ...

  7. Clang Format

    1,最近项目代码要求规范化,在网上找了个Xcode插件:Clang Format ,下载地址:https://github.com/travisjeffery/ClangFormat-Xcode 2, ...

  8. Xcode升级 Alcatraz 无法使用

    Alcatraz 主要是可以管理xcode 插件 随着 Xcode 的更新 Alcatraz 有可能无法使用 以下是解决办法: 1,关闭Xcode 2,如果已经安装过 Alcatraz,先卸载掉,然后 ...

  9. iOS中通讯录的开发

    通讯录开发主要是获取用户手机中的联系人,进而可以在应用中添加好友 一 .如何访问通讯录 (1)在iOS9之前,有两个框架可以访问用户的通讯录 AddressBookUI.framework: 提供了联 ...

  10. HTML5系列:HTML5本地存储

    1. Web Storage存储 HTML4在客户端存储数据通常使用Cookie存储机制将数据保存在用户的客户端,但使用Cookie方式存储客户端数据存在一系列的制约发展因素,如限制存储数据空间大小. ...