仓酷云

标题: PHP网页设计PHP完成Mysql数据库毗连、查询、纪录集... [打印本页]

作者: 透明    时间: 2015-2-3 23:36
标题: PHP网页设计PHP完成Mysql数据库毗连、查询、纪录集...
我的文章不会对您的学习起到实质性的作用,您能否成功,还得靠自己的,坚持,坚持,再坚持,就是步入成功的不二法门。     在PHP网站开辟中,常常需求对Mysql数据库停止操作,大体上需求经由以下几个步调:Mysql数据库链接、Mysql数据库查询、Mysql纪录集操作等,假如每次都反复上述操作,不仅繁琐,并且代码冗余度高,对此我收拾整顿了局部使用PHP完成Mysql数据库操作的代码,以函数的模式贴出,可依据自行需求添加其他功效或整分解Mysql数据库类。
Mysql数据库链接代码
1
2
3
4
5
6
7
8
9
10
11
12
function dbConnect($hostname,$username,$pass,$db_name,$pconnect = 0)
{
     $func = empty($pconnect) ? 'mysql_connect' : 'mysql_pconnect';
     
     if(!$connect) {
         $connect = @$func&#40;$hostname,$username,$pass&#41; or die&#40;"<font size='2'>Mysql_Error : ".mysql_error&#40;&#41;."<br>Mysql Error Num : ".mysql_errno&#40;&#41;."</font>"&#41;;
     }
     
     @mysql_select_db&#40;$db_name, $connect&#41; or die&#40;"<font size='2'> Mysql_Error : ".mysql_error&#40;&#41;."<br>Mysql Error Num : ".mysql_errno&#40;&#41;."</font>"&#41;;

     return $connect;
} 正文
参数$hostname,$username,$pass,$db_name分离代表Mysql数据库办事器地址,用户名,暗码,和毗连的数据库名,凡是情形下hostname普通都是localhost或127.0.0.1。参数$pconnect默许为0,暗示凡是情形下是以mysql_connect函数毗连Mysql数据库。
常识点
mysql_connect与mysql_pconnect的区分:当履行完以后PHP法式后,PHP主动封闭mysql_connect创立的数据库毗连,而mysql_pconnect前往一个耐久安定的数据库毗连,在必定工夫内有下一个毗连恳求时可以被复用,节俭了重复毗连Mysql数据库的工夫,使得会见速度加速,其合用于并发会见量不大的情形,如并发会见量对照大,则能够会由于Mysql已到达最大毗连数, 使以后的恳求得不到知足。
mysql_error函数:前往上一个Mysql操作发生的文本毛病信息。mysql_errno函数前往上一个Mysql操作中的毛病号码,假如没有失足则前往0。
Mysql数据库查询代码
1
2
3
4
5
6
7
function query_error&#40;$query&#41;
{
     global $connect;
     $temp_bar = "<br>=============================================================================<br>";
     $result = mysql_query&#40;$query, $connect&#41; or die&#40;"DB ERROR <br>".$temp_bar."<font size='2'> Mysql_Query : ".$query."<br> Mysql_Error : ".mysql_error&#40;&#41;."<br> Mysql Error Num : ".mysql_errno&#40;&#41;."</font>".$temp_bar&#41;;
     return $result;
} 正文:此函数为Mysql数据库查询函数,等于同mysql_query函数的功效,假如失足则输入失足信息(SQL语句),其实为了避免表露网站数据库的布局,正式商用时,最好不要输入SQL履行语句。
Mysql纪录集操作函数代码(mysql_fetch_array)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
function fetch_array&#40;$result,$result_type = MYSQL_ASSOC,$records = "one"&#41;
{
     if &#40;$records == "one"&#41; {
         return @mysql_fetch_array&#40;$result,$result_type&#41;;
     }
     else {
         for &#40;$i=0;num_rows&#40;$result&#41;;$i++&#41;
         {
             $info&#91;$i&#93; = @mysql_fetch_array&#40;$result,$result_type&#41;;
         }
         
         free_result&#40;$result&#41;;
         
         return $info;
     }
} 正文:此函数的功效由mysql_fetch_array函数延生而来,在此基本上我增添了对Mysql数据库纪录集的读取功效,并以数组模式前往获得的值。
常识点
mysql_fetch_array函数是mysql_fetch_row函数的扩大版本。第二个参数 result_type有三个值:MYSQL_ASSOC,MYSQL_NUM 和 MYSQL_BOTH。默许值是 MYSQL_BOTH。MYSQL_BOTH:失掉一个同时包括联系关系和数字索引的数组。MYSQL_ASSOC:只失掉联系关系索引(好像mysql_fetch_assoc()那样),MYSQL_NUM :失掉数字索引(好像 mysql_fetch_row()那样)。
报错信息函数代码
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
function error_msg&#40;$msg, $url= ""&#41;
{
     global $connect;

     if&#40;$connect&#41; {
         mysql_close&#40;$connect&#41;;
     }

     switch &#40;$url&#41;
     {
         case "":
             $url = "history.go(-1)";
             break;
         case "close":
             $url = "window.close()";
             break;
         default:
             $url = "document.location.href = '$url'";
             break;  
     }
     
     if &#40;!empty&#40;$msg&#41;&#41; {
         echo "<script language='javascript'>alert('$str');$url;</script>";
     }
     else{
         echo "<script language='javascript'>$url;</script>";
     }
     exit;
} 正文:此函数的功效次要以alert的模式报错并停止页面跳转,是一个通用函数,报错或跳转之前其会先将Mysql数据库毗连封闭,用到了mysql_close函数。
挪用申明
从上述Mysql数据库操作的函数代码中,咱们可以看到$connect变量是一个全局变量,起首将上述几个函数放入一个文件,如mysqlconnect.php中,然后在声明相干变量并赋值,在dbConnect函数声明后挪用此Mysql数据库毗连函数,即:
1
2
3
4
5
6
$hostname = "mysqlserveraddr";
$username = "yourusername";
$pass = "youruserpass";
$db_name = "yourdatabase";

