关于尚观
最新课程体系
企业服务
零起点咨询
开放课程
报名咨询
免费资源申请
Oracle服务
学员专区&薪资
认证课程
  • 尚观首页
  • 尚观简介
  • 师资力量
  • 尚观文化
  • 尚观动态
  • 加入尚观
  • 联系我们
  • 珍贵瞬间
  • 院校合作
  • Linux系统与集群
  • 数据库集群架构师
  • 嵌入式内核驱动开发
  • 服务器开发架构师
  • Android开发架构师
  • RHCE/LPI认证体系
  • Oracle OCP认证
  • 企业高级技术培训
  • 批量人才供应及研发团队建设
  • 软件外包及研发项目合作
  • 人力外包及人力供应
  • 猎头服务
  • 开启职业生涯
  • 如何入门
  • Unix/Linux职业方向
  • 嵌入式职业方向
  • 集群(Cluster)Oracle(DBA)方向
  • 新手专栏
  • Android开发方向
  • Unix/Linux新手专栏
  • Unix/Linux管理
  • 嵌入式及POSIX开发
  • Linux开源文化及市场
  • 最近网络课堂
  • P2P教学视频
  • 精彩Linux培训视频
  • 零起点数据库集群(长期)
  • 嵌入式驱动(长期)
  • Linux金牌三证(RHCE级)
  • Linux架构师(RHCA级)
  • 嵌入式/驱动加速课程
  • Linux免费网络安全公开课
  • 免费Linux资料申请
  • 免费Linux安全&DDOS防御课程
  • 免费嵌入式Linux开发课程
  • 免费Linux网络安全机制
  • 尚观服务
  • 软件产品
  • 技术方案
  • 尚观支持
  • 学员毕业薪资(不断更新中)
  • 加入尚观猎头服务(仅限老学员)
  • OCP认证
  • Intel认证
  • RHCE认证
  • RHCE+OCP
  • RHCE+LPI
  • OCM认证
  • RHCA认证


    您现在的位置:尚观Linux培训 - 嵌入式Linux培训专家尚观Linux培训 » UNIX/Linux新手专栏 » 初学入门 PHP 和 MySQL (2)

 
 
咨询热线
  • 免费咨询电话:
    400-700-0056
    800-810-0056

    教学就业监督电话:
    400-810-3016



  • 在线咨询
免费资源
  • [北京]Linux安全-4月24日
  • [沈阳]Linux嵌入式-4月24日
  • [上海]DDos攻防-4月24日
  • [上海]Linux嵌入式-4月24日
  • [深圳]DDos攻防-4月24日
  • [深圳]Linux嵌入式-4月24日
  • [北京]DDos攻防-4月24日
  • 就业课程
  • 免费课程
  • 五万年薪就业保证课程

  • ULP-S 尚观王者IT集群课程 v8.2版
  • UEA嵌入式内核驱动开发者 V8.2版
  • UGA-Android开发架构师 V3.2版
  • ULA-linux云存储集群架构师V8.2版
  • UOA-Oracle集群架构师课程V8.2版
  • 八万年薪就业保证课程

  • OCM10g-Oracle顶级数据库大师级
  • UEM-嵌入式开发大师
  • 纯免费!技术达人讲解Android系统通信互动程序开发! 5月24日
  • 纯免费! Shrek主讲Linux网络攻击及安全! 5月17日
  • 纯免费! 大牛讲解如何在开发板上构建Linux系统 5月10日
  • 纯免费! 尚观OCM大师主讲Oracle实时备份课程 4月26日
  • 纯免费! Shrek主讲Linux网络攻击及安全课程 4月11日
  • 纯免费!Foway为您解析OCM考试经验 3月2日
  • 纯免费!shrek主讲 linux网络攻击及安全课程 2月8日
  • 纯免费!连续3天,Android开发入门实战免费公开课 12月27日
  • 纯免费!“云”指南“嵌入式”指北大型讲座! 12月24日
