阿七 |
2006-04-04 14:02 |
首先,到站点www.hughes.com.au注册后就能免费下载该软件的最新版本。mSQL的安装相当简单,二进制版本(针对某一个硬件平台编译后的软件)的安装只是将文件展开到用户某一目录下然后配置几个参数就可以。例如你下载的文件为:mSQL-2.0.3.tar.gz,你想把mSQL安装到/usr/local目录下,这时,我们需要先将这个文件拷贝到/usr/local这个目录,然后键入命令tar zxvf mSQL-2.0.3.tar.gz,这个命令将展开该压缩文件。一般,mSQL数据库系统的所有文件都安装到/usr/local/Hughes目录下。接着就是配置mSQL数据库。你所要做的工作就是要修改/usr/local/Hughes目录下的文件msql.conf。 N*HH,m& 在实际应用中我们改动得最多的是mSQL—User 和Admin—User这两个参数。mSQL—User指明运行mSQL数据库服务程序的用户,而Admin—User指明能对mSQL数据库系统执行特权操作(如:关闭数据库服务程序的运行,创建数据库等操作)的用户。因此,如果你希望mSQL服务程序以database这个用户运行,指定admin这个用户能执行数据库操作,你要将mSQL—User和Admin—User所在的行分别改为:mSQL—User = database和Admin—User = admin。另外你还必须将Hughes目录下的文件和目录的属主改为database。在配置完成后,注销当前用户的身份,重新以msql.conf的参数 mSQL—User设定的用户登录到系统,进入/usr/local/Hughes/bin目录键入如下的命令:./msql2d &,这样就启动了mSQL数据库系统。至于带源码的安装软件,看一看README和INSTALL这些文件一般就能顺利安装完成。 ~.iA`${y% 为了将mSQL集成到用户的应用程序中去,mSQL数据库系统为用户提供了一个C语言的API库和一个解释器:w3—msql,通过C语言的API库,你可以将mSQL集成到用标准C语言开发的应用程序中去。而有了w3—msql这个工具,你可以通过编写类C语言脚本语言将mSQL数据库嵌入到html文件中,下面举一程序实例进行说明。 zU=YNrn 下面的程序片段要完成的功能是将浏览器页面上提交上来的用户名和口令与表registered—user中的用户名和口令相比较,如果用户名和口令正确,将在页面上显示注册成功的信息,否则提示用户注册失败。采用C语言实现的方法如下所示: R9bhC9NP void main(int argc, char ??argv[]) `B:B7Cpvn { a4Ls^ //解析用户提交上来的用户名和口令并保存到变量username和password—usr中 ?VUgwP_= … r(pwOOx //创建与本机的mSQL数据库系统的套接字 e21E_exM0 sock=msqlConnect(NULL); #_on{I //选择数据库test 4t,zHR6W if (msqlSelectDB(sock,″test″)==-1) vU ?b"n { Zlr{L]c
//输出数据库选择失败信息 @Q/x&BV … pCz@(:0 } else r9+E'\ { ]z+*?cc sprintf(buff,″select ?? from registered—user where username=′%s′″,username); 71JM
[2 //以username查询表registered—user中的记录 =X)Q7u".7 if (msqlQuery(sock,buff)==-1) @^'G&%j { 0m]~J_ //输出查询失败的错误信息 R.91v4J
… ^fFtI?.6jI } 3Ne9%" //将查询结果保存到m—result类型的指针变量 res #;wkr)) res=msqlStoreResult(); T@%;0Ro~ //得到查询结果的记录数 c-[Q,c numrow=msqlNumRows(res); MZ;"J82p if (numrow==1) jl;kcGE { 5%2ef{T[ //得到当前记录,类型为:m_row sN6 0o 7. row=msqlFetchRow(res); (eCF>Wh^m //将保存在表中的口令和用户输入的口令相比较 qk_p}
l-F1 if (!strcmp(password_ur,row[2])) +^/Nil { t}5'(9 //输出注册成功信息 %E4$ZPSW } else f o/
D3 { NmH}"ndv+ //输出口令不对的提示信息
7yMieUF } *%ed;>6:Q } else g28S3 '2 { {B'Gm]4 //输出用户名输入出错信息 aX>4Tw } E[SV*1) } IgzCh //释放查询结果的指针 a}5vY msqlFreeResult(res); 4FfwpO3,Ku //关闭数据库系统的套接字 gE-w]/1zD5 msqlClose(sock); Ff)~clIK ' return; C$N4 } |
|