PHP.15-mysqli
从PHP5.0开始可以使用mysql(i), 是一个面向对象的技术(新加功能都会以对象形式添加)
i:表示改进,1. 功能增加了, 2,效率大大增加(以后的PHP项目改成mysqli),3,更稳定
mysqli使用面向对象技术,但也支持过程化的使用方式
mysqli扩展中给我提供了三个类:
1. mysqli和连接有关的类
2. mysqli_result表达了对数据库的查询所返回的结果集。
3. mysqli_stmt (后面重点介绍)
可以选择过程化编程,或是选择面向对象技术
mysql(i)_connect()
面向对象:$mysqli = new $mysqli("localhost", "username", "password", "select_db"); //实例化对象
面向过程:$mysqli = mysqli_connect("localhost", "username", "password", "select_db");
mysql(i)_select_db();
mysql(i)_query();
注:一般使用mysqli扩展就要使用面向对象的编程方式进行开发
1、mysqli处理结果集(mysqli_result)
使用select语句后,得到的结果集的处理
一、处理记录
属性:mysqli_num_rows(); //返回结果集中行的数量
方法:
data_seek(); //调整结果集指针到结果集任意一行
fetch_assoc(); //从结果集中取得一行作为关联数组
fetch_row(); //从结果集中取得行
注:常用的为上面两个
fetch_array(); //从结果集中取得一行作为数字数组或关联数组
fetch_object(); //从结果集中取得当前行,并作为对象返回。
free_result(); //释放结果内存
二、处理字段信息
field_count; //返回最近查找的列数
current_field; //获取结果指针的当前字段偏移量
lengths; //返回结果集中当前行的列的长度
fetch_field(); //从结果集中取得下一字段,并作为对象返回。
fetch_fields(); //返回结果集中代表字段(列)的对象的数组,然后输出每个字段名称、表格和最大长度
2、mysqli完成事务处理和一次执行多条sql语句
一、使用mysqli执行多条语句
a、就是没有结果集(如:插入、更新、删除等语句)
b、多条语句有结果集
二、使用mysqli完成事务处理
事务处理 (多个SQL要完成的任务看为是一个事务)一件事(有任何一个环节出错,都整个事务撤消, 如果都成功才去提交)
目前只有InnoDB 支持事务 (MyISAM)
默认表都是自动提交的(autocommit)
1. 关闭自动提交
2. start事务(如果自动提交已经关闭,使用mysqli不需要开启事务,PDO中则需要)
[start transaction:开启事务,在mysql中输入]
commit; //提交事务
rollback; //回滚当前事务
multi_query; //执行多条数据库语句
三、其他的mysqli类的中的成员使用
3、mysqli预处理类
mysqli_stmt预处理类(推荐你使用的类)
$mysqli=new mysqli("localhost", "root", "123456", "xsphpdb"); //准备好一条语句放到服务器中,插入语句
$sql="insert into shops(name, price, num, desn) values(?, ?, ?, ?)"; $stmt=$mysqli->prepare($sql); //给占位符号每个?号传值(绑定参数) i:整形 d:浮点 s:字符 b:二进制
$stmt->bind_param("sdis", $name, $price, $num, $desn); $name="zhangsan";
$price=56.78;
$num=66;
$desn="hello good"; //执行
$stmt->execute();
$stmt->close();
和mysqli和mysqli_result相比优点:
1. mysqli和mysqli_result参完成的功能,都可以使用mysqli_stmt完成
2. 效率上:高, 就是如果执行多次相同的语句,只有语句数据不同, 因为将一条语句在服务器端准备好,然后将不同的值传给服务器,再让这条语句执行
编译一次,使用多次
3. 安全上:SQL注入(? 占位) ,后期传的值不会当成SQL语句
PHP.15-mysqli的更多相关文章
- php mysqli mysqli_query() mysqli_real_query()
2016年11月26日 15:22:27 星期六 场景: PHP从mysql中读取数据 1. 一次性读取所有数据返给PHP 2. 每次循环只读取一掉记录 数据量小的时候可以使用第一种方法, 数据量很大 ...
- php示例代码之使用mysqli对象
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 30 31 32 33 34 35 36 3 ...
- PHP mysqli 扩展库(面向对象/数据库操作封装/事务控制/预编译)
1.和mysql扩展库的区别: (1 安全性.稳定性更高 (2 提供了面向对象和面向过程两种风格 2.php.ini 中的 extension=php_mysqli.dll 解除封印 3.面 ...
- PHP基础 mysqli的事务处理
1: <?php 2: // PHP 的mysqli的事务处理 3: //======================================================== 4: ...
- PHP的 Mysqli扩展库的多语句执行
$mysqli->multi_query($sqls); 执行多个sql语句,返回true/false 有结果集时,使用 $mysqli->store_result(); 来获取结 ...
- 【PHP&&mysqli】
msyqli和mysql只有一个字母的差别,真正的含义是msyql的增强版扩展. MySQL可以处理满足程序员对MySQL数据库操作的各种需要了,为什么还需要mysqli呢?因为mysqli支持面性对 ...
- php mysqli MySQL server has gone away 问题分析
结论 mysqli没有处理对端(MySQL server)的断开请求.在send时,收到对端(MySQL server)的RST,会打印MySQL server has gone away. 环境 x ...
- PHP 扩展在 Linux(centos7)系统下的编译与安装 以 mysqli 为例
(操作系统 Centos7,环境版本 php7) 01,进入到 PHP 解压后的源码包的的 ext 文件夹 02,查看是否存在 mysqli 扩展 => ls, 如果不存在需要去响应网站下载 ( ...
- php mysqli 链接数据库 CURD 增改查删
<?php function println($msg) { echo "<br>"; echo $msg; } $mysql_server_name = &qu ...
- php安装后,再添加模块pdo_mysql,mysqli
windows下,是动态链接库.dll,linux下是.so. linux下,假设php安装在/usr/local/php,php的源码包放在/usr/local/php-5.6.15 去php源码包 ...
随机推荐
- Android开发由eclipse转Android Studio中一些常见出错问题解决方法
1.给一个Activity添加了一个Dialog主题,结果出现了下面的问题,在eclipse却没有出错 <activity android:name=".DialogActivity& ...
- DEEP LEARNING 大满贯课程表
Reinforcement Learning post by ISH GIRWAN Courses/Tutorials Deep Reinforcement Learning, Spring 2017 ...
- 初识Python(三)
一.作用域 对于变量的作用域,执行声明并在内存中存在,该变量就可以在后续的代码中使用: 外层变量,可以被内层变量使用:内层变量,也可以被外层变量使用: 如下示例: #!/usr/bin/env pyt ...
- April 3 2017 Week 14 Monday
Don't worry about finding your soul mate. Find yourself. 欲寻佳侣,先觅本心. You may fail to find your soul m ...
- 支付宝快速集成ios
看一下这篇文章,非常不错,并在此感谢这篇文章的作者. 惯例,先写出嵌入支付宝的核心代码 - (IBAction)payWithAli:(UIButton *)sender { //生成订单信息NSSt ...
- 【LOJ6043】「雅礼集训 2017 Day7」蛐蛐国的修墙方案(搜索技巧题)
点此看题面 大致题意: 给你一个长度为\(n\)的排列\(p\),要求构造一个合法的括号序列,使得如果第\(i\)个位置是左括号,则第\(p_i\)个位置一定是右括号. 暴搜 很容易想出一个暴搜. 即 ...
- Nginx+Tomcat+memcached高可用会话保持
Nginx+Tomcat+memcached高可用会话保持 文章来源dyc2005 一.概述 之前文章已经描述了企业高可用负载相关的架构及实现,其中常用的nginx或haproxy,LVS结合ke ...
- 2018.7.26 进程和线程的区别 &&你对 Java平台的理解
进程和线程的区别 1.定义 进程:具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位. 线程:进程的一个实体,是CPU调度和分派的基本单位,它是比进程更 ...
- 第16章 STM32中断应用概览—零死角玩转STM32-F429系列
第16章 STM32中断应用概览 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fi ...
- 《JavaScript高级程序设计第三版》——细碎知识痛点整理(第六章)
面向对象的程序设计 对象是一组没有特定顺序的值6.1.1 属性类型ECMAScript中有两种属性:数据属性和访问器属性.1. 数据属性Configurable 表示能否通过delete删除属性从而重 ...