php操作数据库八步走

<?php
// 1、建立连接
$connection = mysqli_connect('127.0.0.1', 'root', ''); // 2、判断连接是否成功
if (mysqli_connect_error() != null) {
die(mysqli_connect_error());
} else {
echo "连接成功!";
} ///3、选择数据库
mysqli_select_db($connection, 'test'); ///4、设置字符集
mysqli_set_charset($connection, 'utf8'); ///5、书写 SQL 语句
$sql = "SELECT * FROM `user` LIMIT 1"; ///6、执行 SQL 语句
$result = mysqli_query($connection, $sql); ///7、解析结果集
$array = mysqli_fetch_array($result, MYSQLI_BOTH); ///8、关闭连接
mysqli_close($connection);

添加、更新、删除数据

<?php
// 连接数据库
$link = mysqli_connect('127.0.0.1', 'root', ''); // 判断数据库连接是否成功
if (!is_null(mysqli_connect_error())) {
die(mysqli_connect_error());
} // 选择数据库
mysqli_select_db($link, 'test'); // 设置连接字符集
mysqli_set_charset($link, 'utf8'); // 书写 SQL 语句
// $sql = "INSERT INTO `user` (`username`, `password`) VALUES('user-5', 'password-5')";//增加数据
// $sql = "UPDATE user SET password='password' WHERE id > 4";//修改数据
$sql = "DELETE FROM user WHERE id > 4";//删除数据 // 执行 SQL 语句
$result = mysqli_query($link, $sql); // 解析 SQL 语句执行结果
if ($result) {
echo "执行成功!"
. " 成功删除了数据 " . mysqli_affected_rows($link) . " 条!";
// . " 插入数据的 ID 是 " . mysqli_insert_id($link) . "。";
} else {
echo "执行失败!";
} // 关闭连接,释放资源
mysqli_close($link);

简单查询和数据解析

<?php
// 建立连接
$link = mysqli_connect('127.0.0.1', 'root', ''); // 判断连接是否成功
if (mysqli_connect_error() != null) {
die(mysqli_connect_error());
} // 选择数据库
mysqli_select_db($link, 'test'); // 设置字符集
mysqli_set_charset($link, 'utf8'); // 书写 SQL 语句
$sql = "SELECT good, class, price, stock FROM good WHERE id < 4"; // 执行 SQL 语句
$result = mysqli_query($link, $sql); // 解析结果集
echo "<pre>";
$data = mysqli_fetch_array($result);
var_dump($data); while ($row = mysqli_fetch_array($result, MYSQLI_BOTH)) {
var_dump($row);//使用或输出所有查询的数据
} while ($row = mysqli_fetch_row($result)) {
var_dump($row);//把查询结果返回到一个数组中,用数字索引取值
} while ($row = mysqli_fetch_assoc($result)) {
var_dump($row);//把查询结果返回到一个数组中,用关键字索引取值
} while ($row = mysqli_fetch_object($result)) {
var_dump($row);//从结果集中取得当前行,并作为对象返回
} $data = mysqli_fetch_all($result, MYSQLI_BOTH);//从结果集中取得所有行作为关联数组
var_dump($data); $num = mysqli_num_rows($result);
echo "共查询到 " . $num . " 条数据!";
$num = mysqli_num_fields($result);
echo "共查询到 " . $num . " 列数据!"; // 关闭连接
mysqli_close($link);

复杂查询

