易班技术部新生培训--PHP与MySQL

PHP操作MySQL有多种方法

  • mysql扩展(在后面版本会被移除,不推荐使用)
  • mysqli扩展
  • PDO扩展
    在这里根据慕课网的教程(教程链接),给大家整理了一下mysqli基本的使用方法。
    主流PHP框架很多都是采用封装PDO的数据库操作类来操作数据库,等大家以后学习框架后自然会体会到框架操作数据库的快速方便优雅,但是现在以基础为重。

mysqli有面向对象的接口与面向过程的接口,因此有两种使用方式,一种是对象的使用方式,一种是函数的使用方式,大家根据习惯选择自己喜欢的吧,个人比较喜欢面向对象式的。

因为涉及到类简单讲一下类的基本概念,表达能力一般,用代码解释,你们感受下- -。
类是面向对象程序设计的基本概念,通俗的理解类就是对现实中某一个种类的东西的抽象, 比如汽车可以抽象为一个类,汽车拥有名字、轮胎、速度、重量等属性,可以有换挡、前进、后退等操作方法。(以上文字抄自慕课网- -)

类的好处:数据与可以执行的方法一起封装,看起来更清晰,另外可以隐藏具体实现与数据,只对外公开接口。每一个类只需要考虑实现自己的接口,使用类时,只需要知道类提供了哪些接口。
下面只是一个最简单的类,还有更多的特性等待大家去学习。

<?php
class people{
 //类里的变量叫类的属性,public是访问修饰符,表示公开
    public $name='lucy';
        public $age=25;
//类里的function叫类的方法
    public function getAction(){
        echo '我是一个方法';
    }
    public function getAge(){
        return $this->age;//$this关键字可以理解为对象本身
    }
}

$person=new people();//实例化一个类,$person是people这个类的一个实例化对象
echo $person->name;//lucy.输出对象的name属性
$person->getAction();//我是一个方法.调用对象的一个方法.
echo $person->getAge();//25

请自行更改数据库的连接选项

$con=new mysqli('127.0.0.1','root','root','test');
$con=mysqli_connect('127.0.0.1','root','root')

有几个理解点:

  • 上述代码的$con你可以理解为PHP与MySQL的一个【连接】
  • 下面的$query你可以理解为查询的【结果集】
$query=mysqli_query($con,$sql_1);
//或者
$query=$con->query($sql)
  • 下面这些方法或函数就是对你查到的结果集进行操作,让他们以【怎样的形式】展现出来,关联数组?索引数组?对象?
mysqli_fetch_row($query)
//或者
$query->fetch_assoc()

数组

$a=array('id'=>1,'name'=>'zhang');//这是关联数组
$a=array(1=>1,2=>'zhang');//这是索引数组

大家把代码在本地跑一下,结合慕课网或其他教程多用就熟练了
有啥不明白的来问各自组长或者问我吧,讲错的或者代码出错的也请指出。

面向对象的使用方法

<?php
    // http://www.imooc.com/video/6759 视频教程在这里
    header("Content-type:text/html;charset=utf-8");
    /* 连接mysql,有错就打印错误
     或者:
     $con=new mysqli('127.0.0.1','root','root')
     if(!$con->select_db('test')){
        echo $con->error;
        }
    设置编码,防止乱码
     或者:
     $con=new mysqli();
     $con->connect('127.0.0.1','root','root')
     */
    $con=new mysqli('127.0.0.1','root','root','test');
    if($con->connect_error){
        echo $con->error;
        die("连接出错,die方法结束进程");
        // die('Connect Eroor'.$con->connect_error);
    }

    // 设置编码,防止乱码
    if(!$con->set_charset('utf8')){
        echo $con->error;
    }

    // 创建表test
    $sql=<<<EOF
         CREATE TABLE IF NOT EXISTS test_table(
         id TINYINT UNSIGNED AUTO_INCREMENT KEY,
         username VARCHAR(20) NOT NULL,
         password VARCHAR(20) NOT NULL
         );
