- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个表“car_purchases”,其中包含“描述”列。该列是一个字符串,其中包含名字首字母、后跟句号、空格和姓氏。描述列的示例是
'Car purchased by J. Blow'
我正在使用“substring_index”函数来提取“.”之前的字母在列字符串中。就像这样:
SELECT
Description,
SUBSTRING_INDEX(Description, '.', 1) as TrimInitial,
SUBSTRING_INDEX(
SUBSTRING_INDEX(Description, '.', 1),' ', -1) as trimmed,
length(SUBSTRING_INDEX(
SUBSTRING_INDEX(Description, '.', 1),' ', -1)) as length
from car_purchases;
我将此查询称为 1。
picture of the result set (Result 1) is as follows
正如您所看到的,问题在于 select 语句中的“修剪”列开始计算第二个分隔符“”,而不是右侧第一个分隔符,并生成“by J”结果,而不仅仅是“J”。此外,长度列表明字符串长度是 5 而不是 4,所以 WTF?
但是当我执行以下 select 语句时;
select SUBSTRING_INDEX(
SUBSTRING_INDEX('Car purchased by J. Blow', '.', 1),' ', -1); -- query 2
结果 =“J”为“结果 2”。
正如您从结果 1 中看到的,“描述”列中的字符串与“结果 2”中的字符串完全相同(据我所知)。但是,当对列(而不仅仅是字符串本身)执行 substring_index 时,结果会忽略第一个分隔符,并从字符串右侧的第二个分隔符中选择一个字符串。
我为此绞尽脑汁,并尝试使用“by”和“by”作为分隔符,但这两个选项都不能产生单个字符的所需结果。我不想通过使用修剪函数来进一步增加查询 1 的复杂性。我还尝试了结果列“修剪”上的强制转换函数,但仍然没有成功。我也不想连接它。
查询 1 的“length”列存在异常,如果我将 length 函数更改为 char_length 函数,如下所示:
select length(SUBSTRING_INDEX(
SUBSTRING_INDEX(Description, '.', 1),' ', -1)) as length -- result = 5
select char_length(SUBSTRING_INDEX(
SUBSTRING_INDEX(Description, '.', 1),' ', -1)) as length -- result = 4
谁能向我解释一下为什么上面的 select 语句会产生 2 个不同的结果?我认为这就是我没有得到我想要的结果的原因。
但要明确的是,我想要的结果是得到“J”而不是“by J”。
我想我可以尝试反向,但我不认为这是一个可以接受的妥协。另外,我不熟悉排序规则和字符集原则,只是使用默认值。
各位玩家加油!!!
最佳答案
CHAR_LENGTH
返回字符长度,因此具有 4 个 2 字节字符的字符串将返回 4。 LENGTH
但是返回以字节为单位的长度,因此具有 4 个 2 字节字符的字符串将返回 8。结果中的差异(包括 SUBSTRING_INDEX
)表明 by
和 J 之间的“空格”
实际上并不是一个单字节空格(ASCII 0x20),而是一个看起来像空格的 2 字节字符。要解决此问题,您可以尝试使用 CONVERT
将所有 unicode 字符替换为空格。和 REPLACE
。在此示例中,我在 by
和 J
之间的字符串中有一个 en-space
unicode 字符。 CONVERT
将其更改为 ?
,然后 REPLACE
将其转换为空格:
SELECT SUBSTRING_INDEX( SUBSTRING_INDEX("Car purchased by J. Blow", '.', 1),' ', -1)
输出:
by J
使用CONVERT
和REPLACE
:
SELECT SUBSTRING_INDEX( SUBSTRING_INDEX(REPLACE(CONVERT("Car purchased by J. Blow" USING ASCII), '?', ' '), '.', 1),' ', -1)
输出
J
对于您的查询,您可以将字符串替换为您的列名称,即
SELECT SUBSTRING_INDEX( SUBSTRING_INDEX(REPLACE(CONVERT(description USING ASCII), '?', ' '), '.', 1),' ', -1)
关于mysql - substring_index 从右侧跳过分隔符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52902397/
似乎这是不可能的,但如果有人提示如何在谷歌浏览器中创建右侧边栏(如 iframe),任何提示都会有所帮助。谢谢。 最佳答案 如果你的意思是这样的 这是来自 google chrome 实验 api:
您好,我在用 C 语言解决编程任务时遇到问题。 The funktion "Trim" should replace all spaces at the end of a String with nu
有什么方法可以找到一个事件(或属性或方法或类似的东西)来检测窗口停靠到左侧或右侧吗? 描述: 通过 WindowState 属性,您可以了解当您的窗口在正常/最小化/最大化这三种状态之间改变状态时。在
我目前需要找到一个算法来确定一个点是在圆弧的右侧还是左侧。 这是以下算法的扩展以包含弧: // isLeft(): tests if a point is Left|On|Right of an i
我正在使用 Selenium 执行测试,该测试在 3 个浏览器上并行执行。我想以下一种方式定位 window :左侧,右侧和底部,所以基本上我正在寻找与 (start btn+left btn...)
如果我有下面的代码,并且我想插入一个带有 jquery 的 div 作为表单标记内的第一个元素,那么最好的方法是什么? //i want to insert a div here with
有没有比这个更好的方法来解决这个问题? def 渲染(arr): single_elements = [] double_elements = [] for i in xrange(len(arr
Home About
我遇到的问题是: www.dondolomemories.it 当调整窗口大小时, Logo 图像直到最后一刻才调整大小,导致可怕的两行菜单溢出。 我花了将近 2 个小时尝试大量不同的设置。有人可以帮
我希望我能很好地解释这一点。我有一个 style="float: right;"的 div在这个 div 中,我有一个包含一些编辑器字段的表。但现在我想要两个文本编辑器框(在 .NET MVC3 @H
如果有人能帮助我解决这个问题,我将不胜感激,因为我无法让它工作。 这是我正在努力处理的代码:http://jsfiddle.net/sp91c3nk/ 基本上,我希望右侧导航栏与灰色主要内容区域处于同
我正在尝试在图像的所有四个边上添加文本,但我无法让正确的文本正确对齐。右边的文字仍然在左边。 fiddle :https://jsfiddle.net/y75L0ww9/ Text on top Te
我正在尝试为顶部以及左侧和右侧设置 css 阴影,但高度降低。我熟悉模糊/半径,但我希望阴影非常短。 picture from wix template (还不能上传,抱歉) 有人可以帮帮我吗?我看到
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 6 年前。 Improve
请看这个jsfiddle . 我想要 与 innerText “嗨!”始终出现在其包含父级的可见部分的底部/右侧。它不应与其父级的内容一起滚动。 HTML: Header
我有一个输入框和一个提交按钮。 当我向右浮动提交按钮时,我希望它在与输入字段相同的点结束 - 这是我的意思的一个例子:http://prntscr.com/aggln5 目前,输入和提交在不同的点结束
我基本上刚刚开始让我的网站响应,但出于某种原因,语言 div (#lang) 设置为向右浮动,正在向右浮动,但在它的右侧有一个小边距。虽然没有填充设置父 div #container,但我无法理解。
我目前正在创建一个网站,该网站有一个带有文本等内容的居中框。现在,我还想要一个漂浮在右边的盒子,与我的主盒子有一点缝隙。留个图吧,我画的红框就是我要制作的 float 框。 顺便说一句。蓝色方框只是我
我不是 UI 开发人员,但这次需要玩 css。为用户配置文件编写表单。我快完成了,但还有一个小问题。问题 个人资料图片未正确显示在右侧。 因此,第一个字段(组织名称)显示不正确 自从过去两个小时以来,
我有以下脚本: http://jsfiddle.net/rYFEY/12/ 效果很好,除了我需要移除右侧和右下角的 handle ,只留下底部 handle 用于调整大小。目前,如果我点击右 hand
我是一名优秀的程序员,十分优秀!