首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sql将字符数据转换为GROUP BY查询中的缩写指数表示法

sql将字符数据转换为GROUP BY查询中的缩写指数表示法
EN

Stack Overflow用户
提问于 2014-03-19 04:22:56
回答 1查看 607关注 0票数 0

我有一个数据表,其中包含一个名为"unique_booking_reference“的字段。该字符字段的样本数据为

代码语言:javascript
复制
4ed74efa3c36d10000  
4ed74efa3c36d10002  
4ee876ab0a01510040  
4ed74efa3c36d10003  
4ed74efa3c36d10004  
4ed74efa3c36d10005  
4f3151bf9213810560  
4f316fb7bb7f010640  
4f3183462abeb10710  
4f3188774374210730  
4f314faa0b25510550

然而,它似乎并不像它的名字所暗示的那样独特,尽管我正在努力确认这一点,这导致了我的问题。我有一个问题

代码语言:javascript
复制
SELECT unique_booking_reference, count(*) FROM [Bookings-21_dm]
group by unique_booking_reference
having count(*)>1

用于标识任何不是那么唯一的unique_booking_references。但是,结果似乎是以缩写的指数表示法显示的,结果是我不知道查询返回的是哪个unique_booking_references。

代码语言:javascript
复制
5.01E+17 

我在MySQL和Access (Jet-SQL)中都尝试过这个查询。我尝试在每个值的中间插入虚假字符("##"),并在开头插入"%“,这样就不可能将其解释为数值,但这两个SQL仍然返回缩写的指数表示法。

代码语言:javascript
复制
unique_booking_reference    Total  
%5.01E+17## 2  
%5.07E+17## 2  
%5.09E+17## 2  
%5.16E+17## 11  
%5.16E+18## 4  
%5.17E+17## 15  
%5.17E+18## 26  
%5.25E+17## 2  
%5.27E+17## 2  
%5.29E+17## 3  
%5.31E+17## 2 

我也尝试了值的转换,但没有任何进展。我试着用上面给出的值创建一个小表,运行正常,但不能帮助我找出错误所在。

为什么SQL将字符字段解释为数字字段,即使在我插入虚假字符之后?

EN

回答 1

Stack Overflow用户

发布于 2014-03-19 05:30:37

您在哪里查看结果?

我怀疑您是在Excel (或Access)中复制它们,因为我在这些情况下见过这个问题。例如,我无法想象SQL Server Management Studio会进行这种转换。您可以通过在字符串的开头放置一个非数字字符来防止这种情况。

尝试以下版本:

代码语言:javascript
复制
SELECT '''' + unique_booking_reference, count(*)
FROM [Bookings-21_dm]
group by unique_booking_reference
having count(*) > 1;

这将预先添加一个单引号,并应防止任何下游应用程序将该值转换为数字。

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

https://stackoverflow.com/questions/22490213

复制
相关文章

相似问题

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