1.连接到数据库:

· 面向对象的方法:

$db = new mysqli('hostname', 'username', 'password', 'dbname');

· 面向过程的方法:

$db = mysqli_connect('hostname', 'username', 'password', 'dbname');

· 连接结果的检查:

if (mysqli_connect_errno()) {

echo 'Error: Could not connect to database.';

exit;

}

mysqli_connect_errno()将在连接错误时返回一个错误号,成功则返回0。

2.选择使用的数据库:

· 面向对象的方法:

$db->select_db(dbname);

· 面向过程的方法:

mysqli_select_db(db_resource, db_name);

3.操作数据库:

· 面向对象的方法:

$query = "select * from table table_name";

$result = $db->query($query);

返回一个结果对象,执行失败则返回false。

· 面向过程的方法:

$query = "select * from table table_name";

$result = mysqli_query($db, $query);

返回一个结果资源,执行失败则返回false。

4.获取结果:

· 面向对象的方法:

$num_results = $result->num_rows;

当使用面向对象的方法时,返回的行数保存在结果对象的num_rows成员变量中。

for ($i=0; $i < $num_results; $i++) {

$row = $result->fetch_assoc();

$value = $row[key];

...

}

· 面向过程的方法:

$num_results = mysqli_num_rows($result);

当使用面向过程的方法时,调用mysqli_num_rows()可以得到返回的行数。

for ($i=0; $i < $num_results; $i++) {

$row = mysqli_fetch_assoc($result);

$value = $row[key];

...

}

· 其他的方法:

1)将结果取回到一个枚举数组中:

· 面向对象的方法:

$row = $result->fetch_row();

· 面向过程的方法:

$row = mysqli_fetch_row($result);

然后通过下标访问即可($row[0], $row[1]...)。

2)将结果取回到一个对象中:

· 面向对象的方法:

$row = $result->fetch_object();

· 面向过程的方法:

$row = mysqli_fetch_object($result);

之后通过$row->keyname访问每个属性即可。

以上是针对数据库查询,如果是执行数据库修改时,应该使用mysqli_affected_rows()来得到受影响的数据库条目总数:

· 面向对象的方法:

$num = $db->affected_rows;

· 面向过程的方法:

$num = mysqli_affected_rows($db);

5.断开连接:

· 面向对象的方法:

$result->free();

· 面向过程的方法:

mysqli_free_result($result);

这样即可释放结果集。

之后断开数据库连接:

· 面向对象的方法:

$db->close();

· 面向过程的方法:

mysqli_close($db);

____________________________

推荐阅读:

Logstash+Kafka+ES实现日志采集系统

大数据开放平台产品落地方案

支付宝系统架构内部剖析

华为Java编程军规,每季度代码验收标准

大数据Spark与Storm技术选型

