SQL SERVER 生僻字查询问题和关键字COLLATE

       先说问题,生僻字查询的问题,有的时候我们的数据里包含一些生僻字,在查询用Like模糊匹配的时候,发现有的查询不准确,测试数据如下:

--测试数据
if not object_id(N'Tempdb..#T') is null
	drop table #T
Go
Create table #T([col] nvarchar(21))
Insert #T
select N'䱗'UNION
SELECT N'啊'
Go
--测试数据结束

       如果这时候用Like查询,就会存在查询不准确的情况:

Select * from #T WHERE col LIKE N'%䱗%'  

       查询结果:

       两个数据都查询出来了,这时候我们使用COLLATE关键字,加上Chinese_PRC_BIN可以解决该问题:

Select * from #T WHERE col LIKE N'%䱗%'  COLLATE Chinese_PRC_BIN

       结果:

       这样就解决了这个生僻字查询的问题。

 

       那么接下来我们说说问题原因和加的这个COLLATE Chinese_PRC_BIN 是什么意思。

       生僻字由于在数据库中没有对应的编码,这样就会造成like的时候定位不到数据,所以解决这个问题也是从编码处入手,在排序的时候来做编码转换。

       COLLATE简单来说就是用来定义排序规则的,具体详细介绍可以看官方文档https://docs.microsoft.com/zh-cn/sql/t-sql/statements/collations?view=sql-server-ver15

       SQLSERVER的排序规则有很多,Chinese_PRC_BIN是一种排序规则,该规则分为两部分,其中Chinese_PRC_是指针对大陆简体字UNICODE的排序规则,BIN指的是二进制排序选项,这些关联选项有很多 ,例如:

 