Linux培训●最新开班
  • [北京]UGA课程5月班热招!
  • [北京]UEA课程5月班热报!
  • [北京]ULP-S课程5月班热招
  • [上海]UEA课程5月班热招!
  • [上海]ULP-S课程5月班热招
  • [上海]UGA课程5月班热招!
  • [深圳]ULP-S课程5月班热招
  • [深圳]UEA课程5月班热招!
 
初学入门 PHP 和 MySQL (2)
  • 假设你对表单很熟悉,这是一个相当简单的脚本。我们根据html页面设计了一个表单,它在提交后调用

      add2tbl.php3脚本。现在,表单与MySQL表相对应由4个字段组成:index number,FirstName,LastName和

      FreeText。注意在这个表单中字段名字与MySQL表中字段名一样,但这只是为了方便起见而不是必须。

      我们再一次使用了include命令<? include ('links.x');?>(象在前面所解释的)来增加链接。

      让我们看一下add2tbl.php3脚本:

      <html>
    <body>
    <?
    if ($UserName)
    {
    mysql_connect() or die ("Problem connecting to DataBase");
    $query = "insert into tbl values ('$idx','$UserName','$LastName','$FreeText')";
    $result = mysql_db_query("example", $query);
    echo "Data inserted. new table:<br><p></p>";
    $query = "SELECT * FROM tbl";
    $result = mysql_db_query("example", $query);
    if ($result)
    {
    echo "<table width=90% align=center border=1><tr>
    <td align=center bgcolor=#00FFFF>idx</td>
    <td align=center bgcolor=#00FFFF>User Name</td>
    <td align=center bgcolor=#00FFFF>Last Name</td>
    <td align=center bgcolor=#00FFFF>Free Text</td>
    </tr>";
    while ($r = mysql_fetch_array($result))
    {
    $idx = $r["idx"];
    $user = $r["UserName"];
    $last = $r["LastName"];
    $free = $r["FreeText"];
    echo "<tr>
    <td>$idx</td>
    <td>$user</td>
    <td>$last</td>
    <td>$free</td>
    </tr>";
    } // while循环结束
    echo "</table>";
    }
    else
    {
    echo "No data.";
    } // if结束($result)
    }
    else
    {
    echo "No UserName Entered. Please go back and reenter UserName";
    } // if结束($UserName)
    echo "<p></p>";
    include ('links.x');
    ?>
    </body>
    </html>解释:


      这一部分包含两个主要部分。第一部分从前一个表单中得到数据,并将它们插入到数据库中。第二部分

      从数据库中打印出表的内容。第二部分同我在查看数据库部分中所演示的一样。

      第一部分:

      首先我们象通常一样使用mysql_connect()来同数据库连接。

      然后我们使用下面查询:

      $query = "insert into tbl values ('$idx','$','$LastName','$FreeText')";

      这个查询使用从前面表单传递过来的$idx,$UserName,$LastName和$FreeTExt变量,并将它们插入到

      tbl表中。

      注意,我在脚本中所作的注释。使用一个注释可以用"//",服务器将忽略此行的后面部分。

      简单,不是吗?

      从数据库中编辑一条记录:

      让我们假设一下,我们想修改数据库中存在的记录。在前面,我们看到有一个叫set的SQL命令用来设置

      数据库中存在字段的值。我们将使用这个命令来修改数据库中的整条记录。

      考虑下面的脚本:

      edit.php3:

      <html>
    <head><title>Editing an entry from the database</title>
    </head>
    <body bgcolor=#ffffff>
    <h1>Edit an entry</h1
    <?
    mysql_connect() or die ("Problem connecting to DataBase");
    $query = "select * from tbl";
    $result = mysql_db_query("example", $query);
    if ($result)
    {
    echo "Found these entries in the database:<br>";
    echo "<table width=90% align=center border=1><tr>
    <td align=center bgcolor=#00ffff>idx</td>
    <td align=center bgcolor=#00FFFF>User Name</td>
    <td align=center bgcolor=#00FFFF>Last Name</td>
    <td align=center bgcolor=#00FFFF>Free Text</td>
    </tr>";
    while ($r = mysql_fetch_array($result))
    {
    $idx = $r["idx"];
    $user = $r["UserName"];
    $last = $r["LastName"];
    $text = $r["FreeText"];
    echo "<tr>
    <td align=center>
    <a href="editing.php3?idx=$idx&user=$user&last=$last&text=$text">$idx</a></td>
    <td>$user</td>
    <td>$last</td>
    <td>$text</td>
    </tr>";
    }
    echo "</table>";
    }
    else
    {
    echo "No data.";
    }
    mysql_free_result($result);
    include ('links.x');
    ?>
    </body>
    </html>  如你所见,这里的代码有些熟悉。第一部分只是打印出数据库中表的内容。注意,有一行不太一样:


      <a href="editing.php3?idx=$idx&user=$user&last=$last&text=$text">$idx</a>

      这一行建立了一个到editing.php3的一个链接,并且给新的脚本传递了一些变量。同表单方式很象,只

      是使用的是链接。我们将信息转换成:变量和值。注意,为了打印出 " 符号,我们需要使用 "否则服务器

      将把它看成PHP脚本的一部分并且作为被打印的信息。

      我们想将数据库中的记录全部转换到过,这样我们就可以得到表中的确切的数据,以便我们修改它容易

      一些。

      Editing.php3:

      <html>
    <head><title>Editing an entry</title>
    </head>
    <body bgcolor=#ffffff>
    <h1>Editing an entry</h1>
    <form method="post" action="editdb.php3">
    <table width=90% align=center>
    <tr><td>idx:</td><td><?php echo "$idx";?></td></tr>
    <tr><td>UserName:</td><td><input type=text name=UserName size=40 maxlength=100
    value="<?php echo "$user";?>"></td></tr>
    <tr><td>LastName:</td><td><input type=text name=LastName size=40 maxlength=100
    value="<?php echo "$last";?>"></td></tr>
    <tr><td>Free Text:</td><td><input type=text name=FreeText size=40 maxlength=100
    value="<?php echo "$text";?>"></td></tr>
    <tr><td></td><td><input type=submit value="Edit it!"></td></tr></table>
    <input type=hidden name=idx value="<?php echo "$idx";?>">
    </form>
    <?php include ('links.x');?>
    </body>
    </html>  好,这个脚本很简单。我们要关心的是,当表单打印出来时,它记录了当前记录的数据,通过在 <input

      type= > 命令中的value属性。这些数据是从前一个页面传递过来的。


      现在,如果我们不改变记录的信息,它将传回当前值,即缺省值。如果我们改变了字段的值,字段的值

      将变成新的值。接着我们可以将新值传给另一个脚本,它将会改变MySQL表中的值。

      editdb.php3:

      <?php
    mysql_connect() or die ("Problem connecting to DataBase");
    $query = "update tbl set
    idx='$idx',UserName='$UserName',LastName='$LastName',FreeText='$FreeText' where
    idx='$idx'";
    $result = mysql_db_query("example", $query);
    $query = "SELECT * FROM tbl";
    $result = mysql_db_query("example", $query);
    if ($result)
    {
    echo "Found these entries in the database:<br><p></p>";
    echo "<table width=90% align=center border=1><tr>
    <td align=center bgcolor=#00FFFF>idx</td>
    <td align=center bgcolor=#00FFFF>User Name</td>
    <td align=center bgcolor=#00FFFF>Last Name</td>
    <td align=center bgcolor=#00FFFF>Free Text</td>
    </tr>";
    while ($r = mysql_fetch_array($result))
    {
    $idx = $r["idx"];
    $user = $r["UserName"];
    $last = $r["LastName"];
    $text = $r["FreeText"];
    echo "<tr>
    <td>$idx</td>
    <td>$user</td>
    <td>$last</td>
    <td>$text</td>
    </tr>";
    }
    echo "</table>";
    }
    else
    {
    echo "No data.";
    }
    mysql_free_result($result);
    include ('links.x');
    ?>  基本上要关心的一件事情是下面一行:

      $query = "update tbl set idx='$idx',UserName='$UserName',LastName='$LastName',FreeText='$FreeText' where idx='$idx'";

      注意,它与我们在前面MySQL部分解释的语法相同。另一件事,注意这个脚本改变的是idx=$idx的记录,


      如果表中有多条idx等于$idx的记录,所以这些记录都将被改变。如果我们想更严格一些,我们可以象下面

      改动一下where子句:

      $query = "update tbl set idx='$idx',UserName='$UserName', LastName='$LastName',FreeText='$FreeText' where idx='$idx' and UserName='$UserName' and LastName='$LastName' and FreeText='$FreeText'";

      这个语法将检查所有的字段,而不仅仅是检查idx。

      从数据库中删除一条记录:

      好,删除很容易。我们仍然需要两个脚本:一个用来选择要删除的记录(基本上同上面选择要编辑的记

      录一样),一个用来真正地进行删除和打印新的表格。

      del.php3:

      <html>
    <head><title>Deleting an entry from the database</title>
    </head>
    <body bgcolor=#ffffff>
    <h1>Del an entry</h1>
    <?
    mysql_connect() or die ("Problem connecting to DataBase");
    $query = "select * from tbl";
    $result = mysql_db_query("example", $query);
    if ($result)
    {
    echo "Found these entries in the database:<br><p></p>";
    echo "<table width=90% align=center border=1><tr>
    <td align=center bgcolor=#00ffff>idx</td>
    <td align=center bgcolor=#00FFFF>User Name</td>
    <td align=center bgcolor=#00FFFF>Last Name</td>
    <td align=center bgcolor=#00FFFF>Free Text</td>
    </tr>";
    while ($r = mysql_fetch_array($result))
    {
    $idx = $r["idx"];
    $user = $r["UserName"];
    $last = $r["LastName"];
    $text = $r["FreeText"];
    echo "<tr>
    <td align=center>
    <a href="dele.php3?
    idx=$idx&UserName=$user&LastName=$last&FreeText=$text">$idx</a></td>
    <td>$user</td>
    <td>$last</td>
    <td>$dtext</td>
    </tr>";
    }
    echo "</table>";
    }
    else
    {
    echo "No data.";
    }
    mysql_free_result($result);
    include ('links.x');
    ?>
    </body>
    </html>


      这个脚本与我们用过的编辑脚本很象,所以可以看一下那里的说明。

      dele.php3:

      <?php
    mysql_connect() or die ("Problem connecting to DataBase");
    $query = "delete from tbl where idx='$idx' and UserName='$UserName' and
    LastName='$LastName' and FreeText='$FreeText'";
    $result = mysql_db_query("example", $query);
    $query = "SELECT * FROM tbl";
    $result = mysql_db_query("example", $query);
    if ($result)
    {
    echo "Found these entries in the database:<br><p></p>";
    echo "<table width=90% align=center border=1><tr>
    <td align=center bgcolor=#00FFFF>idx</td>
    <td align=center bgcolor=#00FFFF>User Name</td>
    <td align=center bgcolor=#00FFFF>Last Name</td>
    <td align=center bgcolor=#00FFFF>Free Text</td>
    </tr>";
    while ($r = mysql_fetch_array($result))
    {
    $idx = $r["idx"];
    $user = $r["UserName"];
    $last = $r["LastName"];
    $text = $r["FreeText"];
    echo "<tr>
    <td>$idx</td>
    <td>$user</td>
    <td>$last</td>
    <td>$text</td>
    </tr>";
    }
    echo "</table>";
    }
    else
    {
    echo "No data.";
    }
    mysql_free_result($result);
    include ('links.x');
    ?>  这个脚本看上去很熟悉,唯一不同的就是删除查询的语法:

      $query = "delete from tbl where idx='$idx' and UserName='$UserName' and LastName='$LastName' and FreeText='$FreeText'";

      这个查询将会删除所有与前面的脚本传递来的信息相配匹的记录。容易吧。

      好了,这就是全部内容了。




    精彩Linux视频、嵌入式视频、Android视频、Oracle视频,免费先学!
    查看:尚观Linux培训学员最新就业薪资待遇统计报告!
    查看:UGA-4G Android开发架构师大纲
    查看:UDA-Linux服务器开发架构师大纲
    查看:UEA-嵌入式内核驱动开发者大纲
    查看:UOA-Oracle数据库集群架构大纲
    查看:ULA-Linux系统与集群架构师大纲

    填表获取 Linux、嵌入式、Oracle 技术资料

  • 姓    名:
  • 固    话:
  • 手    机:
  • E-Mail :
  • 所在地:
  •         

