起步

由于mysql连接方式被废除,在php7中要使用mysql_connect()还需要额外下载组件。

使用mysqli有面向过程和面向对象两种方式。

mysqli提供了三个类:

● mysqli 连接相关的

● mysqli_result 处理结果集

● mysqli_stmt 预处理类

数据库连接<?php

$db_host = 'localhost';

$db_name = 'test';

$db_user = 'root';

$db_pwd = '';

//面向对象方式

$mysqli = new mysqli($db_host, $db_user, $db_pwd, $db_name);

//面向对象的昂视屏蔽了连接产生的错误,需要通过函数来判断

if(mysqli_connect_error()){

echo mysqli_connect_error();

}

//设置编码

$mysqli->set_charset("utf8");//或者 $mysqli->query("set names 'utf8'")

//关闭连接

$mysqli->close();

//面向过程方式的连接方式

$mysqli = mysqli_connect($db_host, $db_user, $db_pwd, $db_name);

//判断是否连接成功

if(!$mysqli ){

echo mysqli_connect_error();

}

//关闭连接

mysqli_close($mysqli);

?>

数据库查询

通用:执行sql语句都可用query(sql),执行失败会返回false,select成功则返回结果集对象,其他返回true,只要不是false就说明sql语句执行成功了。<?php

//无结果集示例

$sql = "insert into table_name (`name`, `address`) values ('xiaoming', 'adddddrrreess')";

$result = $mysqli->query($sql);

//或者

$sql = "delete from table_name where name='xiaoming'";

$result = $mysqli->query($sql);

if($result === false){

echo $mysqli->error;

echo $mysqli->errno;

}

//影响条数

echo $mysqli->num_rows;

//插入的id

echo $mysqli->insert_id;

$mysqli->close();

有结果集<?php

$sql = "select * from table_name";

$result = $mysqli->query($sql);

if($result === false){//执行失败

echo $mysqli->error;

echo $mysqli->errno;

}

//行数

echo $result->num_rows;

//列数 字段数

echo $result->field_count;

//获取字段信息

$field_info_arr = $result->fetch_fields();

//移动记录指针

//$result->data_seek(1);//0 为重置指针到起始

//获取数据

while($row = $result->fetch_assoc()){

echo $row['name'];

echo $row['address'];

}

//也可一次性获取所有数据

//$result->data_seek(0);//如果前面有移动指针则需重置

$data = $result->fetch_all(MYSQLI_ASSOC);

$mysqli->close();

预处理示例

预处理能有效的防止sql注入的产生,mysqli_stmt是预处理类<?php

$sql = "insert inro table_name ('name','address') values (?,?)";

//获得预处理对象

$stmt = $mysqli->prepare($sql);

//绑定参数 第一个参数为绑定的数据类型

/*

i:integer 整型

d:double 浮点型

s:string 字符串

b:a blob packets blob数据包

*/

$name = "xiaoming";

$address = "adddressss";

$stmt->bind_param("ss", $name, $address);//绑定时使用变量绑定

//执行预处理

$stmt->execute();

/*

//可重新绑定 多次执行

$stmt->bind_param("ss", $name, $address);

$stmt->execute();

*/

//插入的id 多次插入为最后id

echo $stmt->insert_id;

//影响行数 也是最后一次执行的

echo $stmt->affected_rows;

//错误号

echo $stmt->errno;

//错误信息

echo $stmt->error;

//关闭

$stmt->close();

$mysqli->close();

下面示例select的预处理

//注释部分省略

$sql = "select * from table_name where id";

$stmt = $mysqli->prepare($sql);

$id = 30;

$stmt->bind_param("i", $id);

$stmt->execute();

//获取结果集

$result = $stmt->get_result();//结果集取后的操作就和之前一样了

//获取所有数据

$data = $result->fetch_all(MYSQLI_ASSOC);

$result->close();

$mysqli->close();

一次执行多条sql语句multiquery(不推荐),执行结果不是结果集,affectd_rows是最后影响的条数<?php

$sql_arr = array(

"insert into table_name (`name`,`address`) values ('xiaoming','a')",

"insert into table_name (`name`,`address`) values ('xiaohong','a')",

'delete from table_name where id=23',

);

$sql = implode(';', $sql_arr);

$result = $mysqli->multi_query($sql);

if($result === false){

echo $mysqli->error;

}

$mysqli->close();

更多的PHP相关知识,请访问PHP中文网!