<?php
// 建立连接
$link = mysqli_connect('127.0.0.1', 'root', ''); // 判断连接是否成功
if (mysqli_connect_error() != null) {
die(mysqli_connect_error());
} // 选择数据库
mysqli_select_db($link, 'test'); // 设置字符集
mysqli_set_charset($link, 'utf8'); // 书写 SQL 语句
$sql = "SELECT good.*, class.class FROM good, class WHERE good.class = class.id AND good.stock >= 25 AND good.price <= 50 AND good.class = 4 ORDER BY good.price ASC LIMIT 6"; // 执行 SQL 语句
$result = mysqli_query($link, $sql); // 解析结果集
echo "<table border=''>";
echo "<tr>";
echo "<th>ID</th>";
echo "<th>商品</th>";
echo "<th>类别</th>";
echo "<th>单价</th>";
echo "<th>库存</th>";
echo "<th>更新时间</th>";
echo "<th>创建时间</th>";
echo "</tr>";
while ($row = mysqli_fetch_assoc($result)) {
echo "<tr>";
echo "<td width='100px'>" . $row['id'] . "</td>";
echo "<td width='100px'>" . $row['good'] . "</td>";
echo "<td width='100px'>" . $row['class'] . "</td>";
echo "<td width='100px'>" . $row['price'] . "</td>";
echo "<td width='100px'>" . $row['stock'] . "</td>";
echo "<td width='100px'>" . $row['updated_at'] . "</td>";
echo "<td width='100px'>" . $row['created_at'] . "</td>";
echo "</tr>";
}
echo "</table>"; // 关闭连接
mysqli_close($link);

程序错误排查

<?php
// 建立连接
$link = mysqli_connect('127.0.0.1', 'root', ''); // 判断连接是否成功
if (mysqli_connect_error() != null) {
die(mysqli_connect_error());
} // 选择数据库
mysqli_select_db($link, 'test'); // 设置字符集
mysqli_set_charset($link, 'utf8'); // 书写 SQL 语句
// $sql = "SELECT * FROM good ORDER BY price ASC GROUP BY class";
$sql = "INSERT INTO good (good, class, price, stock) VALUES('test', 'test', 20, 56)";
// $sql = "INSERT INTO class(class) VALUES('水果')"; // 执行 SQL 语句
$result = mysqli_query($link, $sql); // 解析结果集
// var_dump($result);
$error = mysqli_error($link);
$errno = mysqli_errno($link); echo "SQL 语句执行失败!错误代码:" . $errno . ",错误信息:" . $error; // 关闭连接
mysqli_close($link);

php操作mysql(数据库常规操作)的更多相关文章

  1. Python学习(21)python操作mysql数据库_操作

    目录 数据库连接 创建数据库表 数据库插入操作 数据库查询操作 数据库更新操作 删除操作 执行事务 错误处理 数据库连接 连接数据库前,请先确认以下事项: 您已经创建了数据库 TEST. 在TEST数 ...

  2. Mysql数据库常规操作(建表、查询)

    一.表单操作 1-1.创建表 create table tb_name( id in primary key auto_increment);    1-2.查看表 desc table_name; ...

  3. python操作mysql数据库系列-操作MySql数据库(二)

    接口测试框架层级目录结构示意图: page目录下面的mysqlTest.py:存放的是mysql的操作代码 utils目录下面的helper.py:存放的是公共的配置方法 log目录log.md:存放 ...

  4. 【tips】ORM - SQLAlchemy操作MySQL数据库

    优先(官方文档SQLAlchemy-version1.2): sqlalchemy | 作者:斯芬克斯 推荐一(长篇幅version1.2.0b3):python约会之ORM-sqlalchemy | ...

  5. Python操作Mysql数据库时SQL语句的格式问题

    一.概述 近日使用Python对Mysql数据库进行操作,遇到SQL语句死活出问题的情况.由于最初没有将异常打印出来,一直不知道原因.随后,将异常打印出来之后,通过异常信息,对代码进行修改.最终,成功 ...

  6. PHP操作MySQL数据库5个步骤

    PHP操作MySQL数据库一般可分为5个步骤:1.连接MySQL数据库服务器:2.选择数据库:3.执行SQL语句:4.关闭结果集:5断开与MySQL数据库服务器连接. 1.用mysql_connect ...

  7. python操作mysql数据库的相关操作实例

    python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...

  8. zabbix数据库mariadb从服务器迁移到云mysql数据库的操作

    zabbix数据库mariadb从本机迁移到云mysql数据库的操作 1.将zabbix数据库导出,并导入到云数据库中 由于数据库较大,如果直接使用shell会话中断会导致数据库导出或者导入失败,使用 ...

  9. 转 用C API 操作MySQL数据库

    用C API 操作MySQL数据库 参考MYSQL的帮助文档整理 这里归纳了C API可使用的函数,并在下一节详细介绍了它们.请参见25.2.3节,“C API函数描述”. 函数 描述 mysql_a ...

  10. PHP操作mysql数据库:[2]查询数据听语音

    本文主要详细讲解如何使用php语言,对mysql数据库进行查询.添加.删除.更新等操作. 工具/原料   Macromedia Dreamweaver 8 mysql数据库,php语言 一.前言   ...

