仓酷云

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

[学习教程] PHP网站制作之Smarty实例教授教养---利用ADODB毗连数据...

[复制链接]
老尸 该用户已被删除
跳转到指定楼层
#
发表于 2015-2-4 00:17:47 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

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

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

x
刚开始觉得自己对这些多少有些基础,很简单,但是看了老师那么熟练的进行网页布局的时候,突然之间发现,其实,我的基础并没有自己想像的那么好,自己设计的页面其实并不好看,就连表格的边框为1像素都不会弄。ado|毗连数据库   一样,我在关头的中央加了数标,上面来讲明一下它们的寄义: 1. 创立一个毗连对象$conn,人人在这里要注重的是它的初始不是以$conn = new ADONewConnection($dbType)如许的模式呈现的,也就是说
,ADONewConnection不是一个class,你不克不及利用new 对它停止初始化.看看它的源码你就会分明,这只不外是一个函数.
2. 这个就不必说了吧?翻开一个News的数据库,主机为:localhost, 用户名为root, 暗码为""
3. 一个查询语句,注重,这里要将查询的字段利用AS关头字来从头标识,称号为你在模板中设置的模板变量的称号.
4. 利用Execute来履行这个查询,了局前往一个RecordSet数据集
5. 这里有个办法:$rs->GetArray($num) 这个在上边引见过,它是要从$rs这个数据集中前往$num行,了局为一个可被Smarty所辨认的二维数
据.如许ADODB就主动为咱们构建起了如许的布局,而在咱们之前的例子中,都是利用一个轮回构建如许的数组的.
6. 这一句我看也不必说了吧?
7. 封闭内存中的相干资本.
人人可以看看,全部法式中再没有呈现甚么while语句,法式全体布局显的十分清晰,这就是为何ADODB+Smarty是黄金组合的缘由.不外话也
说回来了,复杂有复杂的成绩,不知人人想过没有,这里对显示的旧事题目的长度没有掌握,也就是说,假如某条旧事题目的长度超越一行显示的范
围,它就是主动折行到下一行,那末全部的版面就会事件,所说人人自已适本人的情形来决意是不是如许利用吧固然,你也能够利用像上一节中介
绍的那样,利用一个轮回语句重构这个二维数组,使它合适你的用处,怎样做人人本人去想吧,参考PHPLIB中的做法,上节我引见过了...
再来看看旧事页吧
=============================================================
news.php
=============================================================
<?php
/*********************************************
*
* 文件名: news.php
* 作 用: 旧事显示法式
*
* 作 者: 巨匠兄
* Email: teacherli@163.com
*
*********************************************/
include_once("./comm/mySmarty.class.php"); file://包括smarty的扩大类文件
include_once("./comm/adodb/adodb.inc.php"); file://包括ADODB主履行文件
$smarty = new MySmarty(); file://创立smarty实例对象$smarty
$conn = ADONewConnection("mysql"); file://初始化ADODB
$conn->Connect("localhost", "root", "", "News"); file://毗连数据库
$NewsID = $_GET["id"]; file://获得旧事编号
$NewsType = $_GET["type"]; file://要显示的旧事类型
switch($NewsType)
{
case 1:
$dbName = "tb_news_CH";
break;
case 2:
$dbName = "tb_news_IN";
break;
case 3:
$dbName = "tb_news_MU";
break;
}
$strQuery = "SELECT vcNewsTitle AS NewsTitle, ltNewsContent AS NewsContent FROM " . $dbName;
1. $row = &$conn->GetRow($strQuery); file://前往一个一维数组,下标为模板变量名
$smarty->display($row);
unset($row);
$conn->Close();
?>
=============================================================
申明一下关头的中央,其其实news.php中也只要一个中央值的申明一下了.
1. $conn->GetRow($strQuery):这一句前往一个一维数组,前往的模式为:
$array = ("NewsTitle"=>"xxxx", "NewsContent"=>"yyyyy...")
分明假如利用$smarty($array)后Smarty会干甚么吗?对了,就是相当于:
$smarty->assign("NewsTitle", "xxxx");
$smarty->assign("NewsContent", "yyyyy...");
复杂吧,的确很复杂
上面再来看看旧事列表:
================================================================
newsList.php
================================================================
<?php
/*********************************************
*
* 文件名: newsList.php
* 作 用: 旧事列表显示法式
*
* 作 者: 巨匠兄
* Email: teacherli@163.com
*
*********************************************/
include_once("./comm/mySmarty.class.php"); file://包括smarty的扩大类文件
include_once("./comm/adodb/adodb.inc.php"); file://包括ADODB主履行文件
$smarty = new MySmarty(); file://创立smarty实例对象$smarty
$conn = ADONewConnection("mysql"); file://初始化ADODB
$conn->Connect("localhost", "root", "", "News"); file://毗连数据库
>file://获得旧事编号
$NewsType = $_GET["type"]; file://要显示的旧事类型
switch($NewsType)
{
case 1:
$tbName = "tb_news_CH";
break;
case 2:
$tbName = "tb_news_IN";
break;
case 3:
$tbName = "tb_news_MU";
break;
}

