php学习笔记-连接操作mysq数据库(基础)-day08

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 本文介绍了PHP中连接操作MySQL数据库的常用函数,包括连接服务器、设置字符集、关闭连接、选择数据库、结果集释放、获取影响行数以及遍历结果集等操作。通过书籍查询的实例演示了如何使用这些函数进行数据库操作,并提供了一个PHP操纵MySQL数据库的模板。

php中常用的mysql操作函数

首先,放一段链接 https://www.php.net/manual/zh/function.mysql-connect,mysql_connect及其诸多函数已经自php5.5.0废弃,然后逐步移除中,使用 mysqli 或者 pdo_mysql中的函数来替代。
在这里插入图片描述

1.连接mysql服务器

mysqli_connect()

语法格式:mysqli_connect ( string hostname,string username, string password,string database,int port,string socket): mysqli | false
函数功能:如果成功链接mysql服务器,则返回一个与mysql服务器连接的标识 mysqli ,如果连接失败则返回 false。

在这里插入代码片

2.设置数据库字符集 和 发送sql

mysqli_query() 函数 可以用来设置数据库字符集。

语法格式:mysqli_query(mysqli $mysqli,string "set names 字符集"); (字符集是 gbk | utf8 )
函数功能:将mysql的字符集设置为指定的字符集。

tip:mysqli_query() 函数 完整的参数如下:
mysqli_query(mysqli $mysql, string $query, int $result_mode = MYSQLI_STORE_RESULT): mysqli_result | bool
query 可以是设定字符集或者相应的sql语句(如:select sid from student | insert into xxx.... | update xxxx set.... | delete from ..... ),如果执行的查询sql成功,则返回一个结果集 mysqli_result。

3.关闭mysql服务器连接

mysqli_close();

语法格式:bool mysqli_close(mysqli $mysqli )
函数功能:关闭mysql服务器连接

4.选择要操作的数据库

mysqli_select_db()

语法格式:bool mysqli_select_db( mysqli $mysqli , string database_name)
函数功能:设置当前想要操纵的数据库

5.结果集释放

mysqli_free_result()

语法格式:mysqli_free_result ( mysqli_result $result)
函数功能:释放结果集所占用的资源,执行成功返回true,失败返回false.

6.获取sql执行后影响的表记录行数

mysqli_affected_rows()

语法格式:mysqli_affected_rows(mysqli $mysql): int|string
函数功能:获取上一个 MySQL 操作中受影响的行数

mysql_insert_id()

语法格式:mysql_insert_id(resource $link_identifier = ?): int
函数功能:取得上一步 INSERT 操作产生的 ID

mysql_insert_id() 返回给定的 link_identifier 中上一步 INSERT 查询中产生的 AUTO_INCREMENT 的 ID 号。如果没有指定 link_identifier,则使用上一个打开的连接。

如果上一查询没有产生 AUTO_INCREMENT 的值,则 mysql_insert_id() 返回 0。如果需要保存该值以后使用,要确保在产生了值的查询之后立即调用 mysql_insert_id()。

7.遍历结果集中的数据

mysqli_fetch_row ( )

语法格式:mysql_fetch_row(resource $result): array
函数功能:返回根据所取得的行生成的数组,如果没有更多行则返回 false。
mysql_fetch_row() 从和指定的结果标识关联的结果集中取得一行数据并作为数组返回。每个结果的列储存在一个数组的单元中,偏移量从 0 开始。
依次调用 mysql_fetch_row() 将返回结果集中的下一行,如果没有更多行则返回 false。

mysqli_fetch_array ()

语法格式:mysql_fetch_array(resource $result, int $result_type = ?): array
函数功能:从结果集中取得一行作为关联数组
参数:
resource 型的结果集。此结果集来自对 msql_query() 的调用。

result_type
接受以下常量值: MSQL_ASSOC,MSQL_NUM 和 MSQL_BOTH,默认为 MSQL_BOTH。如果用了 MYSQL_BOTH,将得到一个同时包含关联和数字索引的数组。用 MYSQL_ASSOC 只得到关联索引(如同 mysql_fetch_assoc() 那样),用 MYSQL_NUM 只得到数字索引(如同 mysql_fetch_row() 那样)。

小练习

书籍查询并且输出结果集数据

创建数据表

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for book
-- ----------------------------
DROP TABLE IF EXISTS `book`;
CREATE TABLE `book`  (
  `id` int(0) NOT NULL AUTO_INCREMENT,
  `bookName` varchar(20) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci NOT NULL,
  `bookPrice` decimal(10, 2) NOT NULL,
  `author` varchar(30) CHARACTER SET utf8mb3 COLLATE utf8mb3_general_ci NOT NULL,
  PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8mb3 COLLATE = utf8mb3_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of book
-- ----------------------------
INSERT INTO `book` VALUES (1, '平凡的世界', 59.00, '路遥');
INSERT INTO `book` VALUES (2, '三体', 99.00, '刘慈欣');
INSERT INTO `book` VALUES (3, '人间失格', 44.00, '太宰治');
INSERT INTO `book` VALUES (4, '白夜行', 38.00, '东野圭吾');

SET FOREIGN_KEY_CHECKS = 1;

创建testDB.php

用来连接数据库和执行sql,以及数据显示输出

<?php

// php 连接 mysql

// 1.resource mysql_connect (string hostname,string username,string password)

// 连接成功则返回一个连接标识,连接失败则返回一个 false

$hostname = "localhost"; // mysql服务器名
$username = "root"; // 账号
$password = "root"; // 密码

// 连接数据库
$conn = @mysqli_connect($hostname,$username,$password,) or die("连接数据库失败");

// 编写sql 通过sql指定要访问的数据库和表
$sql1 = "select * from phpdemo.book";

// 设定编码
mysqli_query($conn,"set names utf-8");
// 操纵数据库,查询一下信息
$rs = mysqli_query($conn,$sql1);


// 将结果集抽离出来,使用最常用的表格


echo "<table>";
echo "<tr><th>id</th><th>书名</th><th>价格</th><th>作者</th></tr>";
while ($row = mysqli_fetch_array($rs)){
   
    echo "<tr>".
            "<td>".$row['id']."</td>".
            "<td>".$row['bookName']."</td>".
            "<td>".$row['bookPrice']."</td>".
            "<td>".$row['author']."</td>".
        "</tr>";
}
echo "</table>";
// 释放结果集内存
mysqli_free_result($rs);



// 关闭数据库连接
mysqli_close($conn);

在这里插入图片描述

mysql连接模板

// php操纵mysql数据库的模板
class dataBase{
   

    public $dbConn = null;

     function getConnection()
    {
   

        $hostname = "localhost";
        $username = "root";
        $password = "root";
        $database = "phpdemo";
        global $dbConn;

        if(mysqli_connect($hostname,$username,$password)){
   
            $dbConn = mysqli_connect($hostname,$username,$password);
        }else{
   
            echo "数据库连接失败,请检查主机名,用户名,密码";
            die(mysqli_error());
        }
        mysqli_query($dbConn,"set names utf-8");// 设定字符集编码
        if(mysqli_select_db($dbConn,$database)){
   
            echo "连接成功";
        }else{
   
            echo "连接失败,检查数据库名是否正常";
            die(mysqli_error());
        }
    }


    function closeConnection():void
    {
   
        global  $dbConn;
        if($dbConn){
   
            mysqli_close($dbConn) or die (mysqli_error($dbConn));
        }
    }
}

tip:“这里对php中的类还没有详细的学过,所以模板还可能有不足的地方”


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
27天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
105 6
|
26天前
|
存储 SQL 关系型数据库
PHP与数据库交互:从基础到进阶
【10月更文挑战第9天】在编程的世界里,数据是流动的血液,而数据库则是存储这些珍贵资源的心脏。PHP作为一门流行的服务器端脚本语言,其与数据库的交互能力至关重要。本文将带你从PHP与数据库的基本连接开始,逐步深入到复杂查询的编写和优化,以及如何使用PHP处理数据库结果。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供宝贵的知识和技巧,让你在PHP和数据库交互的道路上更加从容不迫。
|
13天前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
113 68
|
27天前
|
SQL Ubuntu 关系型数据库
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
本文为MySQL学习笔记,介绍了数据库的基本概念,包括行、列、主键等,并解释了C/S和B/S架构以及SQL语言的分类。接着,指导如何在Windows和Ubuntu系统上安装MySQL,并提供了启动、停止和重启服务的命令。文章还涵盖了Navicat的使用,包括安装、登录和新建表格等步骤。最后,介绍了MySQL中的数据类型和字段约束,如主键、外键、非空和唯一等。
64 3
Mysql学习笔记(一):数据库详细介绍以及Navicat简单使用
|
9天前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
22 3
|
16天前
|
关系型数据库 MySQL 数据库连接
DBeaver如何连接一个数据库
【10月更文挑战第27天】DBeaver 是一款功能强大的通用数据库管理工具,支持多种主流数据库。本文介绍了使用 DBeaver 连接数据库的基本步骤,包括下载安装、创建新连接、选择数据库类型、配置连接参数、测试连接以及最终连接到数据库。详细的操作指南帮助用户轻松管理和操作数据库。
74 9
|
9天前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
13 1
|
9天前
|
Java 数据库连接 数据库
Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销
本文深入探讨了Java连接池在数据库性能优化中的重要作用。连接池通过预先创建和管理数据库连接,避免了频繁创建和关闭连接的开销,显著提升了系统的响应速度和吞吐量。文章介绍了连接池的工作原理,并以HikariCP为例,展示了如何在Java应用中使用连接池。通过合理配置和优化,连接池技术能够有效提升应用性能。
24 1
|
18天前
|
SQL JavaScript 关系型数据库
node博客小项目:接口开发、连接mysql数据库
【10月更文挑战第14天】node博客小项目:接口开发、连接mysql数据库
|
27天前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
44 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库