选项说明
区分大小写 (_CS)区分大写字母和小写字母。 如果选择此项,排序时小写字母将在其对应的大写字母之前。 如果未选择此选项,排序规则将不区分大小写。 即 SQL Server 在排序时将大写字母和小写字母视为相同。 通过指定 _CI,可以显式选择不区分大小写。
区分重音 (_AS)区分重音字符和非重音字符。 例如,“a”和“ấ”视为不同字符。 如果未选择此选项,则排序规则将不区分重音。 即 SQL Server 在排序时将字母的重音形式和非重音形式视为相同。 通过指定 _AI,可以显式选择不区分重音。
区分假名 (_KS)区分日语中的两种假名字符类型:平假名和片假名。 如果未选择此选项,则排序规则将不区分假名。 即 SQL Server 在排序时将平假名字符和片假名字符视为相同。 省略此选项是指定不区分假名的唯一方法。
区分全半角 (_WS)区分全角字符和半角字符。 如果未选择此选项,SQL Server 会在排序时将同一字符的全角和半角形式视为相同。 省略此选项是指定不区分全半角的唯一方法

       上边列举了几个例子,如果想了解更多,可以到微软官网了解https://docs.microsoft.com/zh-cn/sql/relational-databases/collations/collation-and-unicode-support?view=sql-server-ver15,这里就不都贴上了。

       以上就是查询生僻字和排序关键字COLLATE的介绍,欢迎指正交流。

 

       写在最后(今天是个特殊的日子):

       今天是1024程序员节日,1024不知道从什么时候开始成了我们的节日,成了这些穿着格子衬衫、头发稀疏、但正在做着一些伟大事情的人群狂欢的节日,所以在博客里,也要祝福所有正在改变世界的程序员,节日快乐,远离脱发-拒绝Bug,Happy 1024!!!

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SQL Server 和 PostgreSQL 的保留关键字有一些差异。其中,SQL Server 的保留关键字包括:ADD, ALTER, AS, ASC, AUTHORIZATION, BACKUP, BEGIN, BREAK, BROWSE, BULK, BY, CASCADE, CASE, CHECK, CHECKPOINT, CLOSE, CLUSTERED, COALESCE, COLLATE, COLUMN, COMMIT, COMPUTE, CONSTRAINT, CONTAINS, CONTAINSTABLE, CONTINUE, CONVERT, CREATE, CROSS, CURRENT, CURRENT_DATE, CURRENT_TIME, CURRENT_TIMESTAMP, CURRENT_USER, CURSOR, DATABASE, DBCC, DEALLOCATE, DECLARE, DEFAULT, DELETE, DENY, DESC, DISK, DISTINCT, DISTRIBUTED, DOUBLE, DROP, DUMP, ELSE, END, ERRLVL, ESCAPE, EXCEPT, EXEC, EXECUTE, EXISTS, EXIT, EXTERNAL, FETCH, FILE, FILLFACTOR, FOR, FOREIGN, FREETEXT, FREETEXTTABLE, FROM, FULL, FUNCTION, GOTO, GRANT, GROUP, HAVING, HOLDLOCK, IDENTITY, IDENTITY_INSERT, IDENTITYCOL, IF, IN, INDEX, INNER, INSERT, INTERSECT, INTO, IS, JOIN, KEY, KILL, LEFT, LIKE, LINENO, LOAD, MERGE, NATIONAL, NATURAL, NCHAR, NEXT, NOCHECK, NONCLUSTERED, NOT, NULL, NULLIF, OF, OFF, OFFSETS, ON, OPEN, OPENDATASOURCE, OPENQUERY, OPENROWSET, OPENXML, OPTION, OR, ORDER, OUTER, OVER, PERCENT, PLAN, PRECISION, PRIMARY, PRINT, PROC, PROCEDURE, PUBLIC, RAISERROR, READ, READTEXT, RECONFIGURE, REFERENCES, REPLICATION, RESTORE, RESTRICT, RETURN, REVERT, REVOKE, RIGHT, ROLE,ROLLBACK, ROWCOUNT, ROWGUIDCOL, RULE, SAVE, SCHEMA, SECURITYAUDIT, SELECT, SEMANTICKEYPHRASETABLE, SEMANTICSIMILARITYDETAILSTABLE, SEMANTICSIMILARITYTABLE, SESSION_USER, SET, SETUSER, SHUTDOWN, SOME, STATISTICS, SYSTEM_USER, TABLE, TABLESAMPLE, TEXTSIZE, THEN, TO, TOP, TRAN, TRANSACTION, TRIGGER, TRUNCATE, TRY_CONVERT, TSEQUAL, UNION, UNIQUE, UNPIVOT, UPDATE, UPDATETEXT, USE, USER, VALUES, VARYING, VIEW, WAITFOR, WHEN, WHERE, WHILE, WITH, WITHIN GROUP, WRITETEXT。 而 PostgreSQL 的保留关键字包括:ALL, ANALYSE, ANALYZE, AND, ANY, ARRAY, AS, ASC, ASYMMETRIC, AUTHORIZATION, BINARY, BOTH, CASE, CAST, CHECK, COLLATE, COLUMN, CONSTRAINT, CREATE, CROSS, CURRENT_CATALOG, CURRENT_DATE, CURRENT_ROLE, CURRENT_SCHEMA, CURRENT_TIME, CURRENT_TIMESTAMP, CURRENT_USER, DEFAULT, DEFERRABLE, DESC, DISTINCT, DO, ELSE, END, EXCEPT, FALSE, FETCH, FOR, FOREIGN, FREEZE, FROM, FULL, GRANT, GROUP, HAVING, ILIKE, IN, INITIALLY, INNER, INTERSECT, INTO, IS, ISNULL, JOIN, LATERAL, LEADING, LEFT, LIKE, LIMIT, LOCALTIME, LOCALTIMESTAMP, NATURAL, NOT, NOTNULL, NULL, OFFSET, ON, ONLY, OR, ORDER, OUTER, OVERLAPS, PLACING, PRIMARY, REFERENCES, RETURNING, RIGHT, SELECT, SESSION_USER, SIMILAR, SOME, SYMMETRIC, TABLE, TABLESAMPLE, THEN, TO, TRAILING, TRUE, UNION, UNIQUE, USER, USING, VARIADIC, VERBOSE, WHEN, WHERE, WINDOW, WITH。 以上是两种数据库的保留关键字的差异。 ### 回答2: SQL Server和PostgreSQL是两种常见的关系型数据库管理系统(RDBMS)。它们的保留关键字在某些情况下是有所不同的,下面是它们的差异: 1.关键字的数量:SQL Server和PostgreSQL之间的保留关键字数量是不同的。SQL Server拥有更多的保留关键字,这意味着在SQL Server中,您需要更小心地选择列名和表名,以避免使用到这些保留关键字,否则可能会导致语法错误。 2.关键字的用途:两者之间还有一些保留关键字在用法上略有不同。例如,在SQL Server中,使用TOP来获取前几条记录,而在PostgreSQL中,使用LIMIT来实现相同的功能。这意味着,在从一个数据库系统迁移到另一个数据库系统时,您可能需要更改您的查询以适应不同的保留关键字。 3.大小写敏感性:在SQL Server中,保留关键字是不区分大小写的,而在PostgreSQL中,保留关键字是区分大小写的。这意味着在使用PostgreSQL时,必须严格按照保留关键字的大小写编写查询,否则可能会导致语法错误。 总体而言,SQL Server和PostgreSQL在保留关键字方面存在一些差异,包括关键字的数量、用途和大小写敏感性。在编写查询时,要特别注意这些差异,以避免语法错误和查询失败。 ### 回答3: SQL Server和PostgreSQL是两种不同的关系型数据库管理系统,它们在保留关键字方面存在一些差异。 首先,在SQL Server中,一些常用的保留关键字包括:SELECT、INSERT、UPDATE、DELETE、WHERE、FROM、JOIN、GROUP BY、HAVING、ORDER BY等。这些关键字用于执行查询、插入、更新和删除操作,以及过滤、排序和分组数据。此外,SQL Server还有一些特定的保留关键字,例如TOP、AS、INNER JOIN、OUTER JOIN、UNION等。 而在PostgreSQL中,保留关键字的列表与SQL Server有些不同。PostgreSQL的保留关键字包括:SELECT、INSERT、UPDATE、DELETE、WHERE、FROM、JOIN、GROUP BY、HAVING、ORDER BY等,这些与SQL Server相同。但是,PostgreSQL还有一些额外的保留关键字,如VALUES、RETURNING、GRANT、CASE、CAST等。 此外,两者在保留关键字的使用语法上也存在一些差异。在SQL Server中,保留关键字通常不区分大小写,因此可以使用大写或小写或其组合来表示关键字。而在PostgreSQL中,保留关键字是不区分大小写的,但建议使用小写来表示。此外,在PostgreSQL中,如果需要使用与保留关键字相同的名称作为表名或列名,可以使用双引号将其括起来,以区分为标识符而不是关键字。 总结而言,SQL Server和PostgreSQL在保留关键字方面存在一些差异。尽管它们有许多相同的关键字,但两者都有一些特定的关键字和语法上的差异。在编写SQL查询和语句时,要注意了解和遵守所使用的数据库管理系统的保留关键字的规则和约束。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值