mysqli的基本使用
简单实例
面向过程方式
// 创建数据库连接
$connect = mysqli_connect('127.0.0.1', 'root', 'root', 'test', 8889);
// 判读是否连接成功了
if (!$connect) {
echo '数据库连接失败<br>';
// 打印连接失败的原因
var_dump(mysqli_connect_error($connect));
exit();
}
// 设置字符集
mysqli_set_charset($connect, 'utf8');
// 组装sql语句
$sql = "SHOW TABLES";
// 执行sql语句
$res = mysqli_query($connect, $sql);
// 获取结果
$res_array = mysqli_fetch_all($res);
var_dump($res_array);
mysqli_close($connect);
// 输出结果:
array (size=2)
0 =>
array (size=1)
0 => string 'family' (length=6)
1 =>
array (size=1)
0 => string 'person' (length=6)
面向对象方式
// 创建数据库连接对象
$connect = new mysqli('127.0.0.1', 'root', 'root', 'test', 8889);
// 判断是否连接成功
if ($connect->connect_errno) { // 发生错误时,$connect->connect_errno会返回对应的错误码
echo '数据库连接失败<br>';
// 打印错误信息
var_dump($connect->connect_error);
}
// 设置字符集
$connect->set_charset('utf8');
// 组装sql语句
$sql = "SHOW TABLES";
// 执行sql语句
$res = $connect->query($sql);
// 获取结果集
$data = $res->fetch_all();
// 关闭连接
$connect->close();
mysqli详解
1. 连接数据库
连接数据库有两种方式,一种是通过mysqli_connect()帮助函数,另一种是通过new mysqli()对象来实现
两者所需传的参数同样都是这些(注意先后顺序):
host数据库地址数据库地址可以传入域名或ip地址,如
localhost或者127.0.0.1username管理用户名管理员账号,如:
rootpassword 管理员密码
管理员账号的密码
dtabases要连接的数据选择要连接的数据库
port端口号该参数如果不传,默认请求
3306端口
2. 设置字符集
- 使用
mysqli_set_charset($connect, 'utf8');函数设置
第一个参数为mysqli的对象,第二个参数为需要设置的字符集,注意mysql的字符集中的utf8没有中间的-
- 使用面向对象的方式创建
$connect = new mysqli('127.0.0.1', 'root', 'root', 'test', 8889);
$connect->set_charset('utf8');
// 或者
$connect = mysqli_connect('127.0.0.1', 'root', 'root', 'test', 8889);
$connect->set_charset('utf8'); # 都可以这么使用
3. 执行sql语句
通过mysqli_query()进行执行SELECT, SHOW, DESCRIBE或 EXPLAIN,失败时返回false
$sql = "SHOW TABLES";
$res = $connect->query($sql); # 或者 mysqli_query($connect, $sql);
打印一下他返回了什么
var_dump($res);
object(mysqli_result)[2]
public 'current_field' => int 0
public 'field_count' => int 1
public 'lengths' => null
public 'num_rows' => int 2 # 返回了几条数据
public 'type' => int 0
4. 获取结果
通过mysqli_query()执行的sql语句之后如何获取结果呢?可以通过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默认。同时产生关联和数字数组# MYSQLI_BOTH 默认情况
$sql = "SHOW TABLES";
$res = $connect->query($sql);
$data = $res->fetch_array(); # 或者 mysqli_fetch_array($res)
var_dump($data);
# 输出结果
array (size=2)
0 => string 'family' (length=6)
'Tables_in_test' => string 'family' (length=6)
# MYSQLI_ASSOC 获取关联数组
$sql = "SHOW TABLES";
$res = $connect->query($sql);
$data = $res->fetch_array(MYSQLI_ASSOC); # 或者 mysqli_fetch_array($res, MYSQLI_ASSOC)
var_dump($data);
# 输出结果
array (size=1)
'Tables_in_test' => string 'family' (length=6)
# MYSQLI_NUM 获取关联数组
$sql = "SHOW TABLES";
$res = $connect->query($sql);
$data = $res->fetch_array(MYSQLI_NUM); # 或者 mysqli_fetch_array($res, MYSQLI_NUM)
var_dump($data);
# 输出结果
array (size=1)
0 => string 'family' (length=6)
mysqli_fetch_assoc()该函数与
mysqli_fetch_array第二个参数传递MYSQLI_ASSOC的结果是一样的$sql = "SHOW TABLES";
$res = $connect->query($sql);
$data = $res->fetch_assoc(); # 或者 mysqli_fetch_assoc($res)
# 输出结果
array (size=1)
'Tables_in_test' => string 'family' (length=6)
mysqli_fetch_all同
mysqli_fetch_array一样,只不过他的默认获取是数字索引数组$sql = "SHOW TABLES";
$res = $connect->query($sql);
$data = $res->fetch_all(); # 或者 mysqli_fetch_all($res)
# 输出结果
array (size=2)
0 =>
array (size=1)
0 => string 'family' (length=6)
1 =>
array (size=1)
0 => string 'person' (length=6)
mysqli_fetch_row获取一条数据
$sql = "SHOW TABLES";
$res = $connect->query($sql);
$data = $res->fetch_row(); # 或者 mysqli_fetch_row($res)
# 输出结果
array (size=1)
0 => string 'family' (length=6)
5. 关闭连接
mysqli_close($connect);
// 或者
$connect->close();
mysqli的基本使用的更多相关文章
- 比Mysqli操作数据库更简便的方式 。PDO
下面来说一下PDO 先画一张图来了解一下 mysqli是针对mysql这个数据库扩展的一个类 PDO是为了能访问更多数据库 如果出现程序需要访问其他数据库的话就可以用PDO来做 PDO数据访问抽象层1 ...
- PHP 数据库连接工具类(MySQLI函数包装)
====================mysql===================== <?php class mysql { private $mysqli; private $resu ...
- php mysqli mysqli_query() mysqli_real_query()
2016年11月26日 15:22:27 星期六 场景: PHP从mysql中读取数据 1. 一次性读取所有数据返给PHP 2. 每次循环只读取一掉记录 数据量小的时候可以使用第一种方法, 数据量很大 ...
- mysqli操作数据库
1 连接数据库:可以使用对象或函数来连接(我们这里主要用mysqli对象,附带着函数连接) //创建mysqli对象(也可以叫做资源句柄) $_mysqli = new mysqli(); //连接数 ...
- php的mysql\mysqli\PDO(二)mysqli
原文链接:http://www.orlion.ga/1147/ mysqli有面向对象风格和面向过程风格,个人感觉还是用面向对象风格比较好(毕竟是面向对象) 1.mysqli::_construct( ...
- PHP使用mysqli扩展库实现增删改查(面向对象版)
mysqli扩展库是mysql扩展库的改进版本,在mysql扩展库的基础上提高了稳定性和效率,mysqli扩展库有两套东西,一套就是面向过程的mysqli另一套是面向对象的mysqli.操作方式大体和 ...
- 解决 Deprecated: mysql_connect(): The mysql extension is deprecated and will be removed in the future: use mysqli or PDO instead in
转载 php 5个版本,5.2.5.3.5.4.5.5,怕跟不上时代,新的服务器直接上5.5,但是程序出现如下错误:Deprecated: mysql_connect(): The mysql ext ...
- PHP mysql与mysqli事务详解
官方对PHP连接到MySQL数据库服务器的三种主要的API简介如下: http://php.net/manual/zh/mysqli.overview.php PHP mysql与mysqli事务详解 ...
- mysql、mysqli、PDO一句话概括比较
mysql.mysqli.PDO一句话概括比较 1 mysql扩展 (注:原始的,较差) 2 mysqli扩展(面向过程式) (注:比上面多了更多功能) 3 mysqli扩展(面向对象式) (注:比上 ...
- mysqli链接数据库:面向对象
$mysqli = new mysqli('localhost','root','123','test');//检查连接是否成功if (mysqli_connect_error()){ //注意mys ...
随机推荐
- Mybatis学习笔记导航
Mybatis小白快速入门 简介 本人是一个Java学习者,最近才开始在博客园上分享自己的学习经验,同时帮助那些想要学习的uu们,相关学习视频在小破站的狂神说,狂神真的是我学习到现在觉得最GAN的老师 ...
- JIPB | 两篇连发:华中农大黄俊斌团队报道二羟基异丁酰化调控稻曲病菌致病新机制
水稻是我国重要的粮食作物,稻曲病是水稻三大病害之一,不仅造成稻米产量损失,更重要的是稻曲球中的稻曲菌素的毒性和致畸作用,给人畜健康带来严重威胁.病原菌对植物的侵袭是由病原菌的毒力和植物免疫系统相互作用 ...
- 如何用Git上传项目到GitHub
1.登录gitHub,进入主页面,点击"+"号,建立新仓库. 2. 输入自己的仓库名,和简单的描述,根据自己设置为公开的或私有的. 我输入的是仓库名为ESMS. 勾选此选项,rea ...
- Activity与Service生命周期
一. Activity 先展示一张Activity的生命周期图: 1.1 Activity状态 只有下面三个状态是静态的,可以存在较长的时间内保持状态不变.(其它状态只是过渡状态,系统快速执行并切换到 ...
- 开发一个分布式IM(即时通信)系统!
作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 这知识学的,根本没有忘的快呀?! 是不是感觉很多资料,点收藏起来爽.看视频时候嗨.读 ...
- Java Lambda 表达式源码分析
基本概念 Lambda 表达式 函数式接口 方法引用 深入实现原理 字节码 为什么不使用匿名内部类? invokedynamic 总结 参考链接 GitHub 项目 Lambda 表达式是什么?JVM ...
- python关于多级包之间的引用问题
首先得明确包和模块. 包:在一个目录下存在__init__.py,那么该目录就是一个包. 模块:一个.py文件就是一个模块. 我们可以通过from 包 import 模块来引入python文件, 也可 ...
- flutter升级2.0
前言 flutter2.0版本带来了很多变化,特别是加入了空安全,升级后的大片报错,让大家望而却步. 现在距2.0发布已经快半年了,大部分插件也支持了空安全,而我们的项目却因为版本低,用不上新东西,所 ...
- Liunx搭建Rlogin服务
实验环境为 centos7 第一步:安装服务:yum -y install rsh rsh-server xinetd 第二步:启动服务: systemctl restart rsh.sockets ...
- docker 安装mysql设置不区分表名大小写,创建minio,设置开机自启动
环境deepin mysql : docker run -p 3306:3306 --name tyer-mysql --restart=always -v $PWD/conf:/etc/mysql/ ...