PHP+MariaDB数据库操作基本技巧备忘总结


Posted in PHP onMay 21, 2018

本文实例总结了PHP+MariaDB数据库操作基本技巧。分享给大家供大家参考,具体如下:

PHP+MySQL是比较常见的搭配,由于我主观上不太喜欢Oracle,而MySQL被它收购后,骨子里也发生了一些变化,因此我更换了MariaDB,仍然坚持MySQL当初开源信念的亲兄弟。本质上都是MySQL的内核,因此下面所有的数据库操作代码,都是可以直接在MySQL使用的。

晚上搭好PHP+Apache的基础环境,以及安装好MySQL数据库后,写了一个最简单的数据库连接代码,结果报了如下经典错误:Fatal error: Class 'mysqli' not found

<?php
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
?>

其实这问题比较简单,从PHP引擎返回的错误就知道mysqli没有被正确的加载,绝大多数的问题都发生在php.ini文件的配置中,“extension=php_mysqli.dll”这个配置项前面默认的分号没有去掉。这个错误我倒没有犯,php安装路径中的ext目录中,也有php_mysqli.dll这个文件,那问题发生在哪里呢?问题应该还是发生在php.ini文件中哪个地方写错了。走读后发现“extension_dir = "ext"”个地方没有修改。我当时脑子没多想,觉得PHP引擎是能够自动找到这个相对路径的。但后来想想,PHP引擎是被Apache加载的,Apache可不知道这个相对关系。还是老老实实的把这个地方改成了绝对路径,OK了。其实可以在这个代码之前,先写这么一段代码,看看mysqli组件是否已经被加载了,这个方法适用于其他组件的加载前的判断。

if (extension_loaded('mysqli'))
{
  echo 'yes';
}
else
{
  echo 'no';
}

下面用一个用户注册和系统登录记录PHP+MySQL的最基本操作方法。

1、创建数据库、表和用户。

