我看到在 MySQL/MariaDB 数据库中替换 的 SQL 示例:
UPDATE wp_posts SET post_content = REPLACE(post_content, ' ', ' ');
...但是这个语句会抛出一个错误:
#1064 - You have an error in your SQL syntax; check the manual that
corresponds to your MariaDB server version for the right syntax to
use near '' )' at line 1
我看到了 '' 和 )' - 我尝试用反斜杠转义分号 \:
UPDATE wp_posts SET post_content = REPLACE(post_content, ' \;', ' ');
...但得到大致相同的错误。实际上,我看到很多 MySQL/MariaDB 的 SQL 示例,它们既没有转义分号也没有转义符号。
编辑
@Barmar 建议从命令行运行 SQL。我登录到 MariaDB 并输入使用“使用我的数据库”。提示更改为指示当前数据库,我输入了上面的命令。该命令被无误地接受,找到了 2300 多个匹配项,但没有任何更改:
MariaDB [mydatabase]> UPDATE wp_posts SET post_content = REPLACE(post_content, 'Â ', ' ');
Query OK, 0 rows affected (0.25 sec)
Rows matched: 2330 Changed: 0 Warnings: 0
为什么没有任何变化?
编辑 - 包括 WHERE
我越来越迷茫了。从 phpMyAdmin 中:
SELECT * from wp_posts WHERE post_content LIKE '%Â %'; <== 返回="" 1715="">==>
还有在 phpMyAdmin 中:
UPDATE wp_posts SET post_content = REPLACE(post_content, 'Â ', ' ') WHERE post_content LIKE '%Â %'; <== 返回="" 0="" 个匹配的行="">==>
来自 CLI:
SELECT COUNT(*) from wp_posts WHERE post_content LIKE 'Â '; <== 返回="">==>
SELECT COUNT(*) from wp_posts WHERE post_content LIKE 'Â'; <== 返回="">==>
我完全不知道如何看待这些差异。可以肯定的是,我知道我的 wp_posts 中到处都是时髦的 。我可以使用 phpMyAdmin 在数据中看到它。
最佳答案
'Â ' 让我相信问题不是你想的那样。
调试,对您尝试修复的源代码行之一执行 SELECT HEX(col)...。我怀疑您会在十六进制字符串中找到 C2A0。这是使用 htmlentities() 时变成 的 utf8 编码。
您可能还遇到了字符集问题。请找出在 phpmyadmin 中有效的设置; 显示像“char%”这样的变量;;和 SHOW CREATE TABLE。我要求这些是因为 latin1 A0 和 UTF-8 C2A0 之间可能存在一些混淆,这会增加困惑。
在许多情况下,“硬空间”(十六进制 A0)看起来就像一个普通空间(十六进制 20),使它更进一步很难决定什么是什么。
总结:
SELECT HEX()我主要看到 A0 来自 Microsoft Word 文档,但可能还有其他来源。
当被误解为 latin1 时,utf8 C2A0 显示为 Â(A-circumflex 和一个空格)。
关于mysql - 如何在没有 MariaDB 语法错误的情况下进行替换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56067765/
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
我脑子里浮现出一些关于一种新编程语言的想法,所以我想我会尝试实现它。一位friend建议我尝试使用Treetop(Rubygem)来创建一个解析器。Treetop的文档很少,我以前从未做过这种事情。我的解析器表现得好像有一个无限循环,但没有堆栈跟踪;事实证明很难追踪到。有人可以指出入门级解析/AST指南的方向吗?我真的需要一些列出规则、常见用法等的东西来使用像Treetop这样的工具。我的语法分析器在GitHub上,以防有人希望帮助我改进它。class{initialize=lambda(name){receiver.name=name}greet=lambda{IO.puts("He
大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%
我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我有一个奇怪的问题:我在rvm上安装了rubyonrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(
这是在Ruby中设置默认值的常用方法:classQuietByDefaultdefinitialize(opts={})@verbose=opts[:verbose]endend这是一个容易落入的陷阱:classVerboseNoMatterWhatdefinitialize(opts={})@verbose=opts[:verbose]||trueendend正确的做法是:classVerboseByDefaultdefinitialize(opts={})@verbose=opts.include?(:verbose)?opts[:verbose]:trueendend编写Verb
鉴于我有以下迁移:Sequel.migrationdoupdoalter_table:usersdoadd_column:is_admin,:default=>falseend#SequelrunsaDESCRIBEtablestatement,whenthemodelisloaded.#Atthispoint,itdoesnotknowthatusershaveais_adminflag.#Soitfails.@user=User.find(:email=>"admin@fancy-startup.example")@user.is_admin=true@user.save!ende