php mysqli还原数据库,PHP mysqli操作数据库相关推荐

  1. oracle表的历史数据转储过程,C#连接Oracle数据库通过存储过程操作数据库 - cuizm的专栏 - CSDN博客...

    C#连接Oracle数据库通过存储过程操作数据库 收藏 此文于2011-06-07被推荐到CSDN首页 此文于2011-06-08被推荐到CSDN首页 如何被推荐? 之前笔者一直用C#连接SQL Se ...

  2. 第二百七十九节,MySQL数据库-pymysql模块操作数据库

    MySQL数据库-pymysql模块操作数据库 pymysql模块是python操作数据库的一个模块 connect()创建数据库链接,参数是连接数据库需要的连接参数 使用方式: 模块名称.conne ...

  3. Java数据库开发与应用之MySQL数据库、JDBC操作数据库、C3P0数据库连接池,Java反射等

    MySQL数据库,JDBC接口,MyBatis框架等,掌握的数据的存放和管理. Java数据库开发基础,介绍MySQL数据库.JDBC操作数据库.C3P0数据库连接池,Java反射等内容,进行油画商城 ...

  4. django_4:数据库1——django操作数据库

    创建数据库记录(插入) 使用python3 manage.py shell(python3亲测好使) ipython3 manage.py shell(亲测不好使) 方式一. [root@centos ...

  5. python创建数据库表_Python 操作数据库(1)SQL基础

    一.数据库 关系型数据库 常见的关系型数据库:SQL Server.MySql.MariaDB.SQLite.ORACLE.PostgreSQL等 非关系型数据库 常见的非关系型数据看:MongoDB ...

  6. vfp 连接mysql数据库_Visual FoxPro操作数据库之函数大全

    ADATABASES() 将所有打开数据库的名称和路径放到内存变量数组中 ADBOBJECTS() 把当前数据库中的命名连接名.关系名.表名或sQL视图名放到一个内存变量数组中 AFIELDS() 把 ...

  7. ProcessDB实时/时序数据库——C/C++操作数据库对象

    目录 前言 一.数据库字段介绍 二.新增数据库 三.删除数据库 四.修改数据库 五.查询数据库 前言 上文已经介绍C/C++使用ProcessDB的基本操作,本文将针对数据库的相关操作进行介绍 一.数 ...

  8. python搭配什么数据库_python 连接操作数据库(一)

    一.下面我们所说的就是连接mysql的应用: 1.其实在python中连接操作mysql的模块有多个,在这里我只给大家演示pymysql这一个模块(其实我是感觉它比较好用而已): pymysql是第三 ...

  9. dbcontext mysql_九、.net core用orm继承DbContext(数据库上下文)方式操作数据库

    一.创建一个DataContext普通类继承DbContext 安装程序集:Pomelo.EntityFrameworkCore.MySql 二.配置连接字符串(MySql/SqlServer都可以) ...

  10. php 单例模式数据库,php单例模式操作数据库(实例)

    代码 /* * 单例数据库连接 */ class Db { private static $_instance; //static可以保存值不丢失 private static $_dbConnect ...

最新文章

  1. 华为云发布全新DevOps实践,大幅提升交付效率
  2. Bitmap,byte[],Drawable相互转化
  3. 学python工资高吗-现在Python就业薪资高吗?
  4. TWITTER背后的开源技术
  5. 访百度奥运logo设计师李兴钢:虚实之间最美的呈现
  6. 最新Django2.0.1在线教育零基础到上线教程(十四)- 全剧终
  7. Adobe illustrator 论文图形编辑和排版 - 连载 1
  8. 几个简单的OpenCV程序
  9. 软考信息系统项目管理师_项目风险管理---软考高级之信息系统项目管理师019
  10. Atitit 远程存储与协议 mtp ptp rndis midi nfs smb webdav ftp Atitit mtp ptp rndis midi协议的不同区别 1. PTP: 图
  11. 【百度分享】javascript中函数调用过程中的this .
  12. 负载均衡之LVS详解
  13. 基于深度学习的人脸表情识别实现
  14. arcgis面积计算
  15. 笔记本电脑共享WiFi
  16. unity经营类游戏-植树造林-虚拟现实期末大作业
  17. 接力和隔空投送无效、handoff airdrop无效
  18. Nginx + ModSecurity 报错
  19. Python中pprint与print的区别
  20. java 实验6 图形用户界面设计试验(2)

热门文章

  1. 为什么美团打车、滴滴外卖必败?君智谢伟山揭秘了背后的竞争战略逻辑
  2. php 中curd表达啥,CURD语句的基本语法和PDO中操作数据表的基本步骤实例演示增删改查命令 2019年07月24日 23时10分...
  3. java struts2 excel上传_文件上传下载——通过struts的FormFile上传单个excel文件
  4. linux 查看mysql安装目录_Linux环境下安装MySQL数据库示例教程
  5. cos html cache插件,关于Cos-Html-Cache插件不能创建首页缓存的解决办法
  6. python中取整数的几种方法
  7. python 获取本机IP的三种方式
  8. Python练习题:合并列表和列表排序
  9. python函数后面有多个括号怎么理解?
  10. Python类的约束以及super()剖析