当前位置:Gxlcms > 数据库问题 > PHP中将对数据库的操作,封装成一个工具类以及学会使用面向对象的方式进行编程

PHP中将对数据库的操作,封装成一个工具类以及学会使用面向对象的方式进行编程

时间:2021-07-01 10:21:17 帮助过:4人阅读

class SqlTool { //属性 private $conn; private $host="localhost"; private $user="root"; private $password="root"; private $db="test"; function SqlTool(){ $this->conn=mysql_connect($this->host,$this->user,$this->password); if(!$this->conn){ die("连接数据库失败".mysql_error()); } mysql_select_db($this->db,$this->conn); mysql_query("set names utf8");//设置字符集 } //方法.. // 完成select dql public function execute_dql($sql){ $res=mysql_query($sql,$this->conn) or die(mysql_error()); return $res; } //完成 update,delete ,insert dml public function execute_dml($sql){ $b=mysql_query($sql,$this->conn); //echo "添加的id=".mysql_insert_id($this->conn); if(!$b){ return 0;//失败 }else{ if(mysql_affected_rows($this->conn)>0){ return 1;//表示成功 }else{ return 2;//表示没有行数影响. } } } } ?>

2.使用php的 mysqli 扩展库去操作mysql数据库

 

简单介绍:

 

mysqli (mysql improve mysql扩展库的增强版)

 

mysql 扩展库 和  mysqli 扩展库的比较

 

  1. mysqli 的稳定性和安全性,效率有所提高
  2. mysqi 支持面向对象编程 ,同时 mysqli 扩展库考虑到php老程序员,提供面向过程的编程风格.

 

mysqli 有两套编程风格:

 

 技术分享

 

$mysqli=new MySQLi(“localhost”,”root”,”roo3t”,”test”);
//按照面向对象的方式
if($mysqli->connect_error){
    die($mysqli->connect_error);
}
// 考虑兼容低版本
if(mysqli_connect_error()){
    die(“连接error”. mysqli_connect_error())
}

 

mysqli 编程的快速入门

编写一个程序,这个程序从user1表中读取数据,并打印在网页中。(使用mysqli完成.)

  1. 先使用mysqli面向对象的风格,完成案例 

    1.1. 配置php.ini 文件让php支持mysqli扩展库

    extension=php_mysqli.dll

    1.2 建库,建表.

    这里我们使用原来的user1.

    1.3 编写代码

 

 <?php

    header("Content-type: text/html;charset=utf-8");
    //mysqli操作mysql数据库(面向对象风格)
    
    //1.创建MySQLi 对象
    $mysqli=new MySQLi("localhost","root","root","test");
    //验证是否ok
    if($mysqli->connect_error){
        die("连接失败".$mysqli->connect_error);
    }
    //2. 操作数据库(发送sql)
    $sql="select * from user1";
    //$res 是结果集.mysqli result
    $res=$mysqli->query($sql);
    //var_dump($res);
    //3. 处理结果 mysql_fetch_row();
    while($row=$res->fetch_row()){
        foreach($row as $key=>$val){
            echo "--$val";
        }
        echo "<br/>";
    }
    //4. 关闭资源
    //释放内存
    $res->free();
    //关闭连接
    $mysqli->close();

?>

 

3.再使用面向过程的方式给大家演示一下.

 

 

//1.得到mysqli连接
    header("Content-type: text/html;charset=utf-8");
    $mysqli=mysqli_connect("localhost","root","root","test");

    if(!$mysqli){
        die("连接失败".mysqli_connnect_error($mysqli));
    }

    //2.向数据库发送sql语句(ddl,dml dql ...) 
    $sql="select * from user1";
    $res=mysqli_query($mysqli,$sql);
    //var_dump($res);
    //3.处理得到的结果
    //循环取出$res中的数据mysqli_fetch_row mysql_fetch_row
    while($row=mysqli_fetch_row($res)){
        
        foreach($row as $key=>$val){
            echo "--$val";
        }
        echo "<br/>";
    }

    //4.关闭资源
    mysqli_free_result($res);
    mysqli_close($mysqli);

 

? 在mysqli 扩展中,也提供了四种方式来获取mysqli result结果集

mysqli_result::fetch_assoc    <==>    mysql_fetch_assoc

mysqli_result::fetch_row  <==>    mysql_fetch_row

mysqli_result::fetch_array <===> mysql_fetch_array

mysqli_result::fetch_object<===> mysql_fetch_object

这里我们推荐大家使用前两种效率较高 

? 在mysqli释放结果集有三种方式:

void mysqli_result::free ( void )

void mysqli_result::close ( void )

void mysqli_result::free_result ( void )

? mysql 的 sql  语句的特别说明:

如果操作的字段类型是 string 型,则要求我们的 要用 ‘’ 包括。

如果操作的字段类型是 数值型,则可以用 ’80’ 包括,也可以不用

u mysqli的增强-批量执行sql语句

 

批量执行 dml语句

基本语法

$sqls=”sql1;sql2;...”
mysqli::multi_query($sqls)

//请使用mysqlimysqi::multi_query() 一次性添加三个用户 宋江 卢俊义 吴用

 

$sqls="insert into user1 (name,password,email,age) values(‘宋江‘,‘aaa‘,‘aa@shu.com‘,45);";
$sqls.="insert into user1 (name,password,email,age) values(‘卢俊义‘,‘aaa‘,‘aa@shu.com‘,45);";
$sqls.="insert into user1 (name,password,email,age) values(‘吴用‘,‘aaa‘,‘aa@shu.com‘,45);";
//$sqls.="update ;";
//$sqls.="delete ;";
//dml 和 dql

$b=$mysqli->multi_query($sqls);

 

? 批量执行dml语句可以混合使用 delete insert update,但是最好不要使用select

 

PHP中将对数据库的操作,封装成一个工具类以及学会使用面向对象的方式进行编程

标签:

人气教程排行