仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1034|回复: 19
打印 上一主题 下一主题

[学习教程] PHP网站制作之PHP PEAR DB类装置与利用实例详解

[复制链接]
小妖女 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-3 23:36:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
PHP成功的插入,删除,更新数据的时候,显然,你已经距离成功指日可待了。     在PHP网站开辟中,因为其撑持各类数据库引擎,如Mysql,Mssql,Pgsql,sqlite等,并对各类数据库体系都供应了分歧的函数作为接口,给PHP网站开辟者带来良多便当,但同时也带来了平台移植性的成绩,跟着底层数据库的改动,PHP代码也必需改动。关于这个成绩,有各类处理办法,如利用PHP ADODB类,PHP PEAR DB类或自行编写PHP DB类,将各类数据库的函数操作聚合在一同等,明天和人人分享若何装置利用PHP PEAR DB类,以完成分歧数据库的会见功效。
筹办任务
  1、在利用PHP PEAR DB类会见数据库之前,需求装置PHP PEAR,然后经由过程PEAR来下载装置DB类,即。
    pear install db
  2、依据需求装置相干数据库,好比Mysql,Mssql,Pgsql,Sqlite等,同时在PHP.INI中找到Dynamic Extensions,引入对应数据的DLL文件,偏重启Apache。
  注重:因为我利用的是DedeAMPZ,在装置PHP PEAR时必定要装置在DedeAMPZ\WebRoot\Default目次下,不然在引入DB.php时会报Failedopening required ‘DB.php’毛病,即找不到DB类(could not find pear db library),由于DedeAMPZ能够对相干的目次做了限制。
PHP PEAR DB类利用示例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<?
require_once&#40;"DB.php"&#41;;

$userName = 'root';
$password = '123456';
$hostName = 'localhost';
$dbName = 'test';

$dsn = "mysql://$userName:$password@$hostName/$dbName";

$dbCon = DB::connect&#40;$dsn&#41;;

if &#40;DB::isError&#40;$dbCon&#41;&#41; {
         die &#40;$dbCon->getMessage&#40;&#41;&#41;;
}

$sql = "CREATE TABLE leapsoul (".
"`id` INT( 11 ) UNSIGNED NOT NULL ,".
"`name` VARCHAR( 30 ) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL ,".
"`age` INT( 2 ) NOT NULL ,".
"`birthday` VARCHAR( 30 ) CHARACTER SET gbk COLLATE gbk_chinese_ci NOT NULL ,".
"`sex` INT( 1 ) NOT NULL ,".
"PRIMARY KEY (  `id` )".
") ENGINE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci";

$result = $dbCon->query&#40;$sql&#41;;

if &#40;DB::isError&#40;$result&#41;&#41; {
         die &#40;$result->getMessage&#40;&#41;&#41;;
}

$sql = "insert into leapsoul(id,name,age,birthday,sex) values(1,'leapsoul',1,'2009-05-13',1),(2,'leapsoul',1,'2009-05-13',1),(3,'leapsoul',1,'2009-05-13',1)";

$result = $dbCon->query&#40;$sql&#41;;

if &#40;DB::isError&#40;$result&#41;&#41; {
         die &#40;$result->getMessage&#40;&#41;&#41;;
}

$dbCon->setFetchMode&#40;DB_FETCHMODE_ASSOC&#41;;

$sql = "select * from leapsoul";

$result = $dbCon->query&#40;$sql&#41;;

if &#40;DB::isError&#40;$result&#41;&#41; {
         die &#40;$result->getMessage&#40;&#41;&#41;;
}
for&#40;$i=0;$i<$result->numRows&#40;&#41;;$i++&#41;
{
     $info = &$result->fetchRow&#40;&#41;;
     
     echo "name:".$info&#91;'name'&#93;;
     echo "birthday:".$info&#91;'birthday'&#93;."<br>";
}
$result->free&#40;&#41;;

$dbCon->disconnect&#40;&#41;;
} 正文:
第2行:引入PHP PEAR DB 类库
第4-7行:设定会见的数据库、登录用户名、暗码、主机
第9-11行:设定DSN参数,并停止数据库链接,我毗连的数据库为Mysql
常识点:从pear/DB.php的parseDSN函数中咱们可以看到$dsn参数有以下几种格局
phptype://username:password@protocol+hostspec:110//usr/db_file.db?mode=0644
phptype://username:password@hostspec/database_name
phptype://username:password@hostspec
phptype://username@hostspec
phptype://hostspec/database
phptype://hostspec
phptype(dbsyntax)
phptype
个中
phptype: 代表利用的数据库,如Mysql,Mssql,Pgsql,Sqlite等
dbsyntax: Database used with regards to SQL syntax etc.(没看分明)
protocol: 利用的协定,好比TCP等
hostspec: 主机,好比数据库寄存在近程办事器上,可指定端口(hostname[:port])
database: 数据库办事器上的数据库名
username: 登录的用户名
password: 登录的暗码
第13-15行:毛病处置,如数据库链接失足,则报错。
第17-38行:履行数据库表创立并拔出测试数据。
第40行:setFetchMode函数是PHP PEAR DB让用户设定前往纪录集是数字索引数组仍是联系关系数组或对象,此处我设定为联系关系数组的模式。默许DB_FETCHMODE_ORDERED形式,其他两种形式为DB_FETCHMODE_ASSOC与DB_FETCHMODE_OBJECT
第49-55行:输入纪录集
第56-58行:释放纪录集并封闭毗连
PHP PEAR DB类局部函数申明:更多函数可参考pear/db.php和pear/db/common.php
connect():数据库链接函数
query():SQL语句履行函数
execute():SQL语句履行函数,与query()函数利用体例略有分歧,详细可参考pear/db/common.php文件
setFetchMode():设定前往纪录集是数字索引数组仍是联系关系数组或对象
numRows():前往纪录集有几何行
numCols():前往纪录集有几何列
free():释放纪录集
disconnect():封闭数据库链接
affectedRows():操作影响的纪录行数
isManip():判别一个查询是数据处置仍是数据界说操作
平台移植申明
  幻想情形下,移植到其他类型的数据库平台时,只需求修正PEAR DB中的DSN字符串参数便可,然而关于一些特定命据库独有的查询,当移植到其他数据库平台时只能停止修正了。