DROP DATABASE IF EXISTS `test`;
CREATE DATABASE `test`
USE `test`;
DROP TABLE IF EXISTS `tbl_user`;
CREATE TABLE `tbl_user` (
 `username` varchar(32) NOT NULL default '',
 `password` varchar(32) NOT NULL default '',
 PRIMARY KEY (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312;

2、创建注册和登录的html页面,分别是register.html和login.html。如下图所示:

PHP+MariaDB数据库操作基本技巧备忘总结 PHP+MariaDB数据库操作基本技巧备忘总结

3、注册和登录的代码:

register_do.php

<?php
  $username = $_POST['username'];
  $password = $_POST['password'];
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
  $query = "select * from tbl_user where username = '" . $username . "'";
  echo '<p>' . $query;
  $result = $db->query($query);
  if ($result)
  {
    echo '<p>' . 'The user '. $username .' exist';
    echo '<p>' . '<a href="register.html" rel="external nofollow" rel="external nofollow" >Back to register</a>';
  }
  else
  {
    $query = "insert into tbl_user values ('". $username ."', '". $password ."')";
    echo '<p>' . $query;
    $result = $db->query($query);
    if ($result)
    {
      echo '<p>' . '<a href="register.html" rel="external nofollow" rel="external nofollow" >Register successful</a>';
    }
  }
?>

login_do.php

<?php
  $username = $_POST['username'];
  $password = $_POST['password'];
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
  $query = "select * from tbl_user where username = '" . $username . "' and password = '" . $password . "'";
  echo '<p>' . $query;
  $result = $db->query($query);
  if ($result->num_rows)
  {
    echo '<p>' . '<a href="login.html" rel="external nofollow" rel="external nofollow" >Login successful</a>';
  }
  else
  {
    echo '<p>' . '<a href="login.html" rel="external nofollow" rel="external nofollow" >Login failed</a>';
  }
?>

userlist.php

<?php
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
  echo '<p>' . 'All user as follows:';
  $query = "select * from tbl_user order by username";
  if ($result = $db->query($query))
  {
    while ($row = $result->fetch_assoc())
    {
      echo '<p>' . 'Username : ' . $row['username'] . '  <a href="userdelete.php?username=' . $row['username'] . '" rel="external nofollow" >delete</a>';
    }
  }
?>

4、该页面最终的显示效果如下图所示:

PHP+MariaDB数据库操作基本技巧备忘总结

5、删除用户的代码:

userdelete.php

<?php
  $username = $_GET['username'];
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
  $query = "delete from tbl_user where username = '" . $username . "'";
  echo $query;
  if ($result = $db->query($query))
  {
    echo '<p>' . 'Delete user ' . $username . ' successful';
  }
  else
  {
    echo '<p>' . 'Delete user ' . $username . ' failed';
  }
  echo '<p>' . '<a href="userlist.php" rel="external nofollow" >Back to user list</a>';
?>

Prepare预处理

1、图书添加的页面如下图所示(bookadd.html):

PHP+MariaDB数据库操作基本技巧备忘总结

2、建表脚本如下:

DROP DATABASE IF EXISTS `test`;
CREATE DATABASE IF NOT EXISTS `test`;
USE `test`;
DROP TABLE IF EXISTS `tbl_book`;
CREATE TABLE IF NOT EXISTS `tbl_book` (
 `isbn` varchar(32) NOT NULL,
 `title` varchar(32) NOT NULL,
 `author` varchar(32) NOT NULL,
 `price` float NOT NULL,
 PRIMARY KEY (`isbn`)
) ENGINE=InnoDB DEFAULT CHARSET=utf-8;

3、添加的逻辑处理代码如下(bookadd_do.php):这里特别要注意的是这句话“$db->query("set names utf-8")”,代表向数据库写入数据时,采用utf-8编解码,显示的对数据库表操作的编解码进行设置,以防止中文的乱码。后面我会专门针对这个技术点记录一篇文章。

<?php
  $isbn = $_POST['isbn'];
  $title = $_POST['title'];
  $author = $_POST['author'];
  $price = $_POST['price'];
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
  $db->query("set names utf-8"); //特别注意这句话
  $stmt = $db->stmt_init();
  $stmt->prepare("insert into tbl_book values (?,?,?,?)");
  $stmt->bind_param("sssd", $isbn, $title, $author, $price);
  $stmt->execute();
  echo '<p>' . 'Affect rows is ' . $stmt->affected_rows;
  echo '<p>' . '<a href="booklist.php" rel="external nofollow" >Go to book list page</a>';
?>

4、显示图书信息的逻辑代码如下,同样注意这句话“$db->query("set names utf-8")”:

<?php
  $db = new mysqli('localhost', 'root', 'admin', 'test');
  if (mysqli_connect_errno())
  {
    echo '<p>' . 'Connect DB error';
    exit;
  }
  $db->query("set names utf-8"); //特别注意这句话
  $stmt = $db->stmt_init();
  $stmt->prepare("select * from tbl_book");
  $stmt->bind_result($isbn, $title, $author, $price);
  $stmt->execute();
  while($stmt->fetch())
  {
    echo 'ISBN : ' . $isbn . '<p>';
    echo 'Title : ' . $title . '<p>';
    echo 'Author : ' . $author . '<p>';
    echo 'Price : ' . $price . '<p>';
    echo '<p>' . '-----------------------------' . '<p>';
  }
?>

5、显示的页面如下图所示:

PHP+MariaDB数据库操作基本技巧备忘总结

好了,最基础的部分就记录到这,PHP引擎提供了很方便的数据库操作方法,但正是开发绝不是如此简单,各种异常要仔细考虑如何捕获,如何处理。数据库的设计也是一个挺好玩的话题。

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
浅谈Windows下 PHP4.0与oracle 8的连接设置
Oct 09 PHP
提升PHP执行速度全攻略(下)
Oct 09 PHP
台湾中原大学php教程孙仲岳主讲
Jan 07 PHP
解析centos中Apache、php、mysql 默认安装路径
Jun 25 PHP
thinkphp模板的包含与渲染实例分析
Nov 26 PHP
PHP缓冲区用法总结
Feb 14 PHP
详解WordPress中的头像缓存和代理中的缓存更新方法
Mar 01 PHP
php插件Xajax使用方法详解
Aug 31 PHP
如何通过View::first使用Laravel Blade的动态模板详解
Sep 21 PHP
php和C#的yield迭代器实现方法对比分析
Jul 17 PHP
Laravel第三方包报class not found的解决方法
Oct 13 PHP
TP - 比RBAC更好的权限认证方式(Auth类认证)
Mar 09 PHP
PhpStorm本地断点调试的方法步骤
May 21 #PHP
PHP自动识别当前使用移动终端
May 21 #PHP
PHP连接MySQL数据库并以json格式输出
May 21 #PHP
PHP 访问数据库配置通用方法(json)
May 20 #PHP
PHP生成腾讯云COS接口需要的请求签名
May 20 #PHP
windows环境下使用Composer安装ThinkPHP5
May 18 #PHP
PHP实现登录验证码校验功能
May 17 #PHP
You might like
Windows下IIS6/Apache2.2.4+MySQL5.2+PHP5.2.1安装配置方法
2007/05/03 PHP
php循环创建目录示例分享(php创建多级目录)
2014/03/04 PHP
调试WordPress中定时任务的相关PHP脚本示例
2015/12/10 PHP
PHP基于堆栈实现的高级计算器功能示例
2017/09/15 PHP
PHP使用 Imagick 扩展实现图片合成,圆角处理功能示例
2019/09/09 PHP
JavaScript函数详解
2014/11/17 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
JavaScript错误处理
2015/02/03 Javascript
简介JavaScript中POSITIVE_INFINITY值的使用
2015/06/05 Javascript
详解js跨域原理以及2种解决方案
2015/12/09 Javascript
JavaScript实现简单Tip提示框效果
2016/04/20 Javascript
jQuery实现区域打印功能代码详解
2016/06/17 Javascript
Bootstrap基本插件学习笔记之折叠(22)
2016/12/08 Javascript
走进javascript——不起眼的基础,值和分号
2017/02/24 Javascript
详解AngularJS跨页面传值(ui-router)
2017/08/23 Javascript
原生javascript实现文件异步上传的实例讲解
2017/10/26 Javascript
详解vue mixins和extends的巧妙用法
2017/12/20 Javascript
vue element动态渲染、移除表单并添加验证的实现
2019/01/16 Javascript
Vue加载json文件的方法简单示例
2019/01/28 Javascript
Vue项目中使用WebUploader实现文件上传的方法
2019/07/21 Javascript
浅谈element中InfiniteScroll按需引入的一点注意事项
2020/06/05 Javascript
全面解析js中的原型,原型对象,原型链
2021/01/25 Javascript
[02:30]DOTA2英雄基础教程 暗影恶魔
2013/12/17 DOTA
Python实现快速排序和插入排序算法及自定义排序的示例
2016/02/16 Python
python实现数据导出到excel的示例--普通格式
2018/05/03 Python
Python退火算法在高次方程的应用
2018/07/26 Python
python实现梯度下降算法
2020/03/24 Python
Django Admin后台模型列表页面如何添加自定义操作按钮
2020/11/11 Python
美国最大的城市服装和运动鞋零售商:Jimmy Jazz
2016/11/19 全球购物
不假外出检讨书
2014/01/27 职场文书
股东合作协议书范本
2014/04/14 职场文书
团日活动总结范文
2014/04/25 职场文书
经贸日语专业个人求职信范文
2014/04/29 职场文书
2015年信息宣传工作总结
2015/05/26 职场文书
同学聚会感言一句话
2015/07/30 职场文书
Nginx 负载均衡是什么以及该如何配置
2021/03/31 Servers