PHP连接和操作MySQL数据库的常用方式有3种,分别是MySQLi (面向对象),MySQLi (面向过程),PDO (面向对象)。...MySQLi和PDO 都是PHP的扩展,MySQLi只针对 MySQL 数据库,PDO则可以应用在十几种数据库中。而面向对象和面向过程是项目开发中两种不同的编程思想。...以下演示的将是MySQLi (面向对象)的代码示例。 以下的操作中,并不是所有的操作都要同时出现,而是根据需求选择相对应的操作。 第一步 连接数据库 <?...$username = "root"; //数据库密码 $password = "123456"; //数据库名称 $database = 'testDB' // 创建连接 $conn = new mysqli
不过在 PDO 中,一般直接通过 query() 或者 PDOStatement 对象进行查询之后就会返回结果。...但在 MySQLi 中,会把查询到的结果也放入一个对象中,这就是 MySQLI_result 对象。...MySQLI_result 对象属性 首先,我们要通过一段查询来获得一个 MySQLI_result 对象。...,它可以指定返回的格式,默认情况下是 MYSQLI_NUM 这种数组下标的形式,和 PDO 类似,我们直接指定为 MySQLI_ASSOC 就可以返回键名形式的数据内容。...获取对象结果集其实和 PDO 中的相关功能也是类似的,它就是将结果直接放到一个类中,并实例化返回一个对象。
就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi 所生成的预处理语句的。...同 PDO 一样,这个方法只返回成功失败的信息,也就是一个布尔值。...可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...返回结果集 执行 fetch() 方法返回的是一个布尔值,它主要的作用是将结果集绑定到指定的变量中,所以如果你直接打印它的结果是不会有什么有用的信息的,我们必须通过绑定列变量的方式来获得数据。...然后通过该对象的 fetch_assoc() 就获得了键名形式的结果集数组。 关于 MySQLI_result 对象的内容,我们将在下篇文章中再进行详细的学习了解。
PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作 就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi...同 PDO 一样,这个方法只返回成功失败的信息,也就是一个布尔值。...可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...返回结果集 执行 fetch() 方法返回的是一个布尔值,它主要的作用是将结果集绑定到指定的变量中,所以如果你直接打印它的结果是不会有什么有用的信息的,我们必须通过绑定列变量的方式来获得数据。...然后通过该对象的 fetch_assoc() 就获得了键名形式的结果集数组。 关于 MySQLI_result 对象的内容,我们将在下篇文章中再进行详细的学习了解。
from flask import Flask from flask import make_response
论MyBatis返回结果集_返回实体类还是Map 在更多的了解mybatis后发现不单单通过实体类可以直接返回数据,还可以直接返回一个Map结果集(resultType=”java.util.Map...”) ,如果是多条数据则返回一个List>结果集。...很多人会觉得发现,直接返回一个Map的话太方便了,什么映射什么的全都不用管,只用在sql书写的之后 as好别名就可以了。...1.可读性,当你前端用Map接收传递参数和mybatis返回用map接收和传递参数,当你过些时需要行进代码review的时候你会发现你需要先去看jsp里的参数名和sql返回的别名。...2.MyBatis也是O/R框架的一员,从业界准则来看,不符合面向对象思想。 一个代码规范问题。 然后关于效率问题目前还没有参考到。
现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。当然,mysqli 扩展也是支持面向对象式的写法的。...仅支持面向对象方式使用 可以连接多种数据库,切换数据库带来的变更少,甚至可能不用修改代码 支持 存储过程 、 多语句执行 、 预处理语句 最后就是 MySQLi 。...方法名上全部改成 mysqli_xxx 就可以了。 面向对象式 面向对象式的就有点像 PDO 。我们要先获得一个连接句柄类,然后操作这个类就可以了。...zyblog_test_user");$row = $res->fetch_assoc();print_r($row); 在这段代码中,我们实例化了一个 mysqli 对象,然后使用面向过程的 mysqli_query...在接下来的文章中,我们将默认只使用 面向对象 式的写法来继续学习 MySQLi 扩展相关的知识。
现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。当然,mysqli 扩展也是支持面向对象式的写法的。...仅支持面向对象方式使用 可以连接多种数据库,切换数据库带来的变更少,甚至可能不用修改代码 支持 存储过程 、 多语句执行 、 预处理语句 最后就是 MySQLi 。...方法名上全部改成 mysqli_xxx 就可以了。 面向对象式 面向对象式的就有点像 PDO 。我们要先获得一个连接句柄类,然后操作这个类就可以了。...mysqli_query() 函数来执行语句,接着又使用面向对象的方式来获取结果集。...在接下来的文章中,我们将默认只使用 面向对象 式的写法来继续学习 MySQLi 扩展相关的知识。
基于REST API的项目返回的数据结构题都是统一的,这样方便接口对接和使用。...因此,对结果对象的设计会有一定的要求: 一个结果对象要能够同时支持成功和失败的数据结构; 要能够处理多种类的返回结果对象; 能够很轻易的判断出结果是成功还是失败; 能够存储错误编码和错误信息; 下面就基于...Spring Boot项目来设计一下对应的统一结果返回对象。...this.code = code; this.message = message; } } ErrorResponse有code和message两个字段,code可以是http的返回编码也可以是任何业务编码...基于上述对象,返回的JSON报文格式如下: { "status": "success", "data": { "task": "Write a post",
对象的传值与返回 说起函数,就不免要谈谈函数的参数和返回值。一般的,我们习惯把函数看作一个处理的封装(比如黑箱),而参数和返回值一般对应着处理过程的输入和输出。...相对于内置类型的参数传递和返回值,对象的传值和返回可能更复杂一点。当然,如果使用对象的引用或者指针作为参数传递和返回值的方式,这里和上述的内置类型并无多大区别,因为指针总是4个字节。...要获得fun的返回值,直接访问eax即可,因为它保存着返回值对象的地址(ebp-58h)! ? 最后一步是对象的赋值,这里需要调用对象的赋值运算符重载函数。...(a);//对象复制到实际参数 A*pret=&ret;//取返回值对象地址(已经开辟过了) fun(pret,x);//传递返回值指针pret和参数对象x a=*pret;//把返回值对象赋值给对象a...对象返回时,也需要将函数处理的结果进行一次对象拷贝,不过被拷贝的返回值对象内存已经在函数调用之前已经开辟出来了,函数只需要记录它的地址即可,然后调用拷贝构造函数初始化它。 3.
本节课我们了解下mysqli扩展及几个sql。...扩展 class mysqli{ } //数据库连接 $mysqli = new mysqli("localhost", "my_user", "my_password", "world"); /.../数据库连接错误号码 $mysqli->connect_errno //数据库连接错误内容 $mysqli->connect_error //设置编码 $mysqli->set_charset("utf8mb4...")) //执行sql语句 $result=$mysqli->query($sql); //设置结果类型 返回一行的数据 //MYSQLI_ASSOC, MYSQLI_NUM, or MYSQLI_BOTH...__construct 连接数据库 query 执行sql getRow 获取一行 getOne 获取一个字段 getCols 获取一列 getAll 获取多列 insert 插入数据并返回自增
($mysqli);// ["thread_id"]=>// int(164) 首先,我们实例化了一个 mysqli 对象。...通过打印 mysqli 对象的内容就可以看出,两个连接的线程ID不同,也就是说,它们是不同的两个连接,但是使用的都是最上面所初始化的那个 mysqli 对象。...记住,它返回的不是受影响的行数,这一点是需要注意的。我们如果需要获取受影响的行数需要使用 MySQLi 的属性 affected_rows 。...如果执行的是 SELECT 语句,那么 query() 返回的就是一个 mysqli_result 对象,它代表从一个数据库查询中获取的结果集。关于这个对象的内容我们将在后面的文章中进行详细的说明。...如果使用 query() 方法,返回的虽然是 PDOStatement 对象,但是它是无法遍历的。 接下来我们就看看 MySQLi 是如何来执行这个多条语句拼接在一起的 SQL 语句的。
var_dump($mysqli); // ["thread_id"]=> // int(164) 首先,我们实例化了一个 mysqli 对象。...通过打印 mysqli 对象的内容就可以看出,两个连接的线程ID不同,也就是说,它们是不同的两个连接,但是使用的都是最上面所初始化的那个 mysqli 对象。...记住,它返回的不是受影响的行数,这一点是需要注意的。我们如果需要获取受影响的行数需要使用 MySQLi 的属性 affected_rows 。...如果执行的是 SELECT 语句,那么 query() 返回的就是一个 mysqli_result 对象,它代表从一个数据库查询中获取的结果集。关于这个对象的内容我们将在后面的文章中进行详细的说明。...如果使用 query() 方法,返回的虽然是 PDOStatement 对象,但是它是无法遍历的。 接下来我们就看看 MySQLi 是如何来执行这个多条语句拼接在一起的 SQL 语句的。
所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 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...结果集对象 $username='bbb'; $stmt->bind_param('s', $username); $stmt->execute(); $bUser = $stmt->fetch();
php返回json,xml,JSONP等格式的数据 返回json数据: header(‘Content-Type:application/json; charset=utf-8’); $arr = array...(‘a’=>1,’b’=>2); exit(json_encode($data)); 注意:如果不加header直接输出json_encode的值的话,返回的是字符串不是对象,js那边就需要先eval(...‘(‘+data+’)’)转化为对象,在取值 返回xml数据: header(‘Content-Type:text/xml; charset=utf-8’); exit($xml); 返回jsonp数据...(json)”); //注意callback是js传过来的参数名称 thinkphp如何返回各种数据: this->ajaxReturn (json_encode( this->ajaxReturn (...json数据(返回json对象或json格式数据)
常见场景的需求是:通过某一个属性获取对应的枚举属性的另一个值;还有就是常量枚举,比如一下统一返回状态和编码! ==小编的需求是把枚举中的所有属性都取出来,转成实体类那种返回给前端!...这样有点麻烦,小编也是无意发现了,项目中有以前大佬留下来的一个注解@JSONType(serializeEnumAsJavaBean = true),一加上只需要我们使用枚举.values()即可直接帮助我们返回了
问题产生: 近来在写代码的时候,有一个返回的vo对象中,有一个属性是带有xml标签的,而页面展示的内容需要将xml标签转换成html标签进行展示,所以实现了一个工具类,然后再返回的地方调用一下工具类...spring实例化bean对象,默认是无参构造方法实例化的,这时就需要bean类中存在无参构造方法。...com.fasterxml.jackson.databind.JsonMappingException 打断点后发现,原有的工具类是以service形式注入进去的,值为null,又在方法中init()初始化了一下service对象
一个小技巧,调用构造方法或都new返回该对象: function Person(){ // ... // 不是new的时候this指向的是调用者 默认是window if (!
public int addClifford(Clifford clifford) { String sql = "insert into t_user...
领取专属 10元无门槛券
手把手带您无忧上云