草庐IT

php - PHP 中的上标字符导致 MySQLi 选择查询找到 0 行

coder 2023-10-06 原文

我使用的是 PHP 5.3.3 和 MySQL 5.1.61。有问题的列使用 UTF-8 编码,PHP 文件使用没有 BOM 的 UTF-8 编码。

在 Windows 上的 SQLyog 中使用 ² 字符执行 MySQLi 查询时,查询会正确执行并显示正确的搜索结果。

如果我在 PHP 中执行完全相同的查询,它会执行但会显示 0 个 affected_rows。

这是我尝试过的:

  • 同时使用 LIKE 而不是 =
  • 将 PHP 文件的编码更改为 ANSI、UTF-8 without BOM 和 UTF-8
  • 在运行查询之前执行“SET NAMES utf-8”和“latin1”
  • Did header('Content-Type: text/html; charset=UTF-8');在 PHP 中
  • 使用 MySQLi::real_escape_string 转义
  • 执行 filter_var($String, FILTER_SANITIZE_STRING)
  • 尝试了 MySQLi stmt 绑定(bind)

唯一能让它正常工作的方法是将 ² 换成 % 并在 PHP 中将 = 更改为 LIKE。

如何在使用 ² 时在 PHP 中正确查询?

最佳答案

您应该能够通过确保以下内容使查询正常工作:

为 UTF-8 准备 PHP

您首先需要确保将发出这些查询的 PHP 页面以 UTF-8 编码页面的形式提供。这将确保正确显示来自数据库的任何 UTF-8 输出。在 Firefox 中,您可以通过访问您感兴趣的页面并使用查看页面信息菜单项来检查是否属于这种情况。当您这样做时,您应该看到 UTF-8 作为页面的编码 的值。如果页面未以 UTF-8 格式提供,您可以使用以下两种方法之一。您可以在对 header() 的调用中设置编码,像这样:

header('Content-Type: text/html; charset=UTF-8');

或者,您可以使用 meta在您页面的 head 中添加标签 block :

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

为 UTF-8 准备 MySQL

接下来,您需要确保数据库设置为使用 UTF-8 编码。这可以在服务器、数据库、表或列级别进行设置。如果您在共享主机上,您可能只能控制层次结构的表和列级别。如果您可以控制服务器或数据库,则可以通过发出以下两个命令来检查它们使用的字符编码:

SHOW VARIABLES LIKE 'character_set_system';
SHOW VARIABLES LIKE 'character_set_database';

可以使用如下命令更改数据库级别的编码:

(CREATE | ALTER) DATABASE ... DEFAULT CHARACTER SET utf8;

要查看表格使用的字符编码,只需执行以下操作:

SHOW CREATE TABLE myTable;

同样,下面是更改表级编码的方法:

(CREATE | ALTER) TABLE ... DEFAULT CHARACTER SET utf8;

我建议在层次结构中将编码设置得尽可能高。这样,您就不必记住为新表手动设置它。现在,如果您的表字符编码尚未设置为 UTF-8,您可以尝试使用 alter 转换它。像这样的语句:

ALTER TABLE ... CONVERT TO CHARACTER SET utf8;

使用此语句时要非常小心!如果您的表中已有 UTF-8 值,当您尝试转换时它们可能会损坏。有some ways to get around this , 然而。

强制 MySQLi 使用 UTF-8

最后,在连接到数据库之前,请确保发出适当的调用以说明您正在使用 UTF-8 编码。方法如下:

$db = new mysqli(DB_HOST, DB_USERNAME, DB_PASSWORD, DB_NAME);

// Change the character set to UTF-8 (have to do it early)
if(! $db->set_charset("utf8"))
{
    printf("Error loading character set utf8: %sn", $db->error);
}

一旦你这样做了,一切都应该按预期工作。您唯一需要担心编码的字符是 HTML 的大 5:<, >, ', ", and & .您可以使用 htmlspecialchars() 来处理它功能。

如果您想阅读更多内容(并获得其他资源的链接),请随时查看我写的有关此过程的文章。有两部分:Unicode and the Web: Part 1 , 和 Unicode and the Web: Part 2 .祝你好运!

关于php - PHP 中的上标字符导致 MySQLi 选择查询找到 0 行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12277751/

有关php - PHP 中的上标字符导致 MySQLi 选择查询找到 0 行的更多相关文章

  1. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  2. Ruby 解析字符串 - 2

    我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?

  3. ruby - 其他文件中的 Rake 任务 - 2

    我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时

  4. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  5. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  6. ruby-on-rails - unicode 字符串的长度 - 2

    在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)

  7. ruby-on-rails - Rails 3 中的多个路由文件 - 2

    Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题

  8. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  9. ruby - ECONNRESET (Whois::ConnectionError) - 尝试在 Ruby 中查询 Whois 时出错 - 2

    我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.

  10. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

随机推荐