当前位置:首页 > 芯闻号 > 充电吧
[导读]PHP的mysqli扩展(一共有mysqli ,mysqli_stmt ,mysqli_result三个类)1.||--------------启用mysqli扩展模块---------------e

PHP的mysqli扩展(一共有mysqli ,mysqli_stmt ,mysqli_result三个类)
1.||--------------启用mysqli扩展模块---------------
extension=php_mysqli.dll;


2.||=================mysqli的使用步骤=====================================
   1).|-------------连接MySQL服务器-------------------
      方法一:与mysql用发一样,只不过是把mysql换成了mysqli
      方法二:面向对象的方法
        $mysqli=new mysqli("localhost","user","pass","dbname");//连接mysql数据库服务器
   2).|------------处理连接错误报告------------------------------------     
    if(mysqli_connent_errno()){
      echo "连接失败:".mysqli_connect_error();
    }
    
   3).|------------执行SQL语句---------------------
     【1】$sql=select * from stu;
          $mysqli->query($sql);//执行sql语句
          注意:@1.在执行【增/删/改】的时候,成功返回true 失败返回false 
                @2.在执行【查询】的时候,成功会返回一个mysqli_result对象
   
                   
   4).|------------结果的处理使用mysqli_result类----------------------------------
     【1】 【增/删/改】结果的处理
          (1)影响的行数【增/删/改】
             $mysqli->affected_rows
             
         (2) 新插入的ID值【增】
             $mysqli->insert_id 
     【2】【查】的结果的处理      
         查询的时候返回的是一个mysqli_result的对象,所以可以调用mysqli_result中的一些函数
         (1).创建结果集的方法
             《1》$result = $mysqli->query($sql);
                  $result=$mysqli->query($sql,MYSQL_USER_RESULT);//第二个参数提供一个值,
                  在处理的数据集合尺寸比较大或者不适合一次全部取回到客户端的时候
             《2》$mysqli->real_query($sql);
                  $mysqli->store_result();
          (2).从结果集中解析数据
              《1》$result->fetch_row();
                   while($row=$result->fetch_row()){
                       echo $row['name'];
                    }
              《2》$result->fetch_assoc()
                     该方法将以一个关联数组的形式返回一条结果记录     
              《3》$result->fetch_array()
                    该方法将以一个关联和索引数组的形式返回一条结果记录        
              《4》$result->fetch_object()
                     该方法将以一个对象的形式返回一条结果记录         
                     
                     
          (3).从结果集中获取数据列的信息
              $result->field_count;//统计数据表中的列的个数
              $result->field_seek(); // 改变指针当前列的偏移位置
              $result->current_field;//当前列的位置
              $result->fetch_field();//当前列的信息
              $result->close();关闭结果集
    5).|----------------------关闭与MySQL服务器的连接----------------------
           $mysqli->close();      
           
  3.||==========================多条 SQL语句的执行===================================       
          【1】.没有结果集的 (insert update delete)
           $sql="insert into stu values ('a','b','c');update stu set name='lisi' where id=10;delete stu where id>10";
           
           $mysqli->muti_query($sql);
           
           最后插入的的ID:$mysqli->insert_id;还有用
           影响的行数就不管用了:$mysqli->affected_rows
           
           【2】.有结果集的(select)
           $sql="select name gb2312;select CURRENT_USER();SELECT name from stu";
           解析结果集
           do{
           $result=$mysqli->store_result();//返回的result的对象
           //用$result->fetch_assoc()解析
            foreach ($row = $result->fetch_assoc()){
              输出语句
            }           
       } while($mysqli->next_result())下一个结果集
       
    4.||==========================预处理(使用mysqli_stmt)==============================
         1).|------预处理的过程-----------------
           【1】.获取预处理语句对象
                $sql="insert into stu values(?,?,?,?)";
                $stmt=$mysqli->prepare($sql);
           【2】.绑定参数
                $stmt = $stmt->bind_param('issd',$a,$b,$c);
                $a="整型";
                $b="字符串型";
                $c="字符串型";
                $d="浮点数值";          
                //issd 分别代表的是整型 浮点型 和 字符串型
           【3】.执行准备好的语句
                 $stmt->exectue();
                 
                 
           【4】.执行结果的处理
                 $stmt->store_result();//取回全部查询结果   
                 $stmt->num_rows()//输出查询的记录的行数
                 $stmt->bind_result($name,$result,$phone);//将查询的结果绑定到变量
                 while($stmt->fetch()){
                   遍历输出变量
                 } 
                 
                 举例:
                 <?php
                      /* Open a connection */
                      $mysqli = new mysqli("localhost", "root", "1234", "lamp36");


                      /* check connection */
                      if (mysqli_connect_errno()) {
                          printf("Connect failed: %sn", mysqli_connect_error());
                          exit();
                      }


                      $query = "SELECT * FROM gd2 ORDER BY php LIMIT 20";
                      if ($stmt = $mysqli->prepare($query)) {


                          /* execute query */
                          $stmt->execute();


                          /* store result */
                          var_dump($stmt->store_result());


                          printf("Number of rows: %d.n", $stmt->num_rows);
                         $stmt->bind_result($name,$result);//将查询的结果绑定到变量
                                       while($stmt->fetch()){
                                        echo $name."
";
                                echo $result."

";
                                       } 
                          /* free result */
                          $stmt->free_result();
                        
                          /* close statement */
                          $stmt->close();
                      }


                      /* close connection */
                      $mysqli->close();
                    ?> 
                结果:bool(true) Number of rows: 10. 
                        36
                        40


                        34
                        50


                        36
                        58


                        36
                        58


                        34
                        59


                        36
                        70


                        36
                        78


                        34
                        80


                        34
                        89


                        34
                        90
           【5】.资源的释放
                 $stmt->close();                        
                                   
   5.||=======================事物处理=========================================
      【1】数据库首先保证是InnoDB格式的
      【2】关闭自动提交
           $mysqli->autocommit(0);//0关闭自动提交,1打开自动提交
      【3】执行sql语句 
      //向a的值中的cash减去price
        $result=$mysqli->query("update account set cash=cash-$price where name='a'");
        if(!$result or $mysqli->affect_rows!=1){
          $success = FALSE;
        }   
       
      //向b中的cash加上price
      $result = $mysqli->query("update account set cash = caseh +$price where name='b'");
       if(!$result or $mysql->affect_rows!=1){
        $success = FALSE;
       } 
       【4】//判断语句是够成功执行,如果成功执行则提交事物,否则回滚事物
       if($success){
        $mysql->commit();//十五提交
        echo "转账成功";
       }else{
         $mysql->rollback();//回滚当前的事物;
       }
       
       $mysqli->autocommit(1);//开启事物 
       
     6.||=======================类中方法和属性的说明===================================
            
                ========================================
                Mysqli类
                ========================================
                构造函数
                  mysqli - 初始化mysqli对象,连接数据库,参数(主机名,账号,密码,库名)


                方法
                  *autocommit(bool) - turns on or off auto-commiting database modifications
                            设置mysqli的事务是否自动提交 参数(布尔值)
                  *commit() - 提交事务方法(提交sql操作)commits the current transaction
                  
                  *rollback() - 事务回滚方法(撤销sql操作)rolls back the current transaction
                        
                  change_user(string user, string password, string database ) 
                        -更改用户信息 changes the user of the specified database connection


                  character_set_name - 返回默认字符集设置 returns the default character set for the database connection


                  *close -  关闭数据库 closes a previously opened connection


                  connect - 获取一个数据库连接 opens a new connection to MySQL database server


                  debug - 执行调试操作performs debugging operations


                  dump_debug_info - 转存调试信息dumps debug information


                  get_client_info - 获取数据库连接客户端版本信息returns client version


                  get_host_info - 返回连接类型returns type of connection used


                  get_server_info - 返回服务器版本信息returns version of the MySQL server


                  get_server_version - 返回服务版本号returns version of the MySQL server


                  init - 初始化mysqli对象 initializes mysqli object


                  info - 检索最近执行sql的查询信息 retrieves information about the most recently executed query


                  kill - 请求服务器杀死一个mysql进程asks the server to kill a mysql thread


                  multi_query - 执行多条sql查询语句performs multiple queries


                  more_results - 从多查询中检查是否有更多的查询结果check if more results exist from currently executed multi-query


                  next_result - 对多条查询中,读取下一个结果reads next result from currently executed multi-query


                  options - 设置选项set options


                  ping - ping服务器连接或重新连接pings a server connection or reconnects if there is no connection


                  *prepare -准备一个sql语句的执行,返回mysqli_stmt对象 prepares a SQL query


                  *query -执行sql语句查询,若是查询则返回mysqli_result结果集对象 performs a query


                  real_connect - 试图打开一个数据库连接attempts to open a connection to MySQL database server


                  escape_string - 转义sql语句的特殊字符escapes special characters in a string for use in a SQL statement, taking into account the current charset of the connection


                  select_db - 选择默认数据库selects the default database


                  set_charset - 设置客户端连接字符集sets the default client character set


                  ssl_set - 使用安全连接sets ssl parameters


                  stat - 获取系统状态gets the current system status


                  stmt_init- 初始化一个声明,返回mysqli_stmt对象 initializes a statement for use with mysqli_stmt_prepare


                  store_result - 从最后查询中转让结果集transfers a resultset from last query


                  use_result - 不缓存查询 transfers an unbuffered resultset from last query


                  thread_safe - 线程是否安全returns whether thread safety is given or not


                【属性】
                ===================================================================
                *affected_rows -影响的行数 gets the number of affected rows in a previous MySQL operation


                client_info - 客户端信息returns the MySQL client version as a string


                client_version -客户端版本 returns the MySQL client version as an integer


                *errno - 错误号returns the error code for the most recent function call


                *error - 错误信息returns the error string for the most recent function call


                *field_count - 字段数量 returns the number of columns for the most recent query


                host_info - 主机信息 returns a string representing the type of connection used


                info - 最近执行查询信息 retrieves information about the most recently executed query


                *insert_id - 最后插入的自增id号 returns the auto generated id used in the last query


                protocol_version - 协议版本 returns the version of the MySQL protocol used


                sqlstate - 最后错误号returns a string containing the SQLSTATE error code for the last error


                thread_id - 线程id号 returns the thread ID for the current connection


                warning_count - 警告的次数 returns the number of warnings generated during execution of the previous SQL statement






                【mysqli_stmt】
                =====================================================
                Represents a prepared statement. 


                【方法】


                bind_param - 绑定参数 binds variables to a prepared statement


                bind_result - binds variables to a prepared statement for result storage


                close - closes a prepared statement


                data_seek - seeks to an arbitrary row in a statement result set


                execute - 执行sql语句 executes a prepared statement


                fetch - fetches result from a prepared statement into bound variables


                free_result - frees stored result memory for the given statement handle


                result_metadata - retrieves a resultset from a prepared statement for metadata information


                prepare - prepares a SQL query


                send_long_data - sends data in chunks


                reset - resets a prepared statement


                store_result - buffers complete resultset from a prepared statement


                【属性】


                affected_rows - returns affected rows from last statement execution


                errno - returns errorcode for last statement function


                errno - returns errormessage for last statement function


                param_count - returns number of parameter for a given prepare statement


                sqlstate - returns a string containing the SQLSTATE error code for the last statement function




                ======================================================
                mysqli_result 结果集对象
                =======================================================
                Represents the result set obtained from a query against the database. 


                【方法】


                close - closes resultset


                data_seek - moves internal result pointer


                fetch_field - gets column information from a resultset


                fetch_fields - gets information for all columns from a resulset


                fetch_field_direct - gets column information for specified column


                fetch_array - 关联数组和索引式数组解析一条结果集fetches a result row as an associative array, a numeric array, or both.


                fetch_assoc - 以关联数组方式解析一条结果集 fetches a result row as an associative array


                fetch_object - 以对象方式解析一条结果集 fetches a result row as an object


                fetch_row - 以索引式数组解析结果集 gets a result row as an enumerated array


                close - frees result memory


                field_seek - set result pointer to a specified field offset


                【属性】


                current_field - returns offset of current fieldpointer


                field_count - returns number of fields in resultset


                lengths - returns an array of columnlengths


                num_rows - returns number of rows in resultset


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