访问mysql数据库时,localhost和127.0.0.1不同吗?
用php访问本地的mysql数据库,代码如下:
<code>$mysqli = new mysqli("localhost", $name, $passwd, "test"); if ($mysqli->connect_errno) { die("Failed to Connect to mysql: " . $mysqli->connect_errno); } $result = $mysqli->query("SELECT * FROM pet;"); if(!$result){ echo "QUERY ERROR: " . $mysqli->error; } ... ... $mysqli->close(); </code>
当主机名写 localhost
时, 可以正常把库表中的记录显式出来。
而当主机名写成 127.0.0.1
时,虽然连接数据库没有报错,但报 QUERY ERROR
。
这么说 localhost
和 127.0.0.1
不同吗? 怎么回事呢?
回复内容:
用php访问本地的mysql数据库,代码如下:
<code>$mysqli = new mysqli("localhost", $name, $passwd, "test"); if ($mysqli->connect_errno) { die("Failed to Connect to mysql: " . $mysqli->connect_errno); } $result = $mysqli->query("SELECT * FROM pet;"); if(!$result){ echo "QUERY ERROR: " . $mysqli->error; } ... ... $mysqli->close(); </code>
当主机名写 localhost
时, 可以正常把库表中的记录显式出来。
而当主机名写成 127.0.0.1
时,虽然连接数据库没有报错,但报 QUERY ERROR
。
这么说 localhost
和 127.0.0.1
不同吗? 怎么回事呢?
loaclhost和127.0.0.1是不能等价的
loaclhost是一个name,这个name一般情况下代表了127.0.0.1这个IP地址,也就是说,当你对计算机说,我要去loaclhost的时候,计算机会通过DNS或者NBNS或者hosts这个文件将它翻译成127.0.0.1.
如果使用loaclhost去链接数据库,则Mysql会使用unixsocket去链接。如果指定为127.0.0.1,则会使用TCP/IP来链接。
所以,尽量使用127.0.0.1.
嗯,看到答案已经被采纳了,不过还是要多说一点
其实答案写的不是很严谨,不过既然被采纳了,就多说一点。
通常意义上localhost
和127.0.0.1
是等价的,只是mysql在处理这个名词的问题上有一些不同,是根据不同的地址来采取的不同的通信手段。
原因呢,我猜大概是为了本地应用能获得更好的性能。而且localhost
这个地址在mysql中也不会做匹配。即user@'%'
不能匹配到user@'localhost'

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

One of the major changes introduced in MySQL 8.4 (the latest LTS release as of 2024) is that the "MySQL Native Password" plugin is no longer enabled by default. Further, MySQL 9.0 removes this plugin completely. This change affects PHP and other app

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

The page is blank after PHP connects to MySQL, and the reason why die() function fails. When learning the connection between PHP and MySQL database, you often encounter some confusing things...

CMS stands for Content Management System. It is a software application or platform that enables users to create, manage, and modify digital content without requiring advanced technical knowledge. CMS allows users to easily create and organize content
