赛迪网 > IT技术 Linux > 源码开发
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

Linux操作系统下的MySQL数据库开发技术 (1)

发布时间:2008.09.04 06:57     来源:赛迪网    作者:fen

【赛迪网-IT技术报道】首先,到站点www.hughes.com.au注册后就能免费下载该软件的最新版本。MySQL的安装相当简单,二进制版本(针对某一个硬件平台编译后的软件)的安装只是将文件展开到用户某一目录下然后配置几个参数就可以。例如你下载的文件为:MySQL-2.0.3.tar.gz,你想把mSQL安装到/usr/local目录下,这时,我们需要先将这个文件拷贝到/usr/local这个目录,然后键入命令tar zxvf MySQL-2.0.3.tar.gz,这个命令将展开该压缩文件。一般,MySQL数据库系统的所有文件都安装到/usr/local/Hughes目录下。接着就是配置MySQL数据库。你所要做的工作就是要修改/usr/local/Hughes目录下的文件msql.conf。

在实际应用中我们改动得最多的是MySQL—User 和Admin—User这两个参数。MySQL—User指明运行MySQL数据库服务程序的用户,而Admin—User指明能对MySQL数据库系统执行特权操作(如:关闭数据库服务程序的运行,创建数据库等操作)的用户。因此,如果你希望MySQL服务程序以database这个用户运行,指定admin这个用户能执行数据库操作,你要将MySQL—User和Admin—User所在的行分别改为:MySQL—User = database和Admin—User = admin。另外你还必须将Hughes目录下的文件和目录的属主改为database。在配置完成后,注销当前用户的身份,重新以msql.conf的参数 MySQL—User设定的用户登录到系统,进入/usr/local/Hughes/bin目录键入如下的命令:./msql2d &,这样就启动了MySQL数据库系统。至于带源码的安装软件,看一看README和INSTALL这些文件一般就能顺利安装完成。

为了将MySQL集成到用户的应用程序中去,MySQL数据库系统为用户提供了一个C语言的API库和一个解释器:w3—msql,通过C语言的API库,你可以将MySQL集成到用标准C语言开发的应用程序中去。而有了w3—msql这个工具,你可以通过编写类C语言脚本语言将mSQL数据库嵌入到html文件中,下面举一程序实例进行说明。

下面的程序片段要完成的功能是将浏览器页面上提交上来的用户名和口令与表registered—user中的用户名和口令相比较,如果用户名和口令正确,将在页面上显示注册成功的信息,否则提示用户注册失败。采用C语言实现的方法如下所示:

void main(int argc, char argv[]) 
  { 
  //解析用户提交上来的用户名和口令并保存到变量username和password—usr中 
  … 
  //创建与本机的mSQL数据库系统的套接字 
  sock=msqlConnect(NULL); 
  //选择数据库test 
  if (msqlSelectDB(sock,″test″)==-1) 
  { 
  //输出数据库选择失败信息 
  … 
  } else 
  { 
  sprintf(buff,″select ?? from registered—user where username=′%s′″,username); 
  //以username查询表registered—user中的记录 
  if (msqlQuery(sock,buff)==-1) 
  { 
  //输出查询失败的错误信息 
  … 
  } 
  //将查询结果保存到m—result类型的指针变量 res 
  res=msqlStoreResult(); 
  //得到查询结果的记录数 
  numrow=msqlNumRows(res); 
  if (numrow==1) 
  { 
  //得到当前记录,类型为:m_row 
  row=msqlFetchRow(res); 
  //将保存在表中的口令和用户输入的口令相比较 
  if (!strcmp(password_ur,row[2])) 
  { 
  //输出注册成功信息 
  } else 
  { 
  //输出口令不对的提示信息 
  } 
  } else 
  { 
  //输出用户名输入出错信息 
  } 
  } 
  //释放查询结果的指针 
  msqlFreeResult(res); 
  //关闭数据库系统的套接字 
  msqlClose(sock); 
  return; 
  }

以上的例子包含有将MySQL集成到C语言程序中用到的主要函数,这些函数基本能满足应用程序的需要。如果采用w3—msql能解释的类C语言嵌入到html文件中,可以达到同样的功能。与C语言编写的CGI程序需要编译不同,脚本语言不需要编译,该脚本由MySQL数据库系统提供的CGI程序w3—msql来解释执行。脚本中主要的代码段如下所示:

1 2 下一页>>


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 应用:在Linux系统下配置WU-FTP服务器 (09-02) · 应用:在Linux系统下配置WU-FTP服务器 (09-02)
· 应用:在Linux系统下配置WU-FTP服务器 (09-02) · 系统默认的MySQL用户名消失的解决方法 (09-02)
· 系统默认的MySQL用户名消失的解决方法 (09-02) · 系统默认的MySQL用户名消失的解决方法 (09-02)
· 480名硕博士状告北京万方数据库侵权 (09-02) · 480名硕博士状告北京万方数据库侵权 (09-02)
· 480名硕博士状告北京万方数据库侵权 (09-02) · 万方论文数据库再次遭到482名硕博起诉 (09-02)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
· 电子商务盈利新招:垂直化渠道管理新趋势
· 互联网加速蜕变 运营商进军搅动市场格局
· 08 IT技术风起云涌 专访 ITIL落地难在哪
· 视频加密保护解决方案 文档安全解决方案
  IT博客 ·曾剑秋·项立刚·Java学习·网管
  IT技术论坛 ·开发·网管·安全·数据库·系统