- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我很难理解为什么在 4 B 宽表情符号 ( http://emojipedia.org/eyes/ ) 上使用 LIKE
条件的 SELECT
会返回表中的所有行。
-- The DB collation is Finnish_Swedish_CI_AS
CREATE TABLE #Test
(
Number int identity,
Value nvarchar(20) NOT NULL
);
GO
INSERT INTO #Test VALUES ('');
INSERT INTO #Test VALUES ('a');
INSERT INTO #Test VALUES ('b');
INSERT INTO #Test VALUES ('c');
INSERT INTO #Test VALUES ('👀'); -- should be http://emojipedia.org/eyes/
GO
select * from #Test where Value like '%👀%'
select * from #Test where Value like N'%👀%'
GO
DROP TABLE #Test;
GO
第一个选择的结果是单个表情符号行。但是,第二个选择的结果(其中字符串标记为带有 N 前缀的 UNICODE)是所有行。
为什么第二个选择匹配表中的所有行?
实际场景我有一个 Web 应用程序,用户可以在其中搜索目录,如果他们搜索表情符号,则会返回整个表,而不是正确匹配的行。
ASP.NET MVC 5 web application <-> Web Api 2 <-> EF -> SQL Server
更新我的测试SQL
不正确,因为@deroby指出INSERT
语句应该用N'...'标记正确插入为 Unicode。
解决方案 正如 @deroby 所说,这似乎是一个排序问题,将其更改为 Finnish_Swedish_100_CI_AS
似乎可以使事情按预期进行。
select * from #Test where Value like N'%👀%' COLLATE Finnish_Swedish_100_CI_AS
最佳答案
添加后会变得更有趣
INSERT INTO #Test VALUES ('👂'); -- should be http://emojipedia.org/eyes/
您的第一个SELECT
现在将返回两个表情符号记录;即使它们看起来是错误的。其原因是 👂
和👀
是无效的 varchar() 值。因此,它们会导致一些占位符被放入数据库中(显示为 ??
)。
现在,如果您“正确”地进行插入并将数据作为正确的 Unicode 字符串插入,那么事情就会好得多:
INSERT INTO #Test VALUES (N'');
INSERT INTO #Test VALUES (N'a');
INSERT INTO #Test VALUES (N'b');
INSERT INTO #Test VALUES (N'c');
INSERT INTO #Test VALUES (N'👀'); -- should be http://emojipedia.org/eyes/
INSERT INTO #Test VALUES (N'👂'); -- should be http://emojipedia.org/eyes/
select * from #Test -- returns everything
select * from #Test where Value like '%👀%' -- returns nothing (because it looks for the '??' placeholder
select * from #Test where Value like N'%👀%' -- returns just one line
PS:这就是它在我的 SQL2012 上的工作原理 (Latin1_General_BIN)。
Why does the the second select match all rows in the table?
我也无法解释;对我来说则不然。所以我猜测这是一个排序问题,这些表情符号都被认为是相等的。
事实上,正在做测试
select * from #Test where Value like N'%👀%' COLLATE Finnish_Swedish_CI_AS
select * from #Test where Value like N'%👀%' COLLATE Latin1_General_BIN说明这里需要寻找原因。至于为什么,我也不知道。
关于sql-server - SQL Server 2014 LIKE 4 B 宽字符返回整个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29413958/
函数参数中或显示尺寸时(高度,宽度)的顺序是否有约定? 最佳答案 我不知道大量的语言,但我使用过的语言(宽度,高度)。它更适合沿着 (x, y) 坐标线。 关于language-agnostic -
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 6 年前。 Improve th
有没有办法显示自定义宽度/高度的YouTube视频? 最佳答案 在YouTube网站上的this link中: You can resize the player by editing the obj
如何从此表单获取数据(数据的长表示): import pandas as pd df = pd.DataFrame({ 'c0': ['A','A','B'], 'c1': ['b',
我在让宽度为 900px 的页面在宽度低于 900px 的分辨率下看起来不错时遇到了一些麻烦。这包括智能手机等移动设备。看起来我在页面上放大了,但无法滚动或缩小。我的页面包装器被定义为以屏幕为中心。这
我有一个包含一个表的 div,它有另一个带有动态变化文本的 div。div 有样式 overflow: hidden; white-space: nowrap; text-overflow: elli
我一直在愚弄下面的html代码。我已将 div id ="mainWide"设置为 2500 像素的宽度,这比我的屏幕还宽,我希望在主浏览器窗口中有一个水平滚动条,而不是在 div block 本身中
当我的屏幕浏览器窗口在 992px-1199px 之间时,我的文章元素比它们的父 div (.wrapper) 更宽。所以在这个屏幕宽度下,面板重叠并且看起来不对。 在所有其他屏幕宽度下,我的代码都准
我在对齐某些行时遇到了一些问题。我正在显示一个占据视口(viewport) 100% 高度的部分。因此,当您在屏幕上查看此部分时,您只会看到此部分。 在这个部分中,我有一个标题和副标题。标题应显示在节
为什么表单输入字段比其父 div 宽?宽度应用于文本 div,但不应用于其中包含表单字段的 div。为什么会这样? See the livecode here. .parent { width:
我想让这个标题 100% 宽。我在 jsfiddle 上试过这个,但是左边和右边还有一些余量。 CSS: #header { background: url("../img/top-bg.png
我的页面宽度有问题。无论我尝试什么,它的左边或右边都有白边(默认情况下在右边,如果我使用 margin-right:0 则在左边)。如果我使用 margin:0 比它留在右边。尝试了我所知道的一切,但
我有一个带有背景图片的宽 div。 div 的宽度为 1100 像素,当浏览器窗口小于该宽度时,会出现滚动条。有什么办法可以避免滚动条吗?那不是任何黑客。现在我知道我可以把它放在 body image
我有一个您可以访问的应用程序 here .当您打开应用程序时,只需单击加号按钮,您就会看到一个带有搜索栏的模态窗口。 现在请执行这两个搜索: 搜索 1:AAA 搜索 2:AAE 您会看到,在 AAE
这个问题在这里已经有了答案: Does element width include padding? (5 个答案) 关闭 7 年前。 HTML CSS .wrap{widt
我正在尝试在工具栏中创建一个自定义显示,类似于 Xcode 工具栏中心的信息 Pane 。 我们如何创建一个宽度超过 32 点的 NSToolbarItem? 框架始终将其限制为 32 点,即使最小和
我想将df1转换成df2 旧示例数据框 df1 df1 长),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/359
我正在使用 JavaScript 代码在 FireBase/FireStore 中上传图像。 核心功能已经可以运行,我可以上传,但我还需要在上传之前检查图像的大小。这就是我很乐意获得帮助的地方。 以下
如何在 Tkinter 中设置/更改 ttk.Separator 对象的长度/宽度? ttk.Separator(self, orient='horizontal').grid(c
我有一个简单的问题。为什么 a 不会自动调整其内容的大小?像这样: Test 返回 width:100%,尽管我希望“Test”这个词简单地居中。有什么想法吗? 最佳答案 您的问题与 HT
我是一名优秀的程序员,十分优秀!