北京(总部)

电子地图
电话:(010)62113016/17 68949060
地址:北京海淀区中关村南大街 甲10号 银海大厦南区410-418

上海(Shanghai)

电子地图
电话:(021)64859996 64859889
地址:上海徐汇区钦江路333号漕河泾开发区38号楼申能科技3楼

深圳(Shenzhen)

电子地图
电话:(0755)82995128 82995168
地址:深圳福田区 彩田路 中深花园B2005室

沈阳(Shenyang)

电子地图
电话:(024)31500816 31500817
地址:沈阳和平区三好街54号物产科贸大厦2号楼201室

大连(Dalian)

电子地图
电话:(0411)84336822 84326822
地址:大连沙河口区西安路86号行政大厦(罗斯福广场对面)17楼1705室

成都(Chengdu)

电子地图
电话:(028)66677820 66677828
地址:成都青羊区上西顺城街252号顺吉大厦8楼B4

广州(Guangdong)

电子地图
电话:(020) 88900632 81368992
地址:广州市越秀区人民北路612号中广大厦9层(国际银行中心旁)

南京(Nanjing)

电子地图
电话:(025)83176720 83176710
地址:南京新街口广场中山东路9号天时科技园12层G、H单元

武汉(Wuhan)

电子地图
电话:(027)87596339
地址:武汉市洪山区鲁磨路118号国光大厦A座1201室1203室




