sqlite 中文排序

SQLite 默认排序为 UNICODE 编码序,与汉语拼音没有任何联系,而人们常习惯拼音序。
解决方法在 C# 中其实很简单,但网上尚未见有任何中文资料说这事,只有 C 方法。以下我是通过一英文网页学到的。

首先,定义和注入规则
示例代码如下,很简单无须多解释。只有一点必须注意,对同一个函数只能注入一次,不得重复,所以注入语句写在主函数中再合适不过。

[csharp] view plaincopy
  1.     static class Program {  
  2.   
  3.         // 主函数  
  4.         [STAThread]  
  5.         static void Main()  
  6.         {  
  7.             SQLiteFunction.RegisterFunction(typeof(SQLiteCollation_PinYin));    // 注入  
  8.             Config.Reload();  
  9.             Application.EnableVisualStyles();  
  10.             Application.SetCompatibleTextRenderingDefault(false);  
  11.             Application.Run(new MainForm());  
  12.             Config.Save();  
  13.         }  
  14.   
  15.         // 中文拼音排序规则  
  16.         [SQLiteFunction(FuncType = FunctionType.Collation, Name = "PinYin")]  
  17.         class SQLiteCollation_PinYin: SQLiteFunction {  
  18.             public override int Compare(string x, string y)  
  19.             {  
  20.                 return string.Compare(x, y);  
  21.             }  
  22.         }  
  23.     }  


而后,使用
使用时, SQL 代码不能简单地写上 ORDER BY XXX 了事,还得用上 COLLATE ,示例如下:

  1. SELECT * FROM Client_V  
  2. ORDER BY  
  3.     City COLLATE PinYin,  
  4.     Unit COLLATE PinYin,  
  5.     Name COLLATE PinYin;  

COLLATE 便是指定规则, PinYin 便是上面 C# 代码中定义规则时的 Name = "PinYin" 。
另外,用建表、建立索引时,也应当考虑使用 COLLATE ,这样才能让数据库快起来。

转载于:http://blog.csdn.net/ch_fb/article/details/6682791

posted @   把爱延续  阅读(7095)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示