- 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/
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
我对 Angular 还很陌生。我有一个由一些数据填充的列表项: {{content.Company}} {{content.Town}}, {{content.P
我正在尝试从 SwiftUI 中的 List 中删除“行”分隔符(在 SwiftUI 中称为分隔符)。 我浏览了 List 文档,但我没能找到它的修饰符。 如有任何帮助,我们将不胜感激。 最佳答案 i
我有一个带有 4 个按钮的网格...1 行 4 列。我正在寻找一种方法将左侧的两个按钮与右侧的两个按钮进行视觉分组。我一直在寻找一种使用分隔符执行此操作的方法,但它似乎与 Grid 一起玩得不好,更喜
我对 R 语言相当陌生。所以我有这个包含以下内容的向量: > head(sampleVector) [1] "| txt01 | 100 | 200 | 123.456
我正在尝试连接两列中的值,当我使用 =CONCAT(A2,",",B2) 时,它将连接两列并获得正确的结果 (P0810,P1)。但我正在寻找的是这样的东西(“P0810”,“P1”)。我尝试了 =C
我在这里创建了一个简单的演示。在 amount 字段编辑时,我想显示 , 分隔符?目前,它仅在不处于编辑模式时显示 ,。知道如何实现这一目标吗? DEMO IN DOJO var data = [{
这里是java菜鸟... 这让我抓狂,因为我知道这很简单,但我已经为此工作了 30 分钟...... 这是来自代码战斗: 对于参数 = ["Code", "Fight", "On", "!"] 且分隔
基于这个pywin32基础script如何向托盘菜单 menu_options 添加分隔符? 我还可以让菜单在左键单击时弹出,而不仅仅是右键单击吗? 最佳答案 将 notify 函数(从 URL 中的
我正在使用这段代码: StringTokenizer tokenizer=new StringTokenizer(line, "::"); 拆分以下字符串: hi my name is visghal
- Dropbox login fix - Updated iris viewer * other aspects are to be improved + fix crash on viewing
我试图在每个菜单组之间显示一个分隔线。我已经尝试过为每个组提供一个唯一的 ID,但这没有用。我找到了一些其他解决方案,但它们看起来有点奇怪,比如创建高度为 1dp 的 LinearLayout。 这是
我想为 CONCAT_WS() 选择一个与字段值不冲突的分隔符例如,如果我选择“,”,则字段值可能包含带有“,”的字符串我想选择一个与字段值不冲突的分隔符:( 最佳答案 来自here : CONCAT
我想知道 Sphinx 引擎是否可以使用任何定界符(如普通 MySQL 中的逗号和句点)。我的问题来自于一种冲动,根本不使用它们,而是逃避它们,或者至少在使用 FULLTEXT 搜索执行 MATCH
我正在尝试使用 svg 或纯 css3 制作 header 分隔符,如下所示: preview from design 在 header 中我有标准的 bootstrap 4 轮播
我在使用 CSS 分隔符时遇到了一些难题。看看:http://jsfiddle.net/fVxC6/1/ .div-line { border-bottom: 1px solid #f0f0f
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 7 年前。 编辑问题以包含 desired behavior, a specific probl
嘿,我正在尝试使用 getline 读取以下行 (15,0,1,#) (2,11,2,.) (3,20,0,S) 我希望能够将整数提取为 int,将字符提取为 char,但我不知道如何只提取它们。 最
我有 2 列,每边 float 一列,我想使用 1px 宽度的线分隔符,从最长列的顶部到底部。 我宁愿远离 TABLE 布局,而且我不知道哪一个将是最长的列,或者它会有多长。 我怎么能只用 css 做
我是一名优秀的程序员,十分优秀!