EOF;
    if($con->query($sql)){
        $query=$con->query("SELECT * FROM test_table");
        if($query&&$query->num_rows==0){
            $sql="INSERT test_table(username,password)VALUES('zhang','123'),('li','456')";
            $con->query($sql);
        }
    }else{
        echo $con->error ;
        die("创建表出错");
    }


    $sql_1="SELECT * FROM test_table";
    echo '<h4>mysqli面向对象使用方法</h4>';
    echo '<h4>这里只是举了部分常用方法,还有很多请自行看视频或相关手册</h4>';
    echo'<h4>以下都是获取查询数据的第一条,如果要获取全部的可以使用循环语句打印出来</h4>';
    echo'<h4>在这里,$con是连接标识符,$query是执行的结果集</h4>';
    echo'<hr>';

    $query=$con->query($sql_1);//执行sql语句,将执行结果赋给一个变量
    if($query){
        echo '$query->fetch_row():以索引数组的形式获取数据(这个循环打印了)<br><br>';
        //循环打印
        while ($result=$query->fetch_row()) {
            $data[]=$result;
            echo 'name:'.$result[0].' '.'password:'.$result[1].'<br>';
        }
        print_r($data);
        echo '<hr>';
    }
    $query=$con->query($sql_1);
    if($query){
        echo '$query->fetch_assoc():以关联数组的形式获取数据<br><br>';
        $result=$query->fetch_assoc();
        print_r($result);
        echo '<hr>';
    }
    $query=$con->query($sql_1);
    if($query){
        echo '$query->fetch_array(MYSQLI_BOTH):参数不写就是默认以混合数组(索引数组、关联数组)的形式获取数据<br><br>';
        $result=$query->fetch_array(MYSQLI_BOTH);//以混合数组形式,参数可写可不写
        print_r($result);
        echo '<hr>';
    }
    $query=$con->query($sql_1);
    if($query){
        echo '$query->fetch_array(MYSQLI_NUM):以索引数组的形式获取数据,等同于$query->fetch_row()<br><br>';
        $result=$query->fetch_array(MYSQLI_NUM);
        print_r($result);
        echo '<hr>';
    }
    $query=$con->query($sql_1);
    if($query){
        echo '$query->fetch_array(MYSQLI_ASSOC):以关联数组的形式获取数据,等同于$query->fetch_assoc()<br><br>';
        $result=$query->fetch_array(MYSQLI_ASSOC);
        print_r($result);
        echo '<hr>';
    }
    $query=$con->query($sql_1);
    if($query){
        echo '$query->num_rows:获取结果数目<br><br>';
        $result=$query->num_rows;
        print_r($result);
        echo '<hr>';
    }
    $query=$con->query($sql_1);
    if($query){
        echo 'mysqli_num_rows:以对象形式获取数据<br><br>';
        $result=$query->fetch_object(   );
        print_r($result);
        echo"<br>";
        
        echo $result->id;
        echo '<br>';
        echo $result->username.'<br>';
        echo $result->password.'<br>';
        echo '<hr>';
    }
echo"<h4>以下选择性看</h4>";
echo 'mysqli_multi_query:执行多条sql语句,注意每句结束的“;”<br><br>';
$sql="INSERT test_table(username,password)VALUES('wang','789'),('hao','101112');";
$sql.="UPDATE test_table SET password='11111111';";
// if($con->multi_query($sql)){
//  echo 'multi success';
// };
// 
$sql2="SELECT * FROM test_table where id=1;";
$sql2.="SELECT * FROM test_table where id=2";
if($con->multi_query($sql2)){
    $rows=array();
    echo "success<br>";
    do{
        if($result=$con->store_result()){
            $rows[]=$result->fetch_all(MYSQLI_ASSOC);
        }
    }while($con->more_results()&&$con->next_result());
}else{
        echo $con->error;
}
print_r($rows);
//关闭连接
$con->close();
echo"<h4>预处理和事务处理暂时不需要掌握,请以后自己看视频或者以后有机会讲</h4>";



面向过程的使用方法

<?php
    //面向过程
    header("Content-type:text/html;charset=utf-8");
   //以定义常量的形式定义数据库连接信息,
    define('HOST','127.0.0.1');
    define('USERNAME', 'root');
    define("PASSWORD", 'root');
    // 连接mysql,有错就打印错误
    if(!($con=mysqli_connect('127.0.0.1','root','root'))){
        echo mysqli_error($con);
        die("连接MySQL出错");
    }
    // 选择数据库也可以直接写在connect方法的第四个参数里
    if(!mysqli_select_db($con,'test')){
        echo mysqli_error($con);
        die("选择database出错");
    }
    // 设置编码,防止乱码
    if(!mysqli_query($con,'set names utf8')){
        echo mysqli_error($con);
        die("设置编码出错");

    }

    // 创建表test
    $sql=<<<EOF
         CREATE TABLE IF NOT EXISTS test_table(
         id TINYINT UNSIGNED AUTO_INCREMENT KEY,
         username VARCHAR(20) NOT NULL,
         password VARCHAR(20) NOT NULL
         );
