首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用OrderByRaw时的sqlkata问题

使用OrderByRaw时的sqlkata问题
EN

Stack Overflow用户
提问于 2020-10-27 21:34:30
回答 1查看 141关注 0票数 0

您好,我在使用SqlKata的OrderByRaw方法时发现了一个非常奇怪的错误。

代码语言:javascript
复制
var query = new Query("SoftwareVersions").OrderByRaw("string_to_array([version], '.')::int[] DESC")

我也在这里测试了https://sqlkata.com/playground/pgsql相同的错误。

问题在于整方括号,它们被转换为“列”,没有任何内容,或者只有两个引号,下面是与SqlKata在运行时生成的结果完全相同的结果:

代码语言:javascript
复制
SELECT * FROM "SoftwareVersions" ORDER BY string_to_array("version", '.') :: int "" DESC

注意:在这里你可以看到,在int转换之后,我们有两个引号。

我的问题是如何使用SQLKata避免这种意外行为。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-27 21:42:02

默认情况下,对于每个编译器,SqlKata将[]交换为相应的分隔符,这就是为什么你会得到双引号",在MySql中,你可能会得到反引号,依此类推。

要避免这种情况,只需使用反斜杠对它们进行转义。

代码语言:javascript
复制
.OrderByRaw(@"string_to_array([version], '.')::int\[\] DESC")

检查https://sqlkata.com/playground/pgsql?code=var%20query%20%3D%20new%20Query(%22SoftwareVersions%22).OrderByRaw(%40%22string_to_array(%5Bversion%5D%2C%20'.')%3A%3Aint%5C%5B%5C%5D%20DESC%22

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64555632

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档