PHP基础:MYSQL数据库操作的更多相关文章

  1. Vc数据库编程基础MySql数据库的表查询功能

    Vc数据库编程基础MySql数据库的表查询功能 一丶简介 不管是任何数据库.都会有查询功能.而且是很重要的功能.上一讲知识简单的讲解了表的查询所有. 那么这次我们需要掌握的则是. 1.使用select ...

  2. Vc数据库编程基础MySql数据库的常见库命令.跟表操作命令

    Vc数据库编程基础MySql数据库的常见操作 一丶数据库常见的库操作 1.1查看全部数据库 命令:  show databases 1.2 创建数据库 命令: Create database 数据库名 ...

  3. php : mysql数据库操作类演示

    设计目标: 1,该类一实例化,就可以自动连接上mysql数据库: 2,该类可以单独去设定要使用的连接编码(set names XXX) 3,该类可以单独去设定要使用的数据库(use XXX): 4,可 ...

  4. php MySQL数据库操作类源代码

    php MySQL数据库操作类源代码: <?php class MySQL{ private $host; //服务器地址 private $name; //登录账号 private $pwd; ...

  5. 设计模式 - 单例模式mysql数据库操作类

    待续... index.php 调用方法: <?php header('Content-Type:text/html; charset=utf8'); require 'instance.php ...

  6. MySQL数据库操作常用命令

    MySQL数据库操作常用命令DOS连接数据库1.安装MySQL配置好环境2.运行cmd命令net start mysql3.找到mysql文件根目录输入命令mysql -h localhost -u ...

  7. Python/MySQL(四、MySQL数据库操作)

    Python/MySQL(四.MySQL数据库操作) 一.数据库条件语句: case when id>9 then ture else false 二.三元运算: if(isnull(xx)0, ...

  8. Java通过JDBC 进行MySQL数据库操作

    转自: http://blog.csdn.net/tobetheender/article/details/52772157 Java通过JDBC 进行MySQL数据库操作 原创 2016年10月10 ...

  9. Vc数据库编程基础MySql数据库的表增删改查数据

    Vc数据库编程基础MySql数据库的表增删改查数据 一丶表操作命令 1.查看表中所有数据 select * from 表名 2.为表中所有的字段添加数据 insert into 表名( 字段1,字段2 ...

  10. Mysql 数据库操作之DDL、DML、DQL语句操作

    Mysql 数据库操作之DDL.DML.DQL语句操作 设置数据库用户名密码 l  Show databases 查看数据库列表信息 l  查看数据库中的数据表信息 ,格式: use 数据库名: sh ...

随机推荐

  1. Lua学习链接

    Lua捕获 Lua中_G 是个什么鬼 Lua与ObjC的交互

  2. return和throw某些特性相似

    拷贝构造函数的调用拷贝构造函数会在以下三中情况下被调用(1)当类的一个对象去初始化该类的另一个对象时 int main(){ Point a(1,2); Point b(a);//用对象a初始化对象b ...

  3. 美图App的移动端DNS优化实践:HTTPS请求耗时减小近半

    本文引用了颜向群发表于高可用架构公众号上的文章<聊聊HTTPS环境DNS优化:美图App请求耗时节约近半案例>的部分内容,感谢原作者. 1.引言 移动互联网时代,APP 厂商之间的竞争非常 ...

  4. [Swift]LeetCode946. 验证栈序列 | Validate Stack Sequences

    Given two sequences pushed and popped with distinct values, return true if and only if this could ha ...

  5. zookeeper使用详解(命令、客户端、源码)

    1. zookeeper使用详解(命令.客户端.源码) 1.1. 前言   zookeeper我们常用来做分布式协调中间件,很多时候我们都接触不到它的原理和用法,我对他的了解也仅限于知道它可以做分布式 ...

  6. 【Spark调优】提交job资源参数调优

    [场景] Spark提交作业job的时候要指定该job可以使用的CPU.内存等资源参数,生产环境中,任务资源分配不足会导致该job执行中断.失败等问题,所以对Spark的job资源参数分配调优非常重要 ...

  7. linux安装RabbitMQ

    一.RabbitMQ概念RabbitMQ是流行的开源消息队列系统,是AMQP(Advanced Message Queuing Protocol高级消息队列协议)的标准实现,用erlang语言开发.R ...

  8. redis 系列22 复制Replication (下)

    一. 复制环境准备 1.1 主库环境(172.168.18.201) 环境 说明 操作系统版本 CentOS  7.4.1708  IP地址 172.168.18.201 网关Gateway 172. ...

  9. Java__线程---基础知识全面实战---坦克大战系列为例

    今天想将自己去年自己编写的坦克大战的代码与大家分享一下,主要面向学习过java但对java运用并不是很熟悉的同学,该编程代码基本上涉及了java基础知识的各个方面,大家可以通过练习该程序对自己的jav ...

  10. 就算会用python画颗心,可你依然还是只单身狗

    :) 标题是开玩笑的,千万别认真. 随着AI的飞速发展,有志于此行的码农也是急剧的增加,带来的就是大家对算法.数学的兴趣也格外升高. 本文的来历是这样,今天某老同事在朋友圈发了一张屏拍,求公式. 看了 ...