第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

為什么 SQL Server 返回 0.759999 之類的數(shù)字,而 MySQL 返回 0.76?

為什么 SQL Server 返回 0.759999 之類的數(shù)字,而 MySQL 返回 0.76?

LEATH 2022-06-22 16:28:15
我有一個(gè)包含三列的 SQL Server 數(shù)據(jù)庫表。例如,此列中的一個(gè)值可能是 0.76。這列名為“paramvalue”的數(shù)據(jù)定義為real。當(dāng)我使用 pyodbc 模塊命令時(shí)fetchall(),我得到一個(gè)像 0.7599999904632568 而不是 0.76 的數(shù)字。我正在使用 Visual Studio 2017 和 Visual Studio 的 Python 工具。我也嘗試過 pypyodbc 模塊,但遇到了同樣的問題。該表有三列,定義如下;pconfig_id [int] IDENTITY(41,1) NOT NULL,paramname  [nvarchar](50)       NOT NULL,paramvalue [real]                   NULL我的 Python 代碼:import pyodbccnxn = pyodbc.connect('DRIVER={SQL Server};SERVER=SERVERNAME;DATABASE=DBNAME;UID=USER;PWD=PASSWORD;Connect Timeout=15')cursor = cnxn.cursor()dict = {}rows = cursor.execute("SELECT * FROM mytable")for row in cursor.fetchall() :    if not row[1] in dict.keys():        dict[row[1]] = {}        dict[row[1]][row[2]] = row[0]在上面的示例中,典型行的 row[2] 的值是 0.7599999904632568,而不是預(yù)期的 0.76。
查看完整描述

2 回答

?
海綿寶寶撒

TA貢獻(xiàn)1809條經(jīng)驗(yàn) 獲得超8個(gè)贊

我應(yīng)該提到這個(gè)數(shù)據(jù)庫是從 MySQL 數(shù)據(jù)庫遷移而來的,在這種情況下,類型是浮點(diǎn)數(shù)。當(dāng)我使用 MySQLdb 模塊從該 MySQL 表中獲取數(shù)據(jù)時(shí),它按預(yù)期輸入為 0.76。


這不是由 pyodbc 引起的問題。MySQL 和 MSSQL 的區(qū)別在于浮點(diǎn)數(shù)的顯示方式。


0.76 不是一個(gè)可以精確表示為 32 位浮點(diǎn)(“單精度”)值的值。正如這個(gè)網(wǎng)站(和其他網(wǎng)站)會(huì)告訴你的那樣,這個(gè)數(shù)字的最準(zhǔn)確表示是 7.599999904632568359375E-1,所以這就是兩個(gè)數(shù)據(jù)庫存儲(chǔ)的內(nèi)容(內(nèi)部表示為 0x3F428F5C)。


檢索值時(shí),MSSQL 返回寫入數(shù)據(jù)庫的實(shí)際值。這就是為什么它返回為 0.7599999904632568。


另一方面,MySQL 返回表示浮點(diǎn)值的最短字符串,這將導(dǎo)致給定的存儲(chǔ)值。如文檔中所述:


F -> D 轉(zhuǎn)換以盡可能高的精度完成,將 D 作為最短字符串返回,當(dāng)讀回并四舍五入到 IEEE 指定的本機(jī)二進(jìn)制格式中的最接近值時(shí)產(chǎn)生 F。


因此,MySQL 往返 0.76,因?yàn)樗『檬菍?duì)應(yīng)于內(nèi)部表示為 0x3F428F5C 的浮點(diǎn)值的最短值。這可以通過使用非常接近 0.76 但不完全相等的數(shù)字進(jìn)行測試來說明:


is_mssql = (cnxn.getinfo(pyodbc.SQL_DRIVER_NAME) == 'msodbcsql17.dll')


crsr = cnxn.cursor()


test_value = '0.7599999905'

if is_mssql:

    crsr.execute("CREATE TABLE #foo (x real)")

    crsr.execute(f"INSERT INTO #foo (x) VALUES ('{test_value}')")

    result = crsr.execute("SELECT x FROM #foo").fetchval()

else:

    crsr.execute("CREATE TEMPORARY TABLE foo (x float(23))")

    crsr.execute(f"INSERT INTO foo (x) VALUES ('{test_value}')")

    result = crsr.execute("SELECT x FROM foo").fetchval()

print(f'{"MSSQL" if is_mssql else "MySQL"} returned {result}')

即使 0.7599999905 是“實(shí)際”值,MySQL 仍然返回 0.76,MSSQL 仍然返回 0.7599999904632568。


查看完整回答
反對(duì) 回復(fù) 2022-06-22
?
叮當(dāng)貓咪

TA貢獻(xiàn)1776條經(jīng)驗(yàn) 獲得超12個(gè)贊

查看完整回答
反對(duì) 回復(fù) 2022-06-22
  • 2 回答
  • 0 關(guān)注
  • 127 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)