2005-2009高新技术企业

LPI授权培训考试中心

CSDN战略伙伴

51Job战略伙伴

Oracle WDP授权培训与考试中心

Intel软件服务培训供应商

Redhat授权培训与考试中心

高新技术企业证书
 

友情链接(联系QQ:304853420):   LPI  RedHat  CSDN  ChinaUnix  ITPub  Eygle.Com  Linux培训  嵌入式培训  Linux联盟  Unix爱好者  51CTO开发 尚观知识库 天极导航  PHP中国  网易教育  天津赶集网  工具软件下载  连锁加盟  天极网南京站  个人简历模板  北京赶集网  畅享网  网页制作  Linux  ZOL服务器  广告联盟  颈椎病的症状  21CN教育  亿芯网  强直性脊柱炎  数码比价网  投资创业  DJ网站  嵌入式技术网  OCM培训  股票入门  大功率LED网   搜电网  杭州写字楼网  时尚论坛  医药营销联盟  Linux技术中心  泉州人才网  大学后  天天健康  RHCE培训  SVN中文技术网  网罗天下  Oracle培训  北京法律咨询  嵌入式资讯网  Fedora中文爱好者  沸点100网   教培英才网  中国二手车城  Linux公社  Oracle教程  深圳本地宝  狂人网  0090网址大全  数码比价网  中国程序员人才网  IT英才网

  • PR
COPYRIGHT © 2000-2009 北京尚观科技有限公司 - 北京市海淀区尚观培训学校 - Linux培训及嵌入式培训专家 ALL RIGHTS RESERVED

咨询热线:400-700-0056    800-810-0056
在线咨询:QQ:814996026    院校洽谈合作专线:13911737012(张老师)
京ICP备09018548号 | Linux就业信息 | 免责声明 | 隐私声明 |