EOF;
    if(mysqli_query($con,$sql)){
        $query=mysqli_query($con,"SELECT * FROM test_table");
        if($query&&mysqli_num_rows($query)==0){
            $sql="INSERT test_table(username,password)VALUES('zhang','123'),('li','456')";
            mysqli_query($con,$sql);
        }
    }else{
        echo mysqli_error($con);
        die("创建表出错");
    }


    $sql_1="SELECT * FROM test_table";
    echo '<h4>mysqli面向过程使用方法</h4>';
    echo '<h4>这里只是举了部分常用方法,还有很多请自行看视频或相关手册</h4>';
    echo'<h4>以下都是获取查询数据的第一条,如果要获取全部的可以使用循环语句打印出来</h4>';
    echo'<h4>在这里,$con是连接标识符,$query是执行的结果集</h4>';
    echo'<hr>';
    // mysqli_query执行sql语句,第一个参数是mysql连接,第二个参数是sql语句
    $query=mysqli_query($con,$sql_1);//执行sql语句,将执行结果赋给一个变量
    if($query){
        echo 'mysqli_fetch_row($query):以索引数组的形式获取数据(这个循环打印了)<br><br>';
        //循环打印
        while ($result=mysqli_fetch_row($query)) {
            echo 'name:'.$result[0].' '.'password:'.$result[1].'<br>';
            $data[]=$result;
        }
        print_r($data);
        echo '<hr>';
    }
    $query=mysqli_query($con,$sql_1);
    if($query){
        echo 'mysqli_fetch_assoc($query):以关联数组的形式获取数据<br><br>';
        $result=mysqli_fetch_assoc($query);
        print_r($result);
        echo '<hr>';
    }
    $query=mysqli_query($con,$sql_1);
    if($query){
        echo 'mysqli_fetch_array($query,MYSQLI_BOTH):第二个参数不写就是默认以混合数组(索引数组、关联数组)的形式获取数据<br><br>';
        $result=mysqli_fetch_array($query,MYSQLI_BOTH);//以混合数组形式第二个参数可写可不写
        print_r($result);
        echo '<hr>';
    }
    $query=mysqli_query($con,$sql_1);
    if($query){
        echo 'mysqli_fetch_array($query,MYSQLI_NUM):以索引数组的形式获取数据,等同于mysqli_fetch_row<br><br>';
        $result=mysqli_fetch_array($query,MYSQLI_NUM);
        print_r($result);
        echo '<hr>';
    }
    $query=mysqli_query($con,$sql_1);
    if($query){
        echo 'mysqli_fetch_array($query,MYSQLI_NUM):以关联数组的形式获取数据,等同于mysqli_fetch_assoc<br><br>';
        $result=mysqli_fetch_array($query,MYSQLI_ASSOC);
        print_r($result);
        echo '<hr>';
    }
    $query=mysqli_query($con,$sql_1);
    if($query){
        echo 'mysqli_num_rows:获取结果数目<br><br>';
        $result=mysqli_num_rows($query);
        print_r($result);
        echo '<hr>';
    }
    $query=mysqli_query($con,$sql_1);
    if($query){
        echo 'mysqli_fetch_object:以对象形式获取数据<br><br>';
        $result=mysqli_fetch_object($query);
        print_r($result);
        echo"<br>";
        
        echo $result->id;
        echo '<br>';
        echo $result->username.'<br>';
        echo $result->password.'<br>';
        echo '<hr>';
    }
echo"<h4>以下选择性看</h4>";
echo 'mysqli_multi_query:执行多条sql语句,注意每句结束的“;”<br><br>';
$sql="INSERT test_table(username,password)VALUES('wang','789'),('hao','101112');";
$sql.="UPDATE test_table SET password='11111111';";
// if(mysqli_multi_query($con,$sql)){
//  echo 'multi success';
// };
// 
$sql2="SELECT * FROM test_table where id=1;";
$sql2.="SELECT * FROM test_table where id=2";
if(mysqli_multi_query($con,$sql2)){
    $rows=array();
    echo "success<br>";
    do{
        if($result=mysqli_store_result($con)){
            $rows[]=mysqli_fetch_all($result,MYSQLI_ASSOC);
        }
    }while(mysqli_more_results($con)&&mysqli_next_result($con));
}else{
        echo mysqli_error($con);
}
print_r($rows);
//关闭连接
mysqli_close($con);
echo"<h4>预处理和事务处理暂时不需要掌握,请以后自己看视频或者以后有机会讲</h4>";

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容

  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,517评论 6 13
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,296评论 18 399
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,018评论 11 349
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,569评论 25 707
  • 今天,我对实体经济和虚拟经济又有了些新的认识。以前我总喜欢把实体经济和虚拟经济的关系理解为人的肉体和精神的关系...
    breastli阅读 650评论 1 0