当前位置: 首页 > 面试题库 >

SQL的where子句中的'N'

濮佑运
2023-03-14
问题内容

我在某处看到此查询-

SELECT *
FROM HR.Employees
WHERE country <> N'JAP';

什么是 “N” 是什么意思?我不确定这是否仅对SQL Server有效。


问题答案:

N代表“国家字符”,它表示字符串的内容为Unicode。

只要碰到专有名称或其他可能包含默认ASCII字符集以外的字符的实体,就应该使用Unicode(nchar/
nvarchar)。如果不使用N前缀将此类字符串括起来,则会丢失数据。例如:

SELECT N'褍泻 褎械褉褌 褏械褉', '褍泻 褎械褉褌 褏械褉';

结果:

-----------        -----------
ук ферт хер        ?? ???? ???

您还应确保N在您WHERE或其他子句中对n(var)char列使用前缀。不使用N前缀时,由于隐式转换,可能会遇到严重的性能问题。



 类似资料:
  • WHERE 子句用于过滤记录。 SQL WHERE 子句 WHERE 子句用于提取那些满足指定标准的记录。 SQL WHERE 语法SELECT column_name,column_name FROM table_name WHERE column_name operator value; 演示数据库 在本教程中,我们将使用 RUNOOB 样本数据库。 下面是选自 "Websites" 表的数据

  • 问题内容: 是否可以在WHERE子句中使用LIMIT x? 如果是这样,怎么办? 我正在尝试这样做: 但我收到以下错误: 问题答案: 应该在之后。 句法 :

  • 问题内容: 我将如何在没有硬编码值的情况下编写此sql语句? 宁愿有这样的事情: 提前致谢.. 问题答案: 用您当前的方式构造SQL查询是一个糟糕的主意,因为它为各种SQL注入攻击打开了大门 。为了正确执行此操作,您必须改为使用“ 预备语句”。这也将解决您目前显然遇到的各种逃避问题。 请注意,这是一个昂贵的调用(除非您的应用程序服务器使用语句缓存和其他类似的功能)。从理论上讲,最好先准备一次语句,

  • 问题内容: 在处理大型数据库时,哪个性能更好,还是在SQL子句中? 它们的执行方式有什么不同吗? 问题答案: 我假设您想知道以下两者之间的性能差异: 根据MySQL手册,如果值是常数,则对列表进行排序,然后使用二进制搜索。我可以想象一下,它们以不特定的顺序进行逐一评估。因此在某些情况下速度更快。 最好的了解方法是使用特定数据在数据库中同时对它们进行概要分析,以查看哪种方法更快。 我在具有10000

  • 问题内容: 我正在创建一个需要条件子句的SQL查询。 应该是这样的: 上面的查询不起作用。这是不正确的语法,还是我不知道的另一种方式来做到这一点? 我不想使用动态SQL,是否还有其他方法,还是必须使用类似的解决方法,例如对不同的子句使用和使用相同的查询? 问题答案: 试试这个 您可以在此处阅读有关条件WHERE的更多信息。

  • 根据给定的表数据,第三行中的非空字段是“field1”和“field3”。因此WHERE子句将是: 我如何编写一个具有动态WHERE子句的通用SQL来满足这个需求?