其他
  DB目次下存了一切PHP PEAR DB撑持的相干数据库,有乐趣的伴侣可看看。
  经由过程上述代码实例,咱们就能够使用PHP PEAR DB类来完成分歧数据库的会见功效。
:PHP网站开辟教程-leapsoul.cn版权一切,转载时请以链接模式注明原始出处及本声明,感谢。
即使你理解不了PHP,但是也必须先跟它混个脸熟,看,一遍遍的看,看的同时一边琢磨,一边按照它所教的打代码,即使你搞不清楚那些代码到底是干嘛的,但是起码你应该找找感觉。
小妖女 该用户已被删除
沙发
 楼主| 发表于 2015-2-4 03:28:06 | 只看该作者
其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。
莫相离 该用户已被删除
板凳
发表于 2015-2-5 22:30:13 | 只看该作者
对于初学者来说不推荐去拿钱买的。当然如果一个网站你经常去用,而且里面的资料也比较有用,最好还是买个会员比较好,毕竟那些也是别人的工作成果。
乐观 该用户已被删除
地板
发表于 2015-2-7 18:23:23 | 只看该作者
当然这种网站的会员费就几十块钱。
柔情似水 该用户已被删除
5#
发表于 2015-2-7 18:46:48 | 只看该作者
当然这种网站的会员费就几十块钱。
谁可相欹 该用户已被删除
6#
发表于 2015-2-9 02:37:08 | 只看该作者
刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。
简单生活 该用户已被删除
7#
发表于 2015-2-24 06:47:02 | 只看该作者
找到的的资料很多都是在论坛里的,需要注册,所以我一般没到一个论坛都注册一个id,所有的id都注册成一样的,这样下次再进来的时候就不用重复注册啦。当然有些论坛的某些资料是需要的付费的。
再现理想 该用户已被删除
8#
发表于 2015-3-7 11:49:17 | 只看该作者
其实没啥难的,多练习,练习写程序,真正的实践比看100遍都有用。不过要熟悉引擎
金色的骷髅 该用户已被删除
9#
发表于 2015-3-10 12:54:39 | 只看该作者
说点我烦的低级错误吧,曾经有次插入mysql的时间 弄了300年结果老报错,其实mysql的时间是有限制的,大概是到203X年  具体的记不清啦,囧。
飘灵儿 该用户已被删除
10#
发表于 2015-3-11 05:56:44 | 只看该作者
不禁又想起那些说php是草根语言的人,为什么认得差距这么大呢。
飘飘悠悠 该用户已被删除
11#
发表于 2015-3-12 18:15:38 | 只看该作者
最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。
变相怪杰 该用户已被删除
12#
发表于 2015-3-15 08:47:41 | 只看该作者
使用zendstdio 写代码的的时候,把tab 的缩进设置成4个空格是很有必要的
深爱那片海 该用户已被删除
13#
发表于 2015-3-17 17:10:59 | 只看该作者
如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
因胸联盟 该用户已被删除
14#
发表于 2015-3-21 11:27:26 | 只看该作者
多看优秀程序员编写的代码,仔细理解他们解决问题的方法,对自身有很大的帮助。
小魔女 该用户已被删除
15#
发表于 2015-3-29 22:08:26 | 只看该作者
兴趣是最好的老师,百度是最好的词典。
爱飞 该用户已被删除
16#
发表于 2015-3-31 02:35:58 | 只看该作者
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
admin 该用户已被删除
17#
发表于 2015-4-1 19:11:23 | 只看该作者
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
兰色精灵 该用户已被删除
18#
发表于 2015-4-2 14:17:52 | 只看该作者
php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。
海妖 该用户已被删除
19#
发表于 2015-4-5 03:45:39 | 只看该作者
说php的话,首先得提一下数组,开始的时候我是最烦数组的,总是被弄的晕头转向,不过后来呢,我觉得数组里php里最强大的存储方法,所以建议新手们要学好数组。
不帅 该用户已被删除
20#
发表于 2015-4-13 00:11:09 | 只看该作者
如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域,
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-11-14 13:07

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表