采用服务器端嵌入式脚本语言PHP3进行Linux下的网站开发(3)
作者:佚名; 更新时间:2014-12-05
别是红,绿,蓝值.

ImageColorsTotal返回总颜色数.

(9)ImageFontHeight,ImageFontWidth

接收一个字体号作为参数.

(10)ImageGif(图像描述符,[文件名]);

如无文件名,则将gif数据流送往浏览器.这时程序一开始应该有一句:

Header("Content-type: image/gif")

(11)ImageDestroy(图像描述符);

 

图像函数中有一个小Bug(至少在PHP3.0RC和PHP3.0RC3 For Unix的源码中已经发现,现在上的下载文件应该已经更改),就是ImageSetPixel总是在(y,y)处画点,不管x的值是什么,不过这个问题不是很大.

 

 

十、对数据库的操作

PHP的数据库功能应该说是它最有用的功能之一.它的特点就是内置了对很多

数据库的支持,而不再需要重新扩充.

Perl和Tcl也都是常用的跨平台语言,都有很强的字符能力,前者字符能力更

强一些,性能更高一些;而后者有GUI能力.它们都可以扩充以支持数据库,但这时如果

仍旧希望应用程序有跨平台能力,则需要在各种平台上各自扩充,比如在Unix平台上

对Perl扩充DBI包,在Windows 95/NT下对Perl扩充Win32::ODBC包,有时候这是很麻烦

的.而PHP由于内置了数据库支持,就为编程人员省去了这些麻烦.

PHP3.0支持以下数据库:

Adabas_D,dBase,dbm,filePro,mSQL,MySQL,Sybase,Oracle,PostgreSQL,Solid

另外,支持Windows下的ODBC接口.

文档中说如果需要使用Microsoft SQL Server,可以用Sybase接口或ODBC接口

访问.

在Unix下编译时,应该在Configure时指定要带哪些数据库支持,系统中应该有

这些数据库的客户程序(至少是头文件和库文件).

对各种数据库,访问函数并不完全相同,例如那些基于SQL的数据库显然不能用

和dBase或dbm相同的方式访问.以下比较详细地介绍几种数据库的访问函数:

(一) dBase

(1)dbase_create(文件名,域数组);

域数组的每一项又是一个数组,内容为该域的名称,类型,长度和精度(后两项

不一定要有).

域类型是一个字符,有这么几种值:

"L"--逻辑,"M"--备注,"D"--日期,"N"--数字,"C"--字符串

返回一个数据库描述符,失败则返回false.

(2)dbase_open(文件名,打开方式);

打开方式与C的open函数中的一样.

返回一个数据库描述符,失败则返回false.

(3)dbase_numfields(数据库描述符),dbase_numrecords(数据库描述符);

(4)dbase_add_record(数据库描述符,记录);

记录是一个数组.失败则返回false.

(5)dbase_get_record(数据库描述符,记录号);

返回一个数组,下标从0开始.该数组如果用下标"deleted"访问,可以得到

该记录是否已被删除的信息.

(6)dbase_delete_record(数据库描述符,记录号);

(7)dbase_pack(数据库描述符);

(8)dbase_close(数据库描述符);



 

(二)dbm

dbm是Unix下的一种非关系数据库(至少我感觉是这样),它实际上是文件形式

的哈希表,每一对名字/值项称为一个记录.

dbm有好几个版本,如ndbm,gdbm,等等.

(1)dbmopen(文件名,标志);

标志是"r"(只读),"w"(可写)或"n"(新建).

返回一个数据库标识符.

(2)dbmfirstkey(数据库标识符);

取得第一个名字(键),返回一个字符串.

(3)dbmnextkey(数据库标识符,当前键);

返回下一个键.

(4)dbmexists(数据库标识符,键);

确认该键是否存在,返回true/false.

(5)dbmfetch(数据库标识符,键);

返回该键对应的值(字符串).

(6)dbminsert(数据库标识符,键,值);

插入一个记录,如指定键已存在则返回false,否则返回true.

(7)dbmreplace(数据库标识符,键,值);

替换一个记录,如原来没有该记录则插入.

(8)dbmdelete(数据库标识符,键);

删除一个记录.

(9)dbmclose(数据库标识符);

 

(三)mSQL与MySQL.

mSQL(mini SQL)是一种小型的关系数据库,性能不是太好,对SQL语言的

支持也不够完全,但在一些网络数据库应用中是足够了.

MySQL是mSQL的一个变种,性能有所提高,增加了用户访问控制.

这两种数据库都是通过SQL语言访问的,但MySQL基本支持全部SQL92规范,只是"select ... where select .."不支持,另外还扩充了一些数据类型,而mSQL则基本上不支持任何嵌套SQL语句,也不支持"update set column1=column1-1"这样的语句.

mSQL由于较简单,在运行简单的SQL语句时速度比MySQL略快,而MySQL在线程和索引上下了功夫,运行复杂的SQL语句时比mSQL,PostgreSQL,Oracle等都要快一些.

安全性方面,mSQL通过ACL文件设定各主机上各用户的访问权限,缺省是全部可读/写,而MySQL通过一个授权库设定用户名,口令和访问权限,较可靠一些.

mSQL的存储能力不是很清楚,MySQL的存储能力受文件系统限制,例如在Linux下不能超过2G(3G?记不清楚了).

它们的好处就是都能免费得到并在Linux下安装,不过如果用于商业用途需要付费.

PostgreSQL也是Linux下的免费数据库,RedHat5里面就带了,不过我没有用过,就不说了.

mSQL与MySQL既然本来就是差不多的两个东西,PHP中对它们的访问语句也都差不多,例如msql_close与mysql_close就分别完成同样的关闭动作.所以以下介绍时只对mysql介绍,msql的访问语句只需换个前缀即可(特殊情况另行说明).注意:mSQL与MySQL访问函数都需要有相应的权限才能运行.

(1)mysql_connect(主机,用户名,口令);

返回一个连接号.

注意:mysql各用户的口令可以随该用户所在机器IP地址不同而改变.

另外,mSQL没有用户名机制,所以msql_connect只需要一个主机参数.

主机可以是IP地址或域名.

(2)mysql_create_db(数据库名);

(3)mysql_select_db(数据库名,连接号);

连接一个数据库.

(4)mysql_query(SQL语句,连接号);

如果SQL语句是select,则返回一个结果号.否则返回的值可以不理会.

如果失败,返回false.

(5)mysql_fetch_array(结果号);

取出下一行,返回一个数组.可以用数字下标访问(第一个字段是下标

0),

核心期刊快速发表
Copyright@2000-2030 论文期刊网 Corporation All Rights Reserved.
《中华人民共和国信息产业部》备案号:ICP备07016076号;《公安部》备案号:33010402003207
本网站专业、正规提供职称论文发表和写作指导服务,并收录了海量免费论文和数百个经国家新闻出版总署审批过的具有国内统一CN刊号与国际标准ISSN刊号的合作期刊,供诸位正确选择和阅读参考,免费论文版权归原作者所有,谨防侵权。联系邮箱:256081@163.com