$connect = dbConnect&#40;$hostname,$username,$pass,$db_name&#41;; 总结
  经由过程下面几个Mysql数据库毗连、数据库查询、数据库纪录集操作函数代码的解说,在PHP网站开辟中Mysql数据库操作的根基函数已包含,依据需求可在此代码基本上改成Mysql数据库类或使用PHP添加其他的Mysql数据库操作函数都是可行的。
  :PHP网站开辟教程-leapsoul.cn版权一切,转载时请以链接模式注明原始出处及本声明,感谢。
熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_-
作者: 飘灵儿    时间: 2015-2-6 03:24
最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。
作者: 谁可相欹    时间: 2015-2-6 08:17
最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。
作者: 愤怒的大鸟    时间: 2015-2-9 02:37
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
作者: 若天明    时间: 2015-2-10 11:27
你很难利用原理去编写自己的代码。对于php来说,系统的学习我认为还是很重要的,当你有一定理解后,你可你针对某种效果研究,我想那时你不会只是复制代码的水平了。
作者: 山那边是海    时间: 2015-2-28 03:53
我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:
作者: 小妖女    时间: 2015-3-7 09:44
如果你可以写完像留言板这样的程序,那么你可以去一些别人的代码了,
作者: 因胸联盟    时间: 2015-3-13 04:34
遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。
作者: 飘飘悠悠    时间: 2015-3-15 08:47
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
作者: 兰色精灵    时间: 2015-3-17 17:10
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
作者: 金色的骷髅    时间: 2015-3-20 09:19
本文当是我的笔记啦,遇到的问题随时填充
作者: 再见西城    时间: 2015-3-20 15:27
基础有没有对学习php没有太大区别,关键是兴趣。
作者: 冷月葬花魂    时间: 2015-4-1 09:54
个人呢觉得,配wamp 最容易漏的一步就是忘了把$PHP$目录下的libmysql.dll拷贝到windows系统目录的system32目录下,还有重启apache。
作者: 深爱那片海    时间: 2015-4-7 18:01
遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。
作者: 柔情似水    时间: 2015-4-11 07:40
多看优秀程序员编写的代码,仔细理解他们解决问题的方法,对自身有很大的帮助。
作者: 小女巫    时间: 2015-4-17 21:37
其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。
作者: 活着的死人    时间: 2015-5-11 15:21
php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。
作者: 不帅    时间: 2015-6-22 16:46
真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,
作者: 爱飞    时间: 2015-7-8 11:04
装在C盘下面可以利用windows的ghost功能可以还原回来(顺便当做是重转啦),当然啦我的编译目录要放在别的盘下,不然自己的劳动成果就悲剧啦。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2