随机推荐

  1. 数据库及ORM之Mysql

    1. 数据库介绍 1.1什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数据库都有一个或多个不同的API用于创建,访问,管理,搜索和复制所保存的数据.我们也可 ...

  2. Java基于OpenCV实现走迷宫(图片+路线展示)

    Java基于OpenCV实现走迷宫(图片+路线展示) 由于疫情,待在家中,太过无聊.同学发了我张迷宫图片,让我走迷宫来缓解暴躁,于是乎就码了一个程序出来.特此记录. 原图: 这张图,由于不是非常清晰, ...

  3. Codeforces Round #617 (Div. 3)F. Berland Beauty

    题意: 给一棵树,边权未知,现在给m组约束,每组约束给出从u到v路径中的最小值,现在让你给出一组边权,使得符合之前的约束,不能给出输出-1 思路: 因为n较小,对于每组约束我们可以直接暴力修改路径上的 ...

  4. mysqldump 备份与恢复操作记录

     一,参数详解 [root@bug ~]# ? mysqldump --master-data[=#] mysqldump导出数据时,当这个参数的值为1的时候,mysqldump出来的文件就会包括CH ...

  5. 机器学习-NLP之Word embedding 原理及应用

    概述 自然语言是非常复杂多变的,计算机也不认识咱们的语言,那么咱们如何让咱们的计算机学习咱们的语言呢?首先肯定得对咱们的所有文字进行编码吧,那咱们很多小伙伴肯定立马就想出了这还不简单嘛,咱们的计算机不 ...

  6. 《ASP.NET Core 高性能系列》环境(EnvironmentName)的设置

    一.概述 程序启动时Host捕获到环境相关数据,然后交由IEnvironment(传说要作废,但是觉得这个有设计点问题,因为.NET Core 非Web怎么处理?),然后交由IWebHostEnvir ...

  7. JSP&Servlet学习笔记----第3章

    Web容器是JSP/Servlet唯一认识的HTTP服务器. HTTP是基于请求/响应的无状态通信协议. 流程: 1.请求来到HTTP服务器 2.HTTP服务器将请求转交给Web容器 3.Web容器创 ...

  8. Android Webview实现有道电子词典

    毕业设计android电子词典,先实现的一个小小的demo. 所谓的毕业设计就是用最短的时间学习一门语言,做出一个小的project. activity_main.xml <LinearLayo ...

  9. MingGW Posix VS Win32 - 明瓜娃的毒因

    MinGW-posix和win32纠缠的瓜娃子 官方首席佛偈(SourceForge)的官网下载页 法克油啊,让我一个小白情何以堪. 盘TA wiki posix wiki中文-UNIX API标准 ...

  10. mybatis缓存问题导致无法查询到数据

    今天查询记录时,发现重复查询结果时出现空记录的情况 查看控制台信息,只有红色框选部分有进行查询数据,而其他没有.然而上图可看出有两条数据是能展现出来的,故有可能是mybatis缓存命中的. 因此在ma ...