$strQuery = "SELECT iNewsID AS NewsID, vcNewsTitle AS NewsTitle FROM " . $tbName;
1. $rs = &$conn->GetAll($strQuery);
2. $smarty->assign("NewsType", $NewsType); file://这一句为旧事列表中的链接办事
3. $smarty->assign("NewsList", $rs);
unset($rs);
$conn->close();
$smarty->display("newsList.tpl");
?>
================================================================
分离来讲明一下:
1. GetAll($strQuery):这个函数可是个好东东,它的感化是将$strQuery查询到的一切数据组分解为一个可以被Smarty所辨认的二维数组,
记住:它前往的是一个二维数组而不是一个RecordSet,地点你可以法式中直接在3处利用.
2. 这里是为了给旧事题目做链接时要GET参数type=XX而做的
跋文:
人人在利用ADODB时有几个中央要注重:
1. 初始化: 初始化的体例不是利用new,由于它不是一个对象
2. 方 法: 根基上每一个办法都是以大写字母开首巨细写夹杂的称号,这一点仿佛与*NIX的习气有些分歧,也分歧于PHP的全体作风,所以
注重这里的巨细写成绩.
好了,这个Smarty的系列教程到这里就根基已完成了,我的这几篇低级教程就算是抛砖引玉吧,但愿更多的高手将更多的经历写出来,人人配合进步!

  说说这一个月左右的学习情况和心得吧!我个人认为,既然决定了去做一件事,那就要以认真的态度去对待!既然决定来学习了,那不管当初是抱着怎样的心态来到这个培训班的,都要让自己认真的投入到学习中。
愤怒的大鸟 该用户已被删除
19#
发表于 2015-6-9 02:00:46 | 只看该作者
刚开始安装php的时候,我图了个省事,把php的扩展全都打开啦(就是把php.ini 那一片 extension 前面的冒号全去掉啦),这样自然有好处,以后不用再需要什么功能再来打开。
简单生活 该用户已被删除
18#
发表于 2015-6-5 03:35:07 | 只看该作者
当然这种网站的会员费就几十块钱。
小女巫 该用户已被删除
17#
发表于 2015-4-28 08:15:25 | 只看该作者
曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线  \\\\\\\'_\\\\\\\' ;
分手快乐 该用户已被删除
16#
发表于 2015-4-26 23:04:00 | 只看该作者
曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线  \\\\\\\'_\\\\\\\' ;
再现理想 该用户已被删除
15#
发表于 2015-4-20 05:06:45 | 只看该作者
如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域,
透明 该用户已被删除
14#
发表于 2015-4-12 16:36:58 | 只看该作者
最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。
精灵巫婆 该用户已被删除
13#
发表于 2015-4-4 07:33:16 | 只看该作者
Ps:以上纯属原创,如有雷同,纯属巧合
小魔女 该用户已被删除
12#
发表于 2015-3-30 21:00:56 | 只看该作者
先学习php和mysql,还有css(html语言很简单)我认为现在的效果比以前的方法好。
蒙在股里 该用户已被删除
11#
发表于 2015-3-20 12:37:24 | 只看该作者
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
老尸 该用户已被删除
10#
 楼主| 发表于 2015-3-19 19:55:16 | 只看该作者
建议加几个专业的phper的群,当然啦需要说话的人多,一处一点问题能有人回答你的,当然啦要让人回答你的问题,平时就得躲在里面聊天,大家混熟啦,愿意回答你问题的人自然就多啦。
不帅 该用户已被删除
9#
发表于 2015-3-12 10:20:25 | 只看该作者
基础有没有对学习php没有太大区别,关键是兴趣。
再见西城 该用户已被删除
8#
发表于 2015-3-11 17:05:33 | 只看该作者
我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。
变相怪杰 该用户已被删除
7#
发表于 2015-3-11 15:41:35 | 只看该作者
当然这种网站的会员费就几十块钱。
第二个灵魂 该用户已被删除
6#
发表于 2015-3-4 04:27:54 | 只看该作者
曾经犯过一个很低级的错误,我在文件命名的时候用了一个横线\\\\\\\'-\\\\\\\' 号,结果找了好几个小时的错误,事实是命名的时候 是不能用横线 \\\\\\\'-\\\\\\\' 的,应该用的是下划线  \\\\\\\'_\\\\\\\' ;
谁可相欹 该用户已被删除
5#
发表于 2015-3-3 20:34:07 | 只看该作者
其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。
柔情似水 该用户已被删除
地板
发表于 2015-2-28 09:53:52 | 只看该作者
装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。
深爱那片海 该用户已被删除
板凳
发表于 2015-2-25 17:34:11 | 只看该作者
对于懒惰的朋友,我推荐php的集成环境xampp或者是wamp。这两个软件安装方便,使用简单。但是我还是强烈建议自己动手搭建开发环境。
若相依 该用户已被删除
沙发
发表于 2015-2-19 06:30:06 | 只看该作者
建议加几个专业的phper的群,当然啦需要说话的人多,一处一点问题能有人回答你的,当然啦要让人回答你的问题,平时就得躲在里面聊天,大家混熟啦,愿意回答你问题的人自然就多啦。
飘灵儿 该用户已被删除
楼主
发表于 2015-2-9 22:16:32 | 只看该作者
建数据库表的时候,int型要输入长度的,其实是个摆设的输入几位都没影响的,只要大于4就行,囧。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-11-1 13:35

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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