网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.Oracle、SQL Server中如何锁定DB.
.Sql server中时间查询的一个比较.
.一些SQL Server的应用实例.
.特殊数据(SQL).
.MDF文件在SQL Server数据库中恢复.
.正确配置和使用SQL mail.
.SQL Server的空值处理策略.
.MS SQLSERVER 中如何得到表的创建.
.sql server的几个函数要记录.
.sql server 灾难恢复.
.轻松掌握密码有效性验证失败的处.
.SQL Server 服务器安装剖析.
.使用Microsoft SQL Server 2000的.
.MSSQLServer2000的排序功能原来这.
.SQL Server编写存储过程小工具(三.
.使用SQL Server 将现有代码作为W.
.教你快速确定SQL Server栏中的最.
.教你轻松掌握SQL Server错误信息.
.怎样获得SQL Server的优化性能?.
.SQL2005生成SQL2000脚本的一些解.

在Linux下访问MS SQL Server数据库 

发表日期:2001-7-10


 Linux作为一个免费的Unix类操作系统,以其开放性源代码、多任务、Xwindow等特点为众多的用户所采用,并有很多企业采用Linux来作为其内部网的全功能服务器(WWW,FTP,Email、DNS)。企业的内部网不仅要提供文本信息的访问,还要能提供对企业关系数据库中的信息的访问。SQL Server以其低成本、性能高以及与NT的有效集成等特性为许多企业所采用,但Microsoft不提供其Unix下的客户端,为这类应用带来了困难。本文则提出了这一问题的解决方案。

安装Sybase客户端
  首先从Microsoft SQL Server和Sybase SQL Server的关系说起。两公司曾共同开发OS/2上的数据库SQL Server for OS/2,此后两公司又独立开发升级系统,Sybase的客户端可以访问Microsoft SQL Server。

  和其他数据库公司相比,可以说Sybase公司对Linux是最有善意的,它虽不提供Linux下的SQL Server,但提供了免费的CT-LIB的客户端,这也可能是许多IT管理人员在为公司数据库选型时不再考虑Oracle或Informix的理由之一。当然现在情况有所改变。

  Sybase公司发布的OpenClientforLinux是a.out格式的,在互联网上有人将其转化为ELF和动态链接的ELF格式,可从下列地址上寻找下载:http://www.mbay.net/~mpeppler。最好同时下载两个版本,正常使用时采用动态链接的版本,但有的程序在编译时可能需要一个库(libblk.a),只在ELF里面包含。

  下载以后,键入如下命令展开(假设当前目录是/usr/tmp):

  tar zxvf linux elf dynamic tar.gz

  然后将其移至/usr/local目录:

  mv sybase /usr/local

  编译和使用Sybase客户端需要进行如下的设置:

  1.Interface文件举例如下:

  MSSQL

  Query tcp ether mysql 1433

  其中:

MSSQL是客户端使用的服务器名,以后引用MSSQL即可;

mysql是服务器的地址或名字,如果是名字,则系统能够查到其IP地址;

1433是SQL Server的端口号,Microsoft SQL Server的缺省值是1433,Sybase是5000。
  2.SYBASE环境变量,内容是Sybase客户端所在的目录:

  ExportSYBASE=/usr/local/sybase

  3.如果编译Sybase客户端中的例子,则还要设置环境变量SYBPLATFORM:

  export SYBPLATFORM=Linux

  并且修改其头文件中关于服务器名称及用户名和口令的描述。

使用SQSH界面访问SQL Server
  Sybase客户端提供了xisql工具,但更多的人使用的是SQSH,SQSH是SQshell的缩写,是改进了的isql,可从下列地址下载:http://www.voicenet.com/~gray/。当前的最新版本是1.6.0。假设下载后的文件放在/usr/tmp目录下:

  tar zxvf sqsq 1.6.0 tar.gz

  cd sqsh 1.6.0

  ./configure

  make;make install

  然后,将生成的可执行文件sqsh安装到/usr/local/bin/目录下。

  Sqsh的使用如下:

  #sqsh--Uusername--Ppassword--Sservername

  其中username和password是用户名和口令,servername是在interface文件中定义的服务器名(如例子中的MSSQL)。

  Sqsh是交互式的命令行界面,命令用输入go来执行,命令如果较长可直接分成几行书写,以回车换行即可。

  如下是一个例子:

  1> use pubs

  2> go

  1> select * from authors

  2> go采用CT-LIB编写应用程序

  由于Sybase的Linux客户端不提供DB-Library,所以应采用CT-Library来编写应用程序,采用CT-Library编写应用程序可参考例子,详细的编程说明可以参考Sybase的说明。利用Sybperl编写应用程序

  Sybperl是Sybase的Perl扩展,可利用Perl语言来访问SQL Server,或者编写CGI程序。

  Sybperl可从下列地址取得http://www.mbay.net/~mpeppler。当前的最新版本是2.9.5。

  取得Sybperl的源代码展开以后,需要修改一下CONFIG文件,以下是几个参数:

  下一个要修改的文件是PWD,这是用来进行测试的,将其中的服务器名、用户名、用户口令设置成自己的配置即可。然后进行编译:

  perl Makefile.PL

  make; make test; make install

  安装成功以后,即可使用Sybperl进行编程。下面是一个简单的例子。

    #!/usr/bin/perl
   use Sybase::CTlib;
    $dbh=new Sybase::CTlib 'sa','','MSSQL';
    $dbh ->ct_execute("select au_id, au_lname,
au_fname from pubs.dbo.authors");
   while( $dbh ->ct_results( $restype) == CS_SUCCEED) {
    next unless $dbh ->ct_fetchable( $restype);
while(( $au_id, $au_lname, $au_fname) = $dbh ->ct_fetch){
    print " $au_id - $au_lname au_fnamen";
    }
   }
  可以看出,短短几行语句,就可以完成对数据库的操作。 
上一篇:数据库的数据挖掘概述(二) 人气:12405
下一篇:谈数据库中模糊数据的输入与判别 人气:13069
浏览全部Linux的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