现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。当然,mysqli 扩展也是支持面向对象式的写法的。...什么是 MySQLi MySQLi 扩展允许我们访问 MySQL4.1 及以上版本的数据库所提供的功能。...$mysqli = mysqli_connect("localhost", "root", "", "blog_test");$res = mysqli_query($mysqli, "SELECT *...$mysqli = new mysqli("localhost", "root", "", "blog_test");$res = mysqli_query($mysqli, "SELECT * FROM...() 函数来执行语句,接着又使用面向对象的方式来获取结果集。
PHP中的MySQLi扩展学习(一)MySQLi介绍 关于 PDO 的学习我们告一段落,从这篇文章开始,我们继续学习另外一个 MySQL 扩展,也就是除了 PDO 之外的最核心的 MySQLi 扩展。...什么是 MySQLi MySQLi 扩展允许我们访问 MySQL4.1 及以上版本的数据库所提供的功能。...$mysqli = mysqli_connect("localhost", "root", "", "blog_test"); $res = mysqli_query($mysqli, "SELECT...$mysqli = new mysqli("localhost", "root", "", "blog_test"); $res = mysqli_query($mysqli, "SELECT * FROM...mysqli_query() 函数来执行语句,接着又使用面向对象的方式来获取结果集。
本节课我们了解下mysqli扩展及几个sql。...nickname='昵称' //更新数据 update guest set title='这是修改过的标签' where id=2 //删除数据 delete from guest where id=1 //查询...select id,title,content from guest limit 10 select * from guest where id=2 二、mysqli扩展 class mysqli{...} //数据库连接 $mysqli = new mysqli("localhost", "my_user", "my_password", "world"); //数据库连接错误号码 $mysqli...$result=$mysqli->query($sql); //设置结果类型 返回一行的数据 //MYSQLI_ASSOC, MYSQLI_NUM, or MYSQLI_BOTH.
MySQLi 中好玩的方法函数。...在实例化过程中,我们并没有给 mysqli 的构造函数传递任何的参数,而是使用 real_connect() 方法来传递数据库服务器信息并建立连接。...如果执行的是 SELECT 语句,那么 query() 返回的就是一个 mysqli_result 对象,它代表从一个数据库查询中获取的结果集。关于这个对象的内容我们将在后面的文章中进行详细的说明。...所以,use_result() 方法最大的好处就是占用内存小,适合大量查询的遍历,缺点则是每次都要去数据库查询,速度慢。...store_result 除了 use_result() 之外,还有一个 store_result() 方法可以帮助我们获得查询的结果集。
所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。 事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。...而在 MySQLi 中,我们则需要指定 MySQLi_Driver 对象中的报错属性为抛出异常,很明显,MySQLi_Driver 就是 MySQLi 的驱动对象。...// 使用异常处理错误情况 $driver = new mysqli_driver(); $driver->report_mode = MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT...try { // 开始事务 $mysqli->begin_transaction(); $mysqli->query("insert into tran_innodb (name...12)"); // 不存在的表 // 提交事务 $mysqli->commit(); } catch (Exception $e) { // 回滚事务 $mysqli
由于MySQL扩展从php5.5开始弃用,所以以后不推荐大家再用MySQL扩展,请用MySQLi或PDO代替,以下是MySQL对应的MySQLi函数(绿色字体)供大家参考。...mysql_close — (mysqli_close())关闭 MySQL 连接 mysql_connect — (mysqli_connect())打开一个到 MySQL 服务器的连接 mysql_create_db...取得 mysql_list_dbs() 调用所返回的数据库名 mysql_db_query — (mysqli_select_db() then the mysqli_query())选择一个数据库并在它上面执行一个查询...(mysqli_fetch_field_direct() [name] or [orgname])取得结果中指定字段的字段名 mysql_field_seek — (mysqli_field_seek...取得 mysql_list_dbs() 调用所返回的数据库名 mysql_db_query — (mysqli_select_db() then the mysqli_query())选择一个数据库并在它上面执行一个查询
今天跟大家分享的是查询函数——lookup函数家族! 查询函数是excel函数中使用频繁程度与求和函数不相上下的功能。...excel中关于查询功能的函数主要有以下几组: lookup函数组: lookup vlookup hlookup index+match函数 今天我们只介绍第一组lookup函数: lookup函数:...当您需要查询一行或一列并查找另一行或列中的相同位置的值时,会使用其中一个查找和引用函数 LOOKUP。...Vlookup函数: 关于vlookup函数的语法解释,vlookup(查找数据,目标数据,返回列数,查找方式) ? ?...以上三个函数中,vlookup函数应用场景最为丰富,参数设置比较灵活。 通过对比三个函数的用法,我们可以发现三者之间的区别主要如下: ? ? ?
PHP中的MySQLi扩展学习(六)MySQLI_result对象操作 在之前的文章中,我们就已经接触过 MYSQLI_result 相关的内容。它的作用其实就是一个查询的结果集。...但在 MySQLi 中,会把查询到的结果也放入一个对象中,这就是 MySQLI_result 对象。...MySQLI_result 对象属性 首先,我们要通过一段查询来获得一个 MySQLI_result 对象。...对于我们的业务开发来说其实用处不大,除了 num_rows 可以用来根据行数判断查询是否有结果之外,更重要的是我们要获取到结果集中的数据信息,这时就需要使用其它的函数来进行数据的获取了。...总结 至此,MySQLi 相关扩展的学习我们也就告一段落了,其它的一些类和函数比如 MySQLI_Driver 、 MySQLI_Exception 之类的内容大家可以自行查阅相关的文档,内容都不是很多
我们继续 MySQLi 扩展的学习,上篇文章中提到过,MySQLi 的扩展相对于 PDO 来说功能更加的丰富,所以我们依然还会在学习过程中穿插各种 MySQLi 中好玩的方法函数。...在实例化过程中,我们并没有给 mysqli 的构造函数传递任何的参数,而是使用 real_connect() 方法来传递数据库服务器信息并建立连接。...如果执行的是 SELECT 语句,那么 query() 返回的就是一个 mysqli_result 对象,它代表从一个数据库查询中获取的结果集。关于这个对象的内容我们将在后面的文章中进行详细的说明。...所以,use_result() 方法最大的好处就是占用内存小,适合大量查询的遍历,缺点则是每次都要去数据库查询,速度慢。...store_result 除了 use_result() 之外,还有一个 store_result() 方法可以帮助我们获得查询的结果集。
PHP连接和操作MySQL数据库的常用方式有3种,分别是MySQLi (面向对象),MySQLi (面向过程),PDO (面向对象)。...MySQLi和PDO 都是PHP的扩展,MySQLi只针对 MySQL 数据库,PDO则可以应用在十几种数据库中。而面向对象和面向过程是项目开发中两种不同的编程思想。...以下演示的将是MySQLi (面向对象)的代码示例。 以下的操作中,并不是所有的操作都要同时出现,而是根据需求选择相对应的操作。 第一步 连接数据库 <?...$username = "root"; //数据库密码 $password = "123456"; //数据库名称 $database = 'testDB' // 创建连接 $conn = new mysqli
今天要跟大家分享的是一个强大的查询与引用函数——offset函数! OFFSET函数的语法参数相对比较多,但是因为参数位置和函数都比较固定,所以只要能够理解各自含义,应用起来就会很方便。...=OFFSET(A1,2,0,1,1) 上例中函数语法:从A1单元格开始,移动2行,0列,引用一行,一列。对应引用区域刚好是A3单元格(B地区)。...offset函数更多的使用在动态引用单元格或者制作动态图表的数据源。 下面我们分别使用数据有效性下拉菜单、组合框、列表框等组件来看offset是如何动态引用数据的。...=OFFSET(E1,MATCH($O$1,$A$2:$A$6),0,1,1) 以上语法的含义是:通过数据有效性选择地区,然后通过match返回该地区在A2:A6区域中的位置,然后通过offset函数从...=OFFSET(A1,$P$2,0,1,1) 使用列表框,结合offset函数,我们也可以实现动态引用。
可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...MySQLI_STMT 中绑定列的方法名为 bind_result() ,虽说名字不一样,但功能其实都是差不多的,查询语句中是几个列名,就要绑定几个列名。...当使用 fetch() 进行查询结果对象的遍历时,就像使用引用的方式为这 4 个列变量赋值。...在这段代码中,我们使用了 num_rows 这个属性来获得查询结果的行数量,这个属性是只针对 SELECT 语句的。...保存结果集及游标移动 最后就是关于游标的移动,上面的测试数据中我们可以查询到 7 条数据,并且第一条数据的 id 是 42 ,通过游标,我们可以不在 SQL 语句中使用 limit 而直接操作结果集来获取需要的数据
所以上一篇主要提到了几种可以优化分页的方案,而且分页业务一般都伴随着需要count函数查询总条数,所以本篇文章主要讲讲count函数的一般优化方案。 为什么分页一般要伴随查询数量?...函数查询条数的逻辑了,而是大部分分页往往伴随着需要查询总数量的业务。...首先,我们先贴下最基本的count函数语法: select count(expr) from table; 可以看到count函数实际上需要传入expr,这个expr一般取值有以下三个: 列名:会检索对应列值不为...count函数指定where条件 这里一样得分两种情况:count(*)和count(col)。 count(*):where条件添加索引,就可以使用索引优化查询。...然后我们查询name并且使用name限制条件看看是否可以使用索引优化查询: ? 可以看到查询的列名和where条件的列明一致就可以走索引查询提高效率了。
函数名: enumerate() 函数说明: 将下标和索引的值都表示出来 num = np.array([1,3,5,7,9]) for index,value in enumerate(num):...print(index,value) 结果 0 1 1 3 2 5 3 7 4 9 ---- 函数名: lstrip(),rstrip() 函数说明: 删除字符串开头(末尾)指定指定字符串 str...thwas is really string ---- 函数名: rfind() 函数说明: 返回字符串最后一次出现的位置(从右向左查询),如果没有匹配项则返回-1。...: rjust() 函数说明: 返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串。...(rand_num) 结果 [10, 2, 7, 4, 1] ---- 函数名: mean(),sum() 函数说明: 返回数组平均值 和 num = np.array([[1,2,3],[4,5,6
作为替代,可以使用 mysqli 或者 PDO_MySQL 扩展代替。 MySQL 增强版。 mysqli扩展允许我们访问MySQL 4.1及以上版本提供的功能。...是 否 是否支持所有MySQL4.1以上功能 是 否 MySQLi 的 i 代表 Improvement。...相关概念 MySQL 与 MySQLi 都是PHP方面的函数集。 在 PHP5 版本以后,增加了mysqli的函数功能。 某种意义上讲,它是MySQL系统函数的增强版,更稳定更高效更安全。...MySQLi 多次运行将使用同一连接进程,减少了服务器的开销。 链接方式 <?...建议 PHP版本为5.x建议使用 mysqli 扩展。 PHP版本为7 只能使用 mysqli 扩展。 Thanks ~
PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句 对于 MySQLi 来说,事务和预处理语句当然是它之所以能够淘汰 MySQL(原始) 扩展的资本。...所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。 事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。...而在 MySQLi 中,我们则需要指定 MySQLi_Driver 对象中的报错属性为抛出异常,很明显,MySQLi_Driver 就是 MySQLi 的驱动对象。...// 使用异常处理错误情况 $driver = new mysqli_driver(); $driver->report_mode = MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT...try { // 开始事务 $mysqli->begin_transaction(); $mysqli->query("insert into tran_innodb (name
PHP5.0开始,不仅可以使用早期的mysql数据库扩展函数,还能使用新扩展的mysqli技术实现与mysql数据库的信息交流,PHP的mysqli扩展被封装在在一个类中,它是一种面向对象技术,只能在PHP5...和MYSQL4,1或更高的版本才能使用,(i)表示该进,使用mysqli,执行速度更快,更方便,更高效,也可以使数据库访问更安全(因为用类模式) 使用mysqli 简单流程 设置PHP.ini 配置文件....jpg 查询: 微信图片_20191129171041.jpg 三种处理查询结果: 微信图片_20191129171057.jpg 关联数组,就是嵌套的数组 如: 微信图片_20191129171114...$res2 or $mysqli->affected_rows !....jpg 以上就是PHP Mysqli 常用代码集合所有详细内容。
连接数据库 连接数据库有两种方式,一种是通过mysqli_connect()帮助函数,另一种是通过new mysqli()对象来实现 两者所需传的参数同样都是这些(注意先后顺序): host 数据库地址...设置字符集 使用mysqli_set_charset($connect, 'utf8');函数设置 第一个参数为mysqli的对象,第二个参数为需要设置的字符集,注意mysql的字符集中的utf8没有中间的...可以通过mysqli_fetch_array()、mysqli_fetch_assoc()、mysqli_fetch_all()、mysqli_fetch_row()等进行获取结果 当需要获取一条数据的时候可以使用...mysqli_fetch_row() mysqli_fetch_array() 该函数的第一个参数是通过mysqli_query()返回的对象 第二个参数是获取结果的类型: MYSQLI_ASSOC...关联数组 同mysqli_fetch_assoc()函数 MYSQLI_NUM 数字数组 MYSQLI_BOTH默认。
CREATE OR REPLACE FUNCTION FIND_IN_SET(piv_str1 varchar2, piv_str2 varchar2, p_s...