【PHP】MySQL简介与MySQLi函数(含PHP与MySQL交互)

文章目录

  • 一、MySQL简介
  • 二、MySQLi函数
    • 1. 开启mysqli扩展:
    • 2. PHP MySQLi扩展的常用函数
  • 三、PHP与MySQL交互
    • 0. 准备
    • 1. 创建连接(mysqli_connect() )
      • 连接mysql语法
    • 2. 选择数据库(mysqli_select_db())
    • 3. 在php中操作数据库执行语句
      • 1. 读取.sql文件
      • 2. 操作数据库
    • 4. 连接例子:
  • 四、扩展知识
    • mysqli不能使用localhost的解决办法

一、MySQL简介

MySQL是由瑞典MySQL AB公司(先后被Sun和Oracle公司收购)开发的关系型数据库管理系统,支持UNIX,Linux,macOS和Windows等平台上使用。MySQL数据库的默认端口号为3306。

优点:体积小,速度快,使用更加方便快捷,且开源。

特点:

  1. 跨平台性
  2. 可靠性
  3. 适用性
  4. 开源免费

注意:mysql数据库操作时,为了避免用户自定义的数据库名称、字段名称或数据表名称与系统命令冲突,最好使用反引号(`)包裹这些名称。

二、MySQLi函数

PHP作为一门编程语言,本身并不具备操作数据库的功能。所以,若想要在项目开发中完成PHP应用和MySQL数据库之间交互,就需要借助PHP提供的数据库扩展。PHP提供了许多数据库扩展,比较常用的有MySQL扩展、MySQLi扩展和PHP数据对象(PHP Data Objects, PDO)扩展。而PHP MySQLi(PHP MySQL Improved)可以连接MySQL数据库服务器。

注:MySQLi 扩展被设计用于 MySQL 4.1.13 版本或更新的版本。

在使用 MySQLi 函数之前,必须打开 MySQLi 扩展。

1. 开启mysqli扩展:

  1. 检查php的ext文件夹下面看是否有php_mysqli.dll文件

  2. 打开php安装目录下的配置文件:php.ini
    在这里插入图片描述

  3. 找到mysqli扩展

    ;extension=mysqli.dll
    

    在这里插入图片描述

  4. 将分号删掉,并保存
    在这里插入图片描述

  5. 重启apache服务器即可。

2. PHP MySQLi扩展的常用函数

函数描述
mysqli_connect()连接MySQL服务器
mysqli_connect_error()获取连接服务器时的错误信息
mysqli_select_db()选择数据库
mysqli_set_charset()设置客户端字符集
mysqli_query()执行SQL语句,写操作返回true或false,读操作返回结果集对象
mysqli_insert_id()获取上一次插入操作时产生的ID
mysqli_affected_rows()获取上一次操作时受影响的行数
mysqli_errno()返回上一个MySQL操作中的错误信息的错误码
mysqli_error()返回上一个MySQL操作中的错误信息
mysqli_close()关闭数据库连接

三、PHP与MySQL交互

PHP 通过内置函数库 mysqli 进行 MySQL 数据库编程的步骤如下:

  1. 建立与 MySQL 数据服务器的连接(使用 mysqli_connect() 函数);
  2. 选择要进行操作的数据库(使用 mysqli_select_db() 函数);
  3. 执行数据库的操作,如数据的添加删除等(使用 mysqli_query() 函数);
  4. 关闭与 MySQL 数据库服务器进行的连接(使用 mysqli_close() 函数);

0. 准备

前提:apache、mysql、php安装好了,且配置成功。(或者直接使用集成环境WampServer)

开启mysqli扩展:

  1. 检查php的ext文件夹下面看是否有php_mysqli.dll文件

  2. 打开php安装目录下的配置文件:php.ini
    在这里插入图片描述

  3. 找到mysqli扩展

    ;extension=mysqli.dll
    

    在这里插入图片描述

  4. 将分号删掉,并保存
    在这里插入图片描述

  5. 重启apache服务器
    在这里插入图片描述

1. 创建连接(mysqli_connect() )

连接mysql语法

PHP 可以通过 mysqli 接口来连接 MySQL 数据库服务器。mysqli 接口提供了mysqli_connect()函数进行连接。语法格式如下:

$con = mysqli_connect("host_name", "user_name", "password", "mysqldb_name", "port"); // 连接mysql数据库
  • @ 隐藏错误

  • die() 条件显示

  • mysqli_connect_error() 获取连接数据库的错误信息

  • mysqli_connect_errno() 获取连接数据库的错误编码

  • mysqli_set_charset(连接对象,字符编码)

    说明:

    1. host_name:主机名或者主机的 IP 地址,本章中默认的主机名为“localhost:3306”。
    2. user_name:用于登录 MySQL 服务器的用户名,默认值为 root。
    3. pass_word:用户登录口令,默认值为空。
    4. mysqldb_name:数据库名
    5. port:端口号,如果端口号是3306可省略

上述语句通过 mysqli_connect()函数连接 MySQL 数据库服务器并把此连接生成的对象传递给名为$con 的变量。在默认情况下 MySQL 服务器的端口号为 3306,如果采用默认端口号,则可以不指定。如果采用了其他端口号,则要特别指出,如 localhsot:3307。

mysqli_connect( )若成功执行,则返回一个资源句柄型(连接标识号),否者返回逻辑值 FALSE。mysqli_connect( )函数将返回值存放在一个变量中,在其他地方直接引用该变量即可。

2. 选择数据库(mysqli_select_db())

语法格式:

mysqli_select_db(数据库服务器连接对象, "数据库名")

如:

mysqli_select_db($conn, "book")

数据库服务器连接对象或连资源句柄型用于指定相应的与 MySQL 数据库服务器相连的连接标识号,数据库名为指定需要连接的数据库名称。

3. 在php中操作数据库执行语句

1. 读取.sql文件

使用PHP的file_get_contents函数读取要导入的 .sql文件,并将其保存在变量中。

<?php
sql_file = "database.sql"; //.sql文件路径sql_content = file_get_contents($sql_file); //读取.sql文件中的内容
?>

2. 操作数据库

执行语句模板为:

$变量名 = 'mysql执行语句';
mysqli_query($连接名, $变量名);

举例:

$sql = 'create database test';
mysqli_query($conn, $sql);  // 数据库执行上面语句

在这里插入图片描述

4. 连接例子:

例1:

<?php$conn=mysqli_connect("localhost","wrong_user","my_password","my_db");// 检查连接if (!$conn){die("连接错误: " . mysqli_connect_error());}
?>

例2:

<?phpheader("Content-Type: text/html; charset=utf-8"); // 避免中文乱码echo "你好";echo "<br>";$conn = mysqli_connect("localhost:3306", "root", "");var_dump($conn);echo "<br>";if(!mysqli_select_db($conn, "book")){  // 如果连接“book”库失败echo "连接失败<-_->".mysqli_connect_error(); // 显示连接失败信息exit;}else{echo "连接成功"; // 显示连接成功}
?>

浏览器输出结果:

在这里插入图片描述

数据放在mysql安装目录下的data目录下。

四、扩展知识

mysqli不能使用localhost的解决办法

使用mysqli_connect()连接时,当主机填写为localhost时,MySQL会采用 unix domain socket连接,当主机填写为127.0.0.1时MySQL会采用TCP/IP的方式连接。使用Unix socket的连接比TCP/IP的连接更加快速与安全。这是MySQL连接的特性,可以参考MySQL官方文档4.2.4 Connecting to the MySQL Server Using Command Options

On Unix, MySQL programs treat the host name localhost specially, in a way that is likely different from what you expect compared to other network-based programs:the client connects using a Unix socket file.
To ensure that the client makes a TCP/IP connection to the local server, use --host or -h to specify a host name value of 127.0.0.1 (instead of localhost), or the IP address or name of the local server. You can also specify the transport protocol explicitly, even for localhost, by using the --protocol=TCP option.

解决办法:

  1. 将mysqli_connect()里的localhost后面加上端口号,如我用的是3307端口(因为我下载了两个mysql数据库服务器),写成:mysqli_connect(‘localhost:3307’, ‘root’, ‘root’)
    在这里插入图片描述
  2. 使用TCP/IP代替Unix socket。即在连接的时候将localhost换成127.0.0.1。
  3. 修改MySQL的配置文件my.cnf,指定mysql.socket的位置:
/var/lib/mysql/mysql.sock (你的mysql.socket路径)
  1. 直接在php建立连接的时候指定my.socket的位置(官方文档:mysqli_connect)。比如:
$db = new MySQLi('localhost', 'root', 'root', 'my_db', '3306', '/var/run/mysqld/mysqld.sock')

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/228873.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

unity学习笔记07

一、组件 有几个物体他们之间有着重复的功能&#xff0c;该如何避免重复的去写代码&#xff1f; 可以将一些相同的功能写成一个组件&#xff0c;也就是组件就等同于功能。 什么是组件&#xff1f; 在Unity中&#xff0c;游戏物体是不具备任何功能的&#xff0c;如果想要为其…

2021年06月 Scratch图形化(四级)真题解析#中国电子学会#全国青少年软件编程等级考试

Scratch等级考试(1~4级)全部真题・点这里 一、单选题(共10题,每题3分,共30分) 第1题 执行下列程序,输出的结果为? A:12 B:24 C:8 D:30 答案:B 第2题 执行下列程序,角色说出的内容是? A:2 B:3 C:4 D:5 答案:A 第3题 执行下列程序,输出结果为?

算法之插入排序及希尔排序(C语言版)

我们来实现上述排序 一.插入排序. 当插入第i(i>1)个元素时&#xff0c;前面的array[0],array[1],.,array[i-1]已经排好序&#xff0c;此时用array[i的排序码与array[i-1]array[i-2].的排序码顺序进行比较&#xff0c;找到插入位置即将arrayU插入&#xff0c;原来位置上的元…

深度学习之图像分类(十五)DINAT: Dilated Neighborhood Attention Transformer理论精简摘要(二)

Dilated Neighborhood Attention Transformer摘要 局部注意力机制&#xff1a;例如滑动窗口Neighborhood Attention&#xff08;NA&#xff09;或Swin Transformer的Shifted Window Self Attention。 优点&#xff1a;尽管在降低自注意力二次复杂性方面表现出色&#xff0c; …

位运算算法【1】

文章目录 &#x1f34a;面试题 01.01. 判定字符是否唯一&#x1f96d;题目&#x1f351;算法原理&#x1f95d;解法一&#xff1a;哈希表&#x1f95d;解法二&#xff1a;位图 &#x1f951;代码实现 &#x1f33d;268. 丢失的数字&#x1f96c;题目&#x1f344;算法原理&…

吃火锅(Python)

题目描述 吃火锅 以上图片来自微信朋友圈&#xff1a;这种天气你有什么破事打电话给我基本没用。但是如果你说“吃火锅”&#xff0c;那就厉害了&#xff0c;我们的故事就开始了。 本题要求你实现一个程序&#xff0c;自动检查你朋友给你发来的信息里有没有 chi1 huo3 guo1。…

Win7 SP1 x64 Google Chrome 字体模糊

1 打开 Google Chrome &#xff0c;地址栏输入 chrome://version/ &#xff0c;字体模糊。 2 Microsoft Update Catalog 搜索现在更新 kb2670838 &#xff0c;安装&#xff0c;重启电脑。 3 打开 Google Chrome&#xff0c;地址栏输入 chrome://version/ &#xff0c;字体正常。…

使字符串的单词倒序输出表示

题目 任务描述 本关任务&#xff1a;请实现函数 revWordoder&#xff0c;能够将 pa 指向的单词表字符串中的所有单词&#xff0c;按相反顺序放入 pb&#xff0c;同时去除多余的空格&#xff0c;单词之间只留一个空格. 例如 pa 中为 red blue, 则调用函数后&#xff0c;pb 中为b…

看懂YOLOv7混淆矩阵的含义,正确计算召回率、精确率、误检率、漏检率

文章目录 1、准确率、精确率、召回率、误报率、漏报率概念及公式1.1 准确率 Accuracy1.2 精确率 Precision1.3 召回率 Recall1.4 F1-Score1.5 误检率 false rate1.6 漏检率 miss rate 2、YOLOv7混淆矩阵分析 1、准确率、精确率、召回率、误报率、漏报率概念及公式 重点参考博文…

河北中洺科技-数据标注是怎样工作的?

由于人工智能系统的普及&#xff0c;各种智能场景在生活中变得普遍。然而&#xff0c;在这些极大方便我们生活的智能背后&#xff0c;数据标注似乎从未被人们所重视。数据标注是怎样的工作&#xff1f;为什么被称为人工智能训练师&#xff1f; 要想了解这些问题&#xff0c;我…

界面控件DevExpress WPF流程图组件,完美复制Visio UI!(二)

DevExpress WPF Diagram&#xff08;流程图&#xff09;控件帮助用户完美复制Microsoft Visio UI&#xff0c;并将信息丰富且组织良好的图表、流程图和组织图轻松合并到您的下一个WPF项目中。 在上文中&#xff08;点击这里回顾>>&#xff09;&#xff0c;我们为大家介绍…

Linux常用命令——basename命令

在线Linux命令查询工具 basename 打印目录或者文件的基本名称 补充说明 basename命令用于打印目录或者文件的基本名称。basename和dirname命令通常用于shell脚本中的命令替换来指定和指定的输入文件名称有所差异的输出文件名称。 语法 basename(选项)(参数)选项 --help&…