PHP:MySQL数据库访问(mysqli & PDO)

php中文网
发布: 2016-06-23 13:21:11
原创
1299人浏览过

一. 使用mysqli访问数据库

1. 连接数据库

$db = new mysqli("localhost", "username", "password", "databaseName");或者:@ $db = mysqli_connect("localhost", "username", "password", "databaseName");
登录后复制

2. 关闭数据库

$db->close();或者:mysqi_close($db);
登录后复制

3. 选择使用的数据库

$db->select_db(databaseName);或者:mysqli_select_db(databaseName);
登录后复制

4. 查询数据库

查询:

$query = "SELECT * from dbName";$result = $db->query($query);或者:mysqli_query($db, $query);
登录后复制

5. 检索查询结果

(1)查询结果的行数:

$num_results = $result->num_rows;或者:$num_results = mysqli_num_rows($result);
登录后复制

(2)查询结果的每一行内容:

$row = $result->fetch_assoc();或者:$row = mysqli_fetch_assoc($result);
登录后复制

获取每一行的字段的值:

$row["books"]
登录后复制

(3)获取查询结果的列举数组:

$row = $result->fetch_object();或者:$row = mysqli_fetch_object($result);
登录后复制

然后可以通过$row[0}、$row[1]或$row->title、$row->author等来访问每个属性。

6. 释放结果集

$result->free();

立即学习PHP免费学习笔记(深入)”;

或者:

mysqli_free_result($result);

二. 使用PDO访问数据库

1. 连接数据库

$mysql = new PDO("mysql:host=localhost", $user, $password);$mysql = new PDO("mysql:host=localhost;port=8090", $user, $password);$mysql = new PDO("mysql:host=localhost;port=8090;dbname=android", $user, $password);// 连接到一个本地MySQL服务器$mysql = new PDO("mysql:unix_socket=/tmp/mysql.sock", $user, $password);
登录后复制

譬如:

$dbhost = "localhost";$dbdatabase = "android";$username = "android";$userpass = "android";$dsn='mysql:host='.$dbhost.';dbname='.$dbdatabase;try {    $dbh = new PDO($dsn,$username,$userpass);    foreach($dbh->query('SELECT * from test') as $row) {        print_r($row);    }    // 关闭数据库连接    $dbh = null;} catch (PDOException $e) {    print "Error!: " . $e->getMessage() . "<br/>";    die();}
登录后复制

2. 关闭数据库

$conn = null;
登录后复制

3. 持久化连接

<?php    $dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass, array(PDO::ATTR_PERSISTENT => true));?>
登录后复制

4. 想数据库中插入数据

try {      $dbh->beginTransaction();  $dbh->exec("insert into staff (id, first, last) values (23, 'Joe', 'Bloggs')");  $dbh->exec("insert into salarychange (id, amount, changedate)       values (23, 50000, NOW())");  $dbh->commit();} catch (Exception $e) {  $dbh->rollBack();  echo "Failed: " . $e->getMessage();}
登录后复制

PDO 类的常用方法:

方法名 描述
commit() 提交一个事务。
__construct() 创建一个表示数据库连接的 PDO 实例。
errorInfo() 返回最后一次操作数据库的错误信息。
exec() 执行一条 SQL 语句,并返回受影响的行数。
getAttribute() 取回一个数据库连接的属性。
lastInsertId() 返回最后插入行的ID或序列值。
prepare() 备要执行的SQL语句并返回一个 PDOStatement 对象。
query() 执行 SQL 语句,返回PDOStatement对象,可以理解为结果集。
quote() 为SQL语句中的字符串添加引号。
setAttribute() 设置属性。

PDOStatement的常用方法:

方法名 描述
bindColumn() 绑定一列到一个 PHP 变量。
bindParam() 绑定一个参数到指定的变量名。
bindValue() 把一个值绑定到一个参数。
closeCursor() 关闭游标,使语句能再次被执行。
columnCount() 返回结果集中的列数。
debugDumpParams() 打印一条 SQL 预处理命令。
errorCode() 获取跟上一次语句句柄操作相关的 SQLSTATE。
errorInfo() 获取跟上一次语句句柄操作相关的扩展错误信息。
execute() 执行一条预处理语句。
fetch() 从结果集中获取下一行。
fetchAll() 返回一个包含结果集中所有行的数组。
fetchColumn() 从结果集中的下一行返回单独的一列。
fetchObject() 获取下一行并作为一个对象返回。
getAttribute() 检索一个语句属性。
getColumnMeta() 返回结果集中一列的元数据。
nextRowset() 在一个多行集语句句柄中推进到下一个行集。
rowCount() 返回受上一个 SQL 语句影响的行数。
setAttribute() 设置一个语句属性。
setFetchMode() 为语句设置默认的获取模式。

记录:踩过的一些坑

(1)问题:数据为中文时,在数据库中可以正常显示,但是一在前台调用就出现乱码。

解决:

1)首先检查php文件是否有编码格式声明头文件,如

header('COntent-Type:text/html;charset=utf-8');;如果是html文件则要检查是否有meta声明,如

2)如果php文件的编码格式没问题,那问题可能出现在抓取数据过程中,数据的编码格式有误而导致乱码。可以尝试在数据库查询前插入编码格式的显式定义:$db->query("SET NAMES 'UTF8'");。

原文 http://www.dengzhr.com/others/backend/750
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号