numeric.slt 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255
  1. # Copyright Materialize, Inc. and contributors. All rights reserved.
  2. #
  3. # Use of this software is governed by the Business Source License
  4. # included in the LICENSE file at the root of this repository.
  5. #
  6. # As of the Change Date specified in that file, in accordance with
  7. # the Business Source License, use of this software will be governed
  8. # by the Apache License, Version 2.0.
  9. # numeric is for refactoring decimal/numeric in parallel development to the main
  10. # branch
  11. mode cockroach
  12. query T
  13. SELECT pg_typeof(0.2)
  14. ----
  15. numeric
  16. # Parsing
  17. query R
  18. SELECT '0.2'::numeric
  19. ----
  20. 0.2
  21. query R
  22. SELECT '-0.2'::numeric
  23. ----
  24. -0.2
  25. query R
  26. SELECT -'0.2'::numeric
  27. ----
  28. -0.2
  29. query R
  30. SELECT '2'::numeric
  31. ----
  32. 2
  33. query R
  34. SELECT '-2'::numeric
  35. ----
  36. -2
  37. query R
  38. SELECT -'2'::numeric
  39. ----
  40. -2
  41. query R
  42. SELECT '20'::numeric
  43. ----
  44. 20
  45. query R
  46. SELECT '-20'::numeric
  47. ----
  48. -20
  49. query R
  50. SELECT '-1.2e20'::numeric
  51. ----
  52. -120000000000000000000
  53. query R
  54. SELECT '1.2e-20'::numeric
  55. ----
  56. 0.000000000000000000012
  57. query R
  58. SELECT '-0.0000001'::numeric(10,2)
  59. ----
  60. 0
  61. query R
  62. SELECT ' 1.2'::numeric
  63. ----
  64. 1.2
  65. query R
  66. SELECT '1.2 '::numeric
  67. ----
  68. 1.2
  69. query error invalid input syntax for type numeric: "1. 2"
  70. SELECT '1. 2'::numeric
  71. query error invalid input syntax for type numeric: "-123abc456"
  72. SELECT '-123abc456'::numeric;
  73. query error invalid input syntax for type numeric: "1. 2"
  74. SELECT '1. 2'::numeric
  75. query error invalid input syntax for type numeric: "-123abc456"
  76. SELECT '-123abc456'::numeric
  77. query error invalid input syntax for type numeric: "e25"
  78. SELECT 'e25'::numeric
  79. query error invalid input syntax for type numeric: "1e"
  80. SELECT '1e'::numeric
  81. query error invalid input syntax for type numeric: "1x25"
  82. SELECT '1x25'::numeric
  83. query error invalid input syntax for type numeric: "!1"
  84. SELECT '!1'::numeric
  85. query error invalid input syntax for type numeric: "--1"
  86. SELECT '--1'::numeric
  87. query error invalid input syntax for type numeric: "-1-"
  88. SELECT '-1-'::numeric
  89. query error invalid input syntax for type numeric: "1-"
  90. SELECT '1-'::numeric
  91. query error invalid input syntax for type numeric: "1..1"
  92. SELECT '1..1'::numeric
  93. query error invalid input syntax for type numeric: "..1"
  94. SELECT '..1'::numeric
  95. query error invalid input syntax for type numeric: "1.1.1"
  96. SELECT '1.1.1'::numeric
  97. query R
  98. SELECT '-0.0'::numeric
  99. ----
  100. 0
  101. # Max precision is 39
  102. query R
  103. SELECT '-123456789012345678.901234567890123456789'::numeric
  104. ----
  105. -123456789012345678.901234567890123456789
  106. query R
  107. SELECT '-0.000000000000000000000000000000000000001'::numeric
  108. ----
  109. -0.000000000000000000000000000000000000001
  110. # However, we'll round fractional component to not exceed 39 digits of precision
  111. query R
  112. SELECT '-123456789012345678.901234567890123456789123'::numeric
  113. ----
  114. -123456789012345678.901234567890123456789
  115. # We won't round non-decimal places, i.e. overflow
  116. query error "-123456789012345678901234567890123456789123" is out of range for type numeric: exceeds maximum precision 39
  117. SELECT '-123456789012345678901234567890123456789123'::numeric
  118. query error "-1.2e40" is out of range for type numeric: exceeds maximum precision 39
  119. SELECT '-1.2e40'::numeric
  120. # If most significant digit is outside of precision bounds, error, i.e. underflow
  121. query error "1.2e-40" is out of range for type numeric: exceeds maximum precision 39
  122. SELECT '1.2e-40'::numeric
  123. # Literals
  124. query R
  125. SELECT 98754321098754321098754321098754321
  126. ----
  127. 98754321098754321098754321098754321
  128. query RRRR
  129. SELECT 9.1e10, -9.1e10, 9.1e-10, -9.1e-10
  130. ----
  131. 91000000000 -91000000000 0.00000000091 -0.00000000091
  132. query RRRRR
  133. SELECT 0.0, 0.00, 0.000, 0.0000, 0.00000
  134. ----
  135. 0 0 0 0 0
  136. query T
  137. SELECT pg_typeof(1e38)
  138. ----
  139. numeric
  140. query error "1E39" is out of range for type numeric: exceeds maximum precision 39
  141. SELECT pg_typeof(1e39)
  142. query error "-1E39" is out of range for type numeric: exceeds maximum precision 39
  143. SELECT pg_typeof(-1e39)
  144. query error "1E-40" is out of range for type numeric: exceeds maximum precision 39
  145. SELECT pg_typeof(1e-40)
  146. query error "-1E-40" is out of range for type numeric: exceeds maximum precision 39
  147. SELECT pg_typeof(-1e-40)
  148. query error "9876543210987654321098765432109876543210" is out of range for type numeric: exceeds maximum precision 39
  149. SELECT 9876543210987654321098765432109876543210
  150. # Special values
  151. query R
  152. SELECT 'NaN'::numeric
  153. ----
  154. NaN
  155. query error invalid input syntax for type numeric: "-NaN"
  156. SELECT '-NaN'::numeric
  157. query error invalid input syntax for type numeric: "Infinity"
  158. SELECT 'Infinity'::numeric
  159. query error invalid input syntax for type numeric: "-Infinity"
  160. SELECT '-Infinity'::numeric
  161. query error invalid input syntax for type numeric: "sNaN"
  162. SELECT 'sNaN'::numeric
  163. # Casts
  164. ## int4 to numeric
  165. query RRR
  166. SELECT 7::numeric, -7::numeric, 0::numeric
  167. ----
  168. 7 -7 0
  169. query RRR
  170. SELECT 7::numeric(39,3), -7::numeric(39,3), 0::numeric(39,3)
  171. ----
  172. 7 -7 0
  173. query RR
  174. SELECT 2147483647::numeric, -2147483648::numeric
  175. ----
  176. 2147483647 -2147483648
  177. query error numeric field overflow
  178. SELECT 12::numeric(39,38)
  179. ## numeric to int4
  180. query III
  181. SELECT 7::numeric::int, 7.3::int, 7.5::int
  182. ----
  183. 7 7 8
  184. query III
  185. SELECT -7::numeric::int, -7.3::int, -7.5::int
  186. ----
  187. -7 -7 -8
  188. query II
  189. SELECT 0::numeric::int, '-0'::numeric::int
  190. ----
  191. 0 0
  192. query error "2147483648" integer out of range
  193. SELECT '2147483648'::numeric::int4
  194. query error "-2147483649" integer out of range
  195. SELECT '-2147483649'::numeric::int4
  196. ## int8 to numeric
  197. query RRR
  198. SELECT 7::int8::numeric, -7::int8::numeric, 0::int8::numeric
  199. ----
  200. 7 -7 0
  201. query RRR
  202. SELECT 7::int8::numeric(39,3), -7::int8::numeric(39,3), 0::int8::numeric(39,3)
  203. ----
  204. 7 -7 0
  205. query RR
  206. SELECT 9223372036854775807::numeric, -9223372036854775808::numeric
  207. ----
  208. 9223372036854775807 -9223372036854775808
  209. query error numeric field overflow
  210. SELECT 12::int8::numeric(39,38)
  211. ## numeric to int8
  212. query III
  213. SELECT 7::numeric::int8, 7.3::int8, 7.5::int8
  214. ----
  215. 7 7 8
  216. query III
  217. SELECT -7::numeric::int8, -7.3::int8, -7.5::int8
  218. ----
  219. -7 -7 -8
  220. query II
  221. SELECT 0::numeric::int8, -0::numeric::int8
  222. ----
  223. 0 0
  224. query error "9223372036854775808" integer out of range
  225. SELECT '9223372036854775808'::numeric::int4
  226. query error "-9223372036854775809" integer out of range
  227. SELECT '-9223372036854775809'::numeric::int4
  228. # numeric to float4
  229. query RRRR
  230. SELECT 1.234::float4, 1234.567891234567::float4, 0.000000000000000123456789123456789012345::float4, -0.000000000000000123456789123456789012345::float4
  231. ----
  232. 1.234 1234.5679 0.00000000000000012345679 -0.00000000000000012345679
  233. query RRR
  234. SELECT 0.000::float4, 3.40282347E+38::float4, -3.40282347E+38::float4
  235. ----
  236. 0 340282350000000000000000000000000000000 -340282350000000000000000000000000000000
  237. query R
  238. SELECT 'NaN'::numeric::float4
  239. ----
  240. NaN
  241. query R
  242. SELECT 9E-39::float4;
  243. ----
  244. 0.000000000000000000000000000000000000009
  245. query error real out of range
  246. SELECT 9E+38::float4
  247. # float4 to numeric
  248. query RRR
  249. SELECT 1.23::float4::numeric, -1.23::float4::numeric, 1.23::float4::numeric(38,1)
  250. ----
  251. 1.23 -1.23 1.2
  252. query RR
  253. SELECT 'NaN'::float4::numeric, '-NaN'::float4::numeric;
  254. ----
  255. NaN NaN
  256. query RR
  257. SELECT '3.40282347E+38'::float4::numeric, '-3.40282347E+38'::float4::numeric
  258. ----
  259. 340282350000000000000000000000000000000 -340282350000000000000000000000000000000
  260. query error function casting real to numeric is only defined for finite arguments
  261. SELECT 'infinity'::float4::numeric
  262. query error numeric field overflow
  263. SELECT '12.34'::float4::numeric(39,38);
  264. # numeric to float8
  265. query RRRR
  266. SELECT 1.234::float8, 1234.567891234567::float8, 0.000000000000000123456789123456789012345::float8, -0.000000000000000123456789123456789012345::float8
  267. ----
  268. 1.234 1234.567891234567 0.00000000000000012345678912345679 -0.00000000000000012345678912345679
  269. query RRR
  270. SELECT 0.000::float8, 3.40282347E+38::float8, -3.40282347E+38::float8
  271. ----
  272. 0 340282347000000000000000000000000000000 -340282347000000000000000000000000000000
  273. query R
  274. SELECT 'NaN'::numeric::float8
  275. ----
  276. NaN
  277. query RR
  278. SELECT 9E-39::float8, 9E+38::float8;
  279. ----
  280. 0.000000000000000000000000000000000000009 900000000000000000000000000000000000000
  281. # float8 to numeric
  282. query RRR
  283. SELECT 1.23::float8::numeric, -1.23::float8::numeric, 1.23::float8::numeric(38,1)
  284. ----
  285. 1.23 -1.23 1.2
  286. query RR
  287. SELECT 'NaN'::float8::numeric, '-NaN'::float8::numeric;
  288. ----
  289. NaN NaN
  290. query RR
  291. SELECT '3.40282347E+38'::float8::numeric, '-3.40282347E+38'::float8::numeric
  292. ----
  293. 340282347000000000000000000000000000000 -340282347000000000000000000000000000000
  294. query error numeric field overflow
  295. SELECT '1.7976931348623157E+308'::float8::numeric
  296. query error numeric field overflow
  297. SELECT '-1.7976931348623157E+308'::float8::numeric
  298. query error function casting double precision to numeric is only defined for finite arguments
  299. SELECT 'infinity'::float8::numeric
  300. query error numeric field overflow
  301. SELECT '12.34'::float8::numeric(39,38);
  302. # jsonb to numeric
  303. # - note that these just defer to other casts, so don't need as-extensive of testing
  304. query R
  305. SELECT ('1'::jsonb)::numeric;
  306. ----
  307. 1
  308. query R
  309. SELECT ('1.2'::jsonb)::numeric;
  310. ----
  311. 1.2
  312. query error cannot cast jsonb string to type numeric
  313. SELECT ('"Infinity"'::jsonb)::numeric;
  314. query error cannot cast jsonb string to type numeric
  315. SELECT ('"-Infinity"'::jsonb)::numeric;
  316. query error cannot cast jsonb string to type numeric
  317. SELECT ('"NaN"'::jsonb)::numeric;
  318. # not a number
  319. query error cannot cast jsonb array to type numeric
  320. SELECT ('[1]'::jsonb)::numeric;
  321. # not a number
  322. query error cannot cast jsonb string to type numeric
  323. SELECT ('"1"'::jsonb)::numeric;
  324. # Addition
  325. query R
  326. SELECT 1::numeric + 2::numeric
  327. ----
  328. 3
  329. query R
  330. SELECT 1.23 + 2.34
  331. ----
  332. 3.57
  333. query R
  334. SELECT 1.23 + -2.34
  335. ----
  336. -1.11
  337. query R
  338. SELECT 1.23 + -2.34
  339. ----
  340. -1.11
  341. query R
  342. SELECT 1.23 + -1.23
  343. ----
  344. 0
  345. query R
  346. SELECT 3402823669209384634633746074317682 + 3402823669209384634633746074317682::numeric
  347. ----
  348. 6805647338418769269267492148635364
  349. query R
  350. SELECT 3402823669209384.634633746074317682 + 3402823669209384.634633746074317682::numeric
  351. ----
  352. 6805647338418769.269267492148635364
  353. # Values rounded to fit precision
  354. query R
  355. SELECT 1e38 + 1e-39
  356. ----
  357. 100000000000000000000000000000000000000
  358. # Limited precision means losing commutativity
  359. query R
  360. SELECT 1e38 + 1e-39 + -1e38
  361. ----
  362. 0
  363. query R
  364. SELECT 1e38 + -1e38 + 1e-39
  365. ----
  366. 0.000000000000000000000000000000000000001
  367. query error value out of range: overflow
  368. SELECT 999999999999999999999999999999999999999 + 1::numeric
  369. query error value out of range: overflow
  370. SELECT 790123449679012344967901234496790123392 + 790123449679012344967901234496790123392::numeric
  371. query R
  372. SELECT 'NaN'::numeric + 2::numeric
  373. ----
  374. NaN
  375. # Subtraction
  376. query R
  377. SELECT 1::numeric - 2::numeric
  378. ----
  379. -1
  380. query R
  381. SELECT 1.23 - 2.34
  382. ----
  383. -1.11
  384. query R
  385. SELECT 1.23 - -2.34
  386. ----
  387. 3.57
  388. query R
  389. SELECT -1.23 - -2.34
  390. ----
  391. 1.11
  392. query R
  393. SELECT -(1.23 - 2.34)
  394. ----
  395. 1.11
  396. query R
  397. SELECT 1.23 - 1.23
  398. ----
  399. 0
  400. query R
  401. SELECT -3402823669209384634633746074317682 - 3402823669209384634633746074317682::numeric
  402. ----
  403. -6805647338418769269267492148635364
  404. query error value out of range: overflow
  405. SELECT -790123449679012344967901234496790123392 - 790123449679012344967901234496790123392::numeric
  406. query R
  407. SELECT 'NaN'::numeric - 2::numeric
  408. ----
  409. NaN
  410. # Limited precision means losing commutativity
  411. query R
  412. SELECT 1e38 - 1e-39 - 1e38
  413. ----
  414. 0
  415. query R
  416. SELECT 1e38 - 1e38 - 1e-39
  417. ----
  418. -0.000000000000000000000000000000000000001
  419. # Multiplication
  420. query R
  421. SELECT 1.1 * 2.2
  422. ----
  423. 2.42
  424. query R
  425. SELECT 1.1 * -2.2
  426. ----
  427. -2.42
  428. query R
  429. SELECT -1.1 * 2.2
  430. ----
  431. -2.42
  432. query R
  433. SELECT -1.1 * -2.2
  434. ----
  435. 2.42
  436. query R
  437. SELECT -1.1 * .2
  438. ----
  439. -0.22
  440. query R
  441. SELECT .1 * -2.2
  442. ----
  443. -0.22
  444. query R
  445. SELECT -(.1 * 2.2)
  446. ----
  447. -0.22
  448. query error value out of range: overflow
  449. SELECT 123456789012345678901234567890123456789 * 10::numeric
  450. query error value out of range: underflow
  451. SELECT 1E-39 * .1
  452. # Results are rounded to 39 digits of precision
  453. query R
  454. SELECT .123456789012345678901234567890123456789 * .1
  455. ----
  456. 0.012345678901234567890123456789012345679
  457. query R
  458. SELECT 3402823669209384.634633746074317682 * 3402823669209384.634633746074317682
  459. ----
  460. 11579208923731619542357098500868.7900057
  461. # known bad behavior in old i128 implementation
  462. query R
  463. SELECT 1.50000000 * 1.50000000
  464. ----
  465. 2.25
  466. query R
  467. SELECT 'NaN'::numeric * 2::numeric
  468. ----
  469. NaN
  470. query R
  471. SELECT 0::numeric * -1::numeric
  472. ----
  473. 0
  474. # Division
  475. query R
  476. SELECT 1::numeric / 2::numeric;
  477. ----
  478. 0.5
  479. query R
  480. SELECT 2.0 / 1;
  481. ----
  482. 2
  483. query R
  484. SELECT 1 / 0.5;
  485. ----
  486. 2
  487. query R
  488. SELECT 2.0 / 1.1;
  489. ----
  490. 1.81818181818181818181818181818181818182
  491. query R
  492. SELECT 1::numeric / 11;
  493. ----
  494. 0.090909090909090909090909090909090909091
  495. query error value out of range: overflow
  496. SELECT 1::numeric / 0.000000000000000000000000000000000000001;
  497. query error value out of range: overflow
  498. SELECT 123456789012345678901234567890123456789 / .1
  499. query error value out of range: underflow
  500. SELECT 1E-39 / 10::numeric
  501. # Round results to 39 digits of precision
  502. query R
  503. SELECT .123456789012345678901234567890123456789 / 10::numeric
  504. ----
  505. 0.012345678901234567890123456789012345679
  506. query R
  507. SELECT 11579208923731619542357098500868.7900057 / 3402823669209384.634633746074317682
  508. ----
  509. 3402823669209384.63463374607431768200001
  510. query error division by zero
  511. SELECT 1::numeric / 0::numeric
  512. query error division by zero
  513. SELECT 1::numeric / 0.0;
  514. query error division by zero
  515. SELECT 1::numeric / (-1::numeric + 1.0);
  516. query error division by zero
  517. SELECT 0::numeric / 0::numeric;
  518. query R
  519. SELECT 1 / 1.21035
  520. ----
  521. 0.826207295410418473995125376957078531003
  522. query R
  523. SELECT 'NaN'::numeric / 2::numeric
  524. ----
  525. NaN
  526. query R
  527. SELECT 2::numeric / 'NaN'::numeric
  528. ----
  529. NaN
  530. query R
  531. SELECT 0::numeric / -1::numeric
  532. ----
  533. 0
  534. # mod
  535. query R
  536. SELECT 3::numeric % 2::numeric
  537. ----
  538. 1
  539. query R
  540. SELECT 23 % 4::numeric
  541. ----
  542. 3
  543. query R
  544. SELECT 4::numeric % 2::numeric
  545. ----
  546. 0
  547. query R
  548. SELECT 17.8 % 4::numeric
  549. ----
  550. 1.8
  551. query R
  552. SELECT 20.1 % 4.1
  553. ----
  554. 3.7
  555. query R
  556. SELECT -16.3 % 4.1
  557. ----
  558. -4
  559. query R
  560. SELECT 20.1 % -4.1
  561. ----
  562. 3.7
  563. query R
  564. SELECT -20.1 % -4.1
  565. ----
  566. -3.7
  567. query R
  568. SELECT 'NaN'::numeric % -4.1
  569. ----
  570. NaN
  571. query R
  572. SELECT -20.1 % 'NaN'::numeric
  573. ----
  574. NaN
  575. query error division by zero
  576. SELECT 2::numeric % 0::numeric
  577. # Specify scale
  578. query R
  579. SELECT 0.2::numeric(39,1);
  580. ----
  581. 0.2
  582. query R
  583. SELECT 0.2::numeric(39,3);
  584. ----
  585. 0.2
  586. query R
  587. SELECT 0.002::numeric(39,1);
  588. ----
  589. 0
  590. query R
  591. SELECT 0.12::numeric(39,2) + 0.2::numeric(39,1);
  592. ----
  593. 0.32
  594. query R
  595. SELECT 0.12::numeric(39,1) + 0.2::numeric(39,2);
  596. ----
  597. 0.3
  598. query R
  599. SELECT (0.12 + 0.2)::numeric(39,3);
  600. ----
  601. 0.32
  602. query R
  603. SELECT (0.12 + 0.2)::numeric(39,1);
  604. ----
  605. 0.3
  606. query R
  607. SELECT 0.12::numeric(39,2) * 0.2::numeric(39,1);
  608. ----
  609. 0.024
  610. query R
  611. SELECT 0.12::numeric(39,1) * 0.2::numeric(39,2);
  612. ----
  613. 0.02
  614. query R
  615. SELECT (0.12 * 0.2)::numeric(39,3);
  616. ----
  617. 0.024
  618. query R
  619. SELECT (0.14 * 0.2)::numeric(39,2);
  620. ----
  621. 0.03
  622. query R
  623. SELECT (0.12 * 0.2)::numeric(39,1);
  624. ----
  625. 0
  626. query R
  627. SELECT 'NaN'::numeric(39,1);
  628. ----
  629. NaN
  630. query error precision for type numeric must be between 1 and 39
  631. SELECT 0.2::numeric(40,1);
  632. query error scale for type numeric must be between 0 and precision 39
  633. SELECT 0.2::numeric(39,40);
  634. query error scale for type numeric must be between 0 and precision 1
  635. SELECT 0.2::numeric(1,39);
  636. query error numeric field overflow
  637. SELECT (12345678901234567890::numeric(39,3) * 12345678901234567890::numeric(39,3))::numeric(39,3);
  638. # Adding a scale "prevents" rounding
  639. ## This value is within range, but requires 37 digits of precision left of the decimal
  640. query R
  641. SELECT 98765432109876543210987654321098765432.109
  642. ----
  643. 98765432109876543210987654321098765432.1
  644. ## When expressly requesting scale of 3, only have 36 digits of precision left of the decimal
  645. query error numeric field overflow
  646. SELECT 98765432109876543210987654321098765432.109::numeric(39,3)
  647. query error numeric field overflow
  648. SELECT 1::numeric(39,39)
  649. ## Multiplication w/ numeric field overflow
  650. query R
  651. SELECT 1234567890123456789.012345 * 1234567890123456789.012345;
  652. ----
  653. 1524157875323883675049533479957338669.12
  654. query error numeric field overflow
  655. SELECT (1234567890123456789.012345 * 1234567890123456789.012345)::numeric(39,3);
  656. ## Addition w/ numeric field overflow
  657. query R
  658. SELECT 999999999999999999999999999999999999.123 + 1::numeric
  659. ----
  660. 1000000000000000000000000000000000000.12
  661. query error numeric field overflow
  662. SELECT (999999999999999999999999999999999999.123 + 1::numeric)::numeric(39,3);
  663. # Successive operations
  664. ## regression test for database-issues#2137
  665. query R
  666. SELECT -0.0 - 1::numeric * '-0.0 '::numeric;
  667. ----
  668. 0
  669. # Negate is nop on NaN and 0
  670. query R
  671. SELECT -'NaN'::numeric;
  672. ----
  673. NaN
  674. query R
  675. SELECT -0::numeric;
  676. ----
  677. 0
  678. query R
  679. SELECT -0.00;
  680. ----
  681. 0
  682. query R
  683. SELECT -(0.1 - 0.10);
  684. ----
  685. 0
  686. # Abs
  687. query R
  688. SELECT abs(-1::numeric);
  689. ----
  690. 1
  691. query R
  692. SELECT abs(-1::numeric);
  693. ----
  694. 1
  695. query R
  696. SELECT abs(-7e-38);
  697. ----
  698. 0.00000000000000000000000000000000000007
  699. query R
  700. SELECT abs(1::numeric - 1e38);
  701. ----
  702. 99999999999999999999999999999999999999
  703. query R
  704. SELECT abs(-0.00);
  705. ----
  706. 0
  707. query R
  708. SELECT abs('NaN'::numeric);
  709. ----
  710. NaN
  711. # round
  712. query RR
  713. SELECT round(1.4), round(1.5)
  714. ----
  715. 1 2
  716. query RR
  717. SELECT round(-1.4), round(-1.5)
  718. ----
  719. -1 -2
  720. query R
  721. SELECT round('NaN'::numeric)
  722. ----
  723. NaN
  724. query R
  725. SELECT round(1.29, 1)
  726. ----
  727. 1.3
  728. query R
  729. SELECT round(1.23, 4)
  730. ----
  731. 1.23
  732. query R
  733. SELECT round(.1234567890123456789012345678901234567890, 1)
  734. ----
  735. 0.1
  736. query R
  737. SELECT round(.1234567890123456789012345678901234567890, 39)
  738. ----
  739. 0.123456789012345678901234567890123456789
  740. query R
  741. SELECT round(.1234567890123456789012345678901234567890, 41)
  742. ----
  743. 0.123456789012345678901234567890123456789
  744. query R
  745. SELECT round(.1234567890123456789012345678901234567, 37)
  746. ----
  747. 0.1234567890123456789012345678901234567
  748. query R
  749. SELECT round(.1234567890123456789012345678901234567, 39)
  750. ----
  751. 0.1234567890123456789012345678901234567
  752. query R
  753. SELECT round(6e38, 39)
  754. ----
  755. 600000000000000000000000000000000000000
  756. query R
  757. SELECT round(19.87, -1)
  758. ----
  759. 20
  760. query R
  761. SELECT round(99.9, -1)
  762. ----
  763. 100
  764. query R
  765. SELECT round(123456789012345.6789012345678901234567890, -7)
  766. ----
  767. 123456790000000
  768. query R
  769. SELECT round(123456789012345.6789012345678901234567890, -16)
  770. ----
  771. 0
  772. query R
  773. SELECT round('5.6e10'::numeric, -10);
  774. ----
  775. 60000000000
  776. query R
  777. SELECT round('5.6e10'::numeric, 10);
  778. ----
  779. 56000000000
  780. query R
  781. SELECT round('9.876e38'::numeric, -37);
  782. ----
  783. 990000000000000000000000000000000000000
  784. # properly rounded value exceeds max precision
  785. query error value out of range: overflow
  786. SELECT round('9.876e38'::numeric, -38);
  787. query error value out of range: overflow
  788. SELECT round(9e38, -39);
  789. # however, if the "place" argument exceeds the number of digits, the result is
  790. # zero
  791. query R
  792. SELECT round(9e38, -40);
  793. ----
  794. 0
  795. query R
  796. SELECT round (-0.10212864, -900)
  797. ----
  798. 0
  799. # ceil
  800. query RRR
  801. SELECT ceil(1.234), ceil(-1.234), ceil('NaN'::numeric)
  802. ----
  803. 2 -1 NaN
  804. query R
  805. SELECT ceil(-0.6);
  806. ----
  807. 0
  808. # floor
  809. query RRR
  810. SELECT floor(1.234), floor(-1.234), floor('NaN'::numeric)
  811. ----
  812. 1 -2 NaN
  813. #trunc
  814. query RRR
  815. SELECT trunc(1.234), trunc(-1.234), trunc('NaN'::numeric)
  816. ----
  817. 1 -1 NaN
  818. query RR
  819. SELECT trunc(0.6), trunc(-0.6)
  820. ----
  821. 0 0
  822. # Exponential calculations
  823. ## Pow
  824. query RR
  825. SELECT pow(2::numeric, 3::numeric), pow(2.5, -3.5)
  826. ----
  827. 8 0.040477154050155255449585837368738797232
  828. query RR
  829. SELECT pow(1::numeric, 9e38), pow(9e38, 1::numeric)
  830. ----
  831. 1 900000000000000000000000000000000000000
  832. query RR
  833. SELECT pow(0::numeric, 0::numeric), pow(0.00, -0.000)
  834. ----
  835. 1 1
  836. query RR
  837. SELECT pow(1::numeric, 9e-39), pow(9e-39, 1::numeric)
  838. ----
  839. 1 0.000000000000000000000000000000000000009
  840. query RR
  841. SELECT pow('NaN'::numeric, -2.5), pow(-2.5, 'NaN'::numeric);
  842. ----
  843. NaN NaN
  844. query error value out of range: overflow
  845. SELECT pow(999::numeric, 9999::numeric);
  846. query error value out of range: overflow
  847. SELECT pow(-2::numeric, 2111176704::numeric)::text;
  848. query error value out of range: underflow
  849. SELECT pow(999::numeric, -9999::numeric);
  850. query error value out of range: underflow
  851. SELECT pow(-2::numeric, -2111176704::numeric)::text;
  852. query error zero raised to a negative power is undefined
  853. SELECT pow(0::numeric, -1::numeric)
  854. query error function pow cannot return complex numbers
  855. SELECT pow(-1::numeric, '-.1'::numeric)
  856. # Square root
  857. query RRR
  858. SELECT sqrt(2::numeric), sqrt(3::numeric), sqrt(0::numeric)
  859. ----
  860. 1.41421356237309504880168872420969807857 1.73205080756887729352744634150587236694 0
  861. query R
  862. SELECT sqrt('.98765432109876543210'::numeric)
  863. ----
  864. 0.993807990055808231173954156543476014651
  865. query RR
  866. SELECT sqrt(9e38), sqrt(9e-39)
  867. ----
  868. 30000000000000000000 0.00000000000000000009486832980505137996
  869. query error cannot take square root of a negative number
  870. SELECT sqrt(-2::numeric)
  871. ## Exp, i.e. e^x
  872. query R
  873. SELECT exp(1::numeric)
  874. ----
  875. 2.71828182845904523536028747135266249776
  876. query R
  877. SELECT exp(2::numeric)
  878. ----
  879. 7.38905609893065022723042746057500781318
  880. query R
  881. SELECT exp(2.0)
  882. ----
  883. 7.38905609893065022723042746057500781318
  884. query R
  885. SELECT exp(-1::numeric)
  886. ----
  887. 0.367879441171442321595523770161460867446
  888. query R
  889. SELECT exp(-1.0)
  890. ----
  891. 0.367879441171442321595523770161460867446
  892. query R
  893. SELECT exp(1.5)
  894. ----
  895. 4.48168907033806482260205546011927581901
  896. query R
  897. SELECT exp('.5'::numeric)
  898. ----
  899. 1.64872127070012814684865078781416357165
  900. query R
  901. SELECT exp('NaN'::numeric)
  902. ----
  903. NaN
  904. query error value out of range: overflow
  905. SELECT exp(50000::numeric)
  906. query error value out of range: underflow
  907. SELECT exp(-50000::numeric)
  908. # Logarithmic calculations
  909. query RRR
  910. SELECT ln(2.0), ln(2.5), ln(5000::numeric)
  911. ----
  912. 0.693147180559945309417232121458176568076 0.91629073187415506518352721176801107145 8.51719319141623742665473369727928026233
  913. query error function ln is not defined for negative numbers
  914. SELECT ln(-100.000)
  915. query error function ln is not defined for zero
  916. SELECT ln(0::numeric)
  917. query RRR
  918. SELECT log(10.0), log(100.000), log(5000::numeric)
  919. ----
  920. 1 2 3.69897000433601880478626110527550697323
  921. query R
  922. SELECT ln(exp(2::numeric))
  923. ----
  924. 2
  925. query error function log10 is not defined for negative numbers
  926. SELECT log(-100.000)
  927. query error function log10 is not defined for zero
  928. SELECT log(0::numeric)
  929. # These results used to end up with some errant digits in the least significant digit.
  930. query R
  931. SELECT log(2::numeric, 64)
  932. ----
  933. 6
  934. query R
  935. SELECT log(4::numeric, 4096);
  936. ----
  937. 6
  938. query R
  939. SELECT log(6::numeric, 279936);
  940. ----
  941. 7
  942. query R
  943. SELECT log(6::numeric, 1679616);
  944. ----
  945. 8
  946. query R
  947. SELECT log(8::numeric, 16777216);
  948. ----
  949. 8
  950. query R
  951. SELECT log(8::numeric, 134217728);
  952. ----
  953. 9
  954. # This result has never been incorrect
  955. query R
  956. SELECT log(2::numeric, 128)
  957. ----
  958. 7
  959. query R
  960. SELECT log(128, 2::numeric)
  961. ----
  962. 0.142857142857142857142857142857142857143
  963. query R
  964. SELECT log(9e38, 1e-39)
  965. ----
  966. -1.00117464716582763094927800807557636035
  967. query R
  968. SELECT log(1e-39, 9e38)
  969. ----
  970. -0.99882673101126474037410399503872386201
  971. query error function log is not defined for zero
  972. SELECT log(0::numeric, 2::numeric)
  973. query error function log is not defined for negative numbers
  974. SELECT log(-1::numeric, 2::numeric)
  975. query error function log is not defined for zero
  976. SELECT log(128, 0::numeric)
  977. query error function log is not defined for negative numbers
  978. SELECT log(128, -1::numeric)
  979. query error division by zero
  980. select log(1::numeric, 2::numeric);
  981. # Equality
  982. # Tests binary combination of values from set {0, 0.00, 1, 1.00, 1.2, -1.00, NaN}
  983. # including self-combinations using each equality operator
  984. query T
  985. SELECT 0::numeric = 0::numeric;
  986. ----
  987. true
  988. query T
  989. SELECT 0::numeric < 0::numeric;
  990. ----
  991. false
  992. query T
  993. SELECT 0::numeric <= 0::numeric;
  994. ----
  995. true
  996. query T
  997. SELECT 0::numeric > 0::numeric;
  998. ----
  999. false
  1000. query T
  1001. SELECT 0::numeric >= 0::numeric;
  1002. ----
  1003. true
  1004. query T
  1005. SELECT 0::numeric <> 0::numeric;
  1006. ----
  1007. false
  1008. query T
  1009. SELECT 0::numeric = 0.00;
  1010. ----
  1011. true
  1012. query T
  1013. SELECT 0::numeric < 0.00;
  1014. ----
  1015. false
  1016. query T
  1017. SELECT 0::numeric <= 0.00;
  1018. ----
  1019. true
  1020. query T
  1021. SELECT 0::numeric > 0.00;
  1022. ----
  1023. false
  1024. query T
  1025. SELECT 0::numeric >= 0.00;
  1026. ----
  1027. true
  1028. query T
  1029. SELECT 0::numeric <> 0.00;
  1030. ----
  1031. false
  1032. query T
  1033. SELECT 0::numeric = 1::numeric;
  1034. ----
  1035. false
  1036. query T
  1037. SELECT 0::numeric < 1::numeric;
  1038. ----
  1039. true
  1040. query T
  1041. SELECT 0::numeric <= 1::numeric;
  1042. ----
  1043. true
  1044. query T
  1045. SELECT 0::numeric > 1::numeric;
  1046. ----
  1047. false
  1048. query T
  1049. SELECT 0::numeric >= 1::numeric;
  1050. ----
  1051. false
  1052. query T
  1053. SELECT 0::numeric <> 1::numeric;
  1054. ----
  1055. true
  1056. query T
  1057. SELECT 0::numeric = 1.00;
  1058. ----
  1059. false
  1060. query T
  1061. SELECT 0::numeric < 1.00;
  1062. ----
  1063. true
  1064. query T
  1065. SELECT 0::numeric <= 1.00;
  1066. ----
  1067. true
  1068. query T
  1069. SELECT 0::numeric > 1.00;
  1070. ----
  1071. false
  1072. query T
  1073. SELECT 0::numeric >= 1.00;
  1074. ----
  1075. false
  1076. query T
  1077. SELECT 0::numeric <> 1.00;
  1078. ----
  1079. true
  1080. query T
  1081. SELECT 0::numeric = 1.2;
  1082. ----
  1083. false
  1084. query T
  1085. SELECT 0::numeric < 1.2;
  1086. ----
  1087. true
  1088. query T
  1089. SELECT 0::numeric <= 1.2;
  1090. ----
  1091. true
  1092. query T
  1093. SELECT 0::numeric > 1.2;
  1094. ----
  1095. false
  1096. query T
  1097. SELECT 0::numeric >= 1.2;
  1098. ----
  1099. false
  1100. query T
  1101. SELECT 0::numeric <> 1.2;
  1102. ----
  1103. true
  1104. query T
  1105. SELECT 0::numeric = -1.00;
  1106. ----
  1107. false
  1108. query T
  1109. SELECT 0::numeric < -1.00;
  1110. ----
  1111. false
  1112. query T
  1113. SELECT 0::numeric <= -1.00;
  1114. ----
  1115. false
  1116. query T
  1117. SELECT 0::numeric > -1.00;
  1118. ----
  1119. true
  1120. query T
  1121. SELECT 0::numeric >= -1.00;
  1122. ----
  1123. true
  1124. query T
  1125. SELECT 0::numeric <> -1.00;
  1126. ----
  1127. true
  1128. query T
  1129. SELECT 0::numeric = 'NaN'::numeric;
  1130. ----
  1131. false
  1132. query T
  1133. SELECT 0::numeric < 'NaN'::numeric;
  1134. ----
  1135. true
  1136. query T
  1137. SELECT 0::numeric <= 'NaN'::numeric;
  1138. ----
  1139. true
  1140. query T
  1141. SELECT 0::numeric > 'NaN'::numeric;
  1142. ----
  1143. false
  1144. query T
  1145. SELECT 0::numeric >= 'NaN'::numeric;
  1146. ----
  1147. false
  1148. query T
  1149. SELECT 0::numeric <> 'NaN'::numeric;
  1150. ----
  1151. true
  1152. query T
  1153. SELECT 0.00 = 0.00;
  1154. ----
  1155. true
  1156. query T
  1157. SELECT 0.00 < 0.00;
  1158. ----
  1159. false
  1160. query T
  1161. SELECT 0.00 <= 0.00;
  1162. ----
  1163. true
  1164. query T
  1165. SELECT 0.00 > 0.00;
  1166. ----
  1167. false
  1168. query T
  1169. SELECT 0.00 >= 0.00;
  1170. ----
  1171. true
  1172. query T
  1173. SELECT 0.00 <> 0.00;
  1174. ----
  1175. false
  1176. query T
  1177. SELECT 0.00 = 1::numeric;
  1178. ----
  1179. false
  1180. query T
  1181. SELECT 0.00 < 1::numeric;
  1182. ----
  1183. true
  1184. query T
  1185. SELECT 0.00 <= 1::numeric;
  1186. ----
  1187. true
  1188. query T
  1189. SELECT 0.00 > 1::numeric;
  1190. ----
  1191. false
  1192. query T
  1193. SELECT 0.00 >= 1::numeric;
  1194. ----
  1195. false
  1196. query T
  1197. SELECT 0.00 <> 1::numeric;
  1198. ----
  1199. true
  1200. query T
  1201. SELECT 0.00 = 1.00;
  1202. ----
  1203. false
  1204. query T
  1205. SELECT 0.00 < 1.00;
  1206. ----
  1207. true
  1208. query T
  1209. SELECT 0.00 <= 1.00;
  1210. ----
  1211. true
  1212. query T
  1213. SELECT 0.00 > 1.00;
  1214. ----
  1215. false
  1216. query T
  1217. SELECT 0.00 >= 1.00;
  1218. ----
  1219. false
  1220. query T
  1221. SELECT 0.00 <> 1.00;
  1222. ----
  1223. true
  1224. query T
  1225. SELECT 0.00 = 1.2;
  1226. ----
  1227. false
  1228. query T
  1229. SELECT 0.00 < 1.2;
  1230. ----
  1231. true
  1232. query T
  1233. SELECT 0.00 <= 1.2;
  1234. ----
  1235. true
  1236. query T
  1237. SELECT 0.00 > 1.2;
  1238. ----
  1239. false
  1240. query T
  1241. SELECT 0.00 >= 1.2;
  1242. ----
  1243. false
  1244. query T
  1245. SELECT 0.00 <> 1.2;
  1246. ----
  1247. true
  1248. query T
  1249. SELECT 0.00 = -1.00;
  1250. ----
  1251. false
  1252. query T
  1253. SELECT 0.00 < -1.00;
  1254. ----
  1255. false
  1256. query T
  1257. SELECT 0.00 <= -1.00;
  1258. ----
  1259. false
  1260. query T
  1261. SELECT 0.00 > -1.00;
  1262. ----
  1263. true
  1264. query T
  1265. SELECT 0.00 >= -1.00;
  1266. ----
  1267. true
  1268. query T
  1269. SELECT 0.00 <> -1.00;
  1270. ----
  1271. true
  1272. query T
  1273. SELECT 0.00 = 'NaN'::numeric;
  1274. ----
  1275. false
  1276. query T
  1277. SELECT 0.00 < 'NaN'::numeric;
  1278. ----
  1279. true
  1280. query T
  1281. SELECT 0.00 <= 'NaN'::numeric;
  1282. ----
  1283. true
  1284. query T
  1285. SELECT 0.00 > 'NaN'::numeric;
  1286. ----
  1287. false
  1288. query T
  1289. SELECT 0.00 >= 'NaN'::numeric;
  1290. ----
  1291. false
  1292. query T
  1293. SELECT 0.00 <> 'NaN'::numeric;
  1294. ----
  1295. true
  1296. query T
  1297. SELECT 1::numeric = 1::numeric;
  1298. ----
  1299. true
  1300. query T
  1301. SELECT 1::numeric < 1::numeric;
  1302. ----
  1303. false
  1304. query T
  1305. SELECT 1::numeric <= 1::numeric;
  1306. ----
  1307. true
  1308. query T
  1309. SELECT 1::numeric > 1::numeric;
  1310. ----
  1311. false
  1312. query T
  1313. SELECT 1::numeric >= 1::numeric;
  1314. ----
  1315. true
  1316. query T
  1317. SELECT 1::numeric <> 1::numeric;
  1318. ----
  1319. false
  1320. query T
  1321. SELECT 1::numeric = 1.00;
  1322. ----
  1323. true
  1324. query T
  1325. SELECT 1::numeric < 1.00;
  1326. ----
  1327. false
  1328. query T
  1329. SELECT 1::numeric <= 1.00;
  1330. ----
  1331. true
  1332. query T
  1333. SELECT 1::numeric > 1.00;
  1334. ----
  1335. false
  1336. query T
  1337. SELECT 1::numeric >= 1.00;
  1338. ----
  1339. true
  1340. query T
  1341. SELECT 1::numeric <> 1.00;
  1342. ----
  1343. false
  1344. query T
  1345. SELECT 1::numeric = 1.2;
  1346. ----
  1347. false
  1348. query T
  1349. SELECT 1::numeric < 1.2;
  1350. ----
  1351. true
  1352. query T
  1353. SELECT 1::numeric <= 1.2;
  1354. ----
  1355. true
  1356. query T
  1357. SELECT 1::numeric > 1.2;
  1358. ----
  1359. false
  1360. query T
  1361. SELECT 1::numeric >= 1.2;
  1362. ----
  1363. false
  1364. query T
  1365. SELECT 1::numeric <> 1.2;
  1366. ----
  1367. true
  1368. query T
  1369. SELECT 1::numeric = -1.00;
  1370. ----
  1371. false
  1372. query T
  1373. SELECT 1::numeric < -1.00;
  1374. ----
  1375. false
  1376. query T
  1377. SELECT 1::numeric <= -1.00;
  1378. ----
  1379. false
  1380. query T
  1381. SELECT 1::numeric > -1.00;
  1382. ----
  1383. true
  1384. query T
  1385. SELECT 1::numeric >= -1.00;
  1386. ----
  1387. true
  1388. query T
  1389. SELECT 1::numeric <> -1.00;
  1390. ----
  1391. true
  1392. query T
  1393. SELECT 1::numeric = 'NaN'::numeric;
  1394. ----
  1395. false
  1396. query T
  1397. SELECT 1::numeric < 'NaN'::numeric;
  1398. ----
  1399. true
  1400. query T
  1401. SELECT 1::numeric <= 'NaN'::numeric;
  1402. ----
  1403. true
  1404. query T
  1405. SELECT 1::numeric > 'NaN'::numeric;
  1406. ----
  1407. false
  1408. query T
  1409. SELECT 1::numeric >= 'NaN'::numeric;
  1410. ----
  1411. false
  1412. query T
  1413. SELECT 1::numeric <> 'NaN'::numeric;
  1414. ----
  1415. true
  1416. query T
  1417. SELECT 1.00 = 1.00;
  1418. ----
  1419. true
  1420. query T
  1421. SELECT 1.00 < 1.00;
  1422. ----
  1423. false
  1424. query T
  1425. SELECT 1.00 <= 1.00;
  1426. ----
  1427. true
  1428. query T
  1429. SELECT 1.00 > 1.00;
  1430. ----
  1431. false
  1432. query T
  1433. SELECT 1.00 >= 1.00;
  1434. ----
  1435. true
  1436. query T
  1437. SELECT 1.00 <> 1.00;
  1438. ----
  1439. false
  1440. query T
  1441. SELECT 1.00 = 1.2;
  1442. ----
  1443. false
  1444. query T
  1445. SELECT 1.00 < 1.2;
  1446. ----
  1447. true
  1448. query T
  1449. SELECT 1.00 <= 1.2;
  1450. ----
  1451. true
  1452. query T
  1453. SELECT 1.00 > 1.2;
  1454. ----
  1455. false
  1456. query T
  1457. SELECT 1.00 >= 1.2;
  1458. ----
  1459. false
  1460. query T
  1461. SELECT 1.00 <> 1.2;
  1462. ----
  1463. true
  1464. query T
  1465. SELECT 1.00 = -1.00;
  1466. ----
  1467. false
  1468. query T
  1469. SELECT 1.00 < -1.00;
  1470. ----
  1471. false
  1472. query T
  1473. SELECT 1.00 <= -1.00;
  1474. ----
  1475. false
  1476. query T
  1477. SELECT 1.00 > -1.00;
  1478. ----
  1479. true
  1480. query T
  1481. SELECT 1.00 >= -1.00;
  1482. ----
  1483. true
  1484. query T
  1485. SELECT 1.00 <> -1.00;
  1486. ----
  1487. true
  1488. query T
  1489. SELECT 1.00 = 'NaN'::numeric;
  1490. ----
  1491. false
  1492. query T
  1493. SELECT 1.00 < 'NaN'::numeric;
  1494. ----
  1495. true
  1496. query T
  1497. SELECT 1.00 <= 'NaN'::numeric;
  1498. ----
  1499. true
  1500. query T
  1501. SELECT 1.00 > 'NaN'::numeric;
  1502. ----
  1503. false
  1504. query T
  1505. SELECT 1.00 >= 'NaN'::numeric;
  1506. ----
  1507. false
  1508. query T
  1509. SELECT 1.00 <> 'NaN'::numeric;
  1510. ----
  1511. true
  1512. query T
  1513. SELECT 1.2 = 1.2;
  1514. ----
  1515. true
  1516. query T
  1517. SELECT 1.2 < 1.2;
  1518. ----
  1519. false
  1520. query T
  1521. SELECT 1.2 <= 1.2;
  1522. ----
  1523. true
  1524. query T
  1525. SELECT 1.2 > 1.2;
  1526. ----
  1527. false
  1528. query T
  1529. SELECT 1.2 >= 1.2;
  1530. ----
  1531. true
  1532. query T
  1533. SELECT 1.2 <> 1.2;
  1534. ----
  1535. false
  1536. query T
  1537. SELECT 1.2 = -1.00;
  1538. ----
  1539. false
  1540. query T
  1541. SELECT 1.2 < -1.00;
  1542. ----
  1543. false
  1544. query T
  1545. SELECT 1.2 <= -1.00;
  1546. ----
  1547. false
  1548. query T
  1549. SELECT 1.2 > -1.00;
  1550. ----
  1551. true
  1552. query T
  1553. SELECT 1.2 >= -1.00;
  1554. ----
  1555. true
  1556. query T
  1557. SELECT 1.2 <> -1.00;
  1558. ----
  1559. true
  1560. query T
  1561. SELECT 1.2 = 'NaN'::numeric;
  1562. ----
  1563. false
  1564. query T
  1565. SELECT 1.2 < 'NaN'::numeric;
  1566. ----
  1567. true
  1568. query T
  1569. SELECT 1.2 <= 'NaN'::numeric;
  1570. ----
  1571. true
  1572. query T
  1573. SELECT 1.2 > 'NaN'::numeric;
  1574. ----
  1575. false
  1576. query T
  1577. SELECT 1.2 >= 'NaN'::numeric;
  1578. ----
  1579. false
  1580. query T
  1581. SELECT 1.2 <> 'NaN'::numeric;
  1582. ----
  1583. true
  1584. query T
  1585. SELECT -1.00 = -1.00;
  1586. ----
  1587. true
  1588. query T
  1589. SELECT -1.00 < -1.00;
  1590. ----
  1591. false
  1592. query T
  1593. SELECT -1.00 <= -1.00;
  1594. ----
  1595. true
  1596. query T
  1597. SELECT -1.00 > -1.00;
  1598. ----
  1599. false
  1600. query T
  1601. SELECT -1.00 >= -1.00;
  1602. ----
  1603. true
  1604. query T
  1605. SELECT -1.00 <> -1.00;
  1606. ----
  1607. false
  1608. query T
  1609. SELECT -1.00 = 'NaN'::numeric;
  1610. ----
  1611. false
  1612. query T
  1613. SELECT -1.00 < 'NaN'::numeric;
  1614. ----
  1615. true
  1616. query T
  1617. SELECT -1.00 <= 'NaN'::numeric;
  1618. ----
  1619. true
  1620. query T
  1621. SELECT -1.00 > 'NaN'::numeric;
  1622. ----
  1623. false
  1624. query T
  1625. SELECT -1.00 >= 'NaN'::numeric;
  1626. ----
  1627. false
  1628. query T
  1629. SELECT -1.00 <> 'NaN'::numeric;
  1630. ----
  1631. true
  1632. query T
  1633. SELECT 'NaN'::numeric = 'NaN'::numeric;
  1634. ----
  1635. true
  1636. query T
  1637. SELECT 'NaN'::numeric < 'NaN'::numeric;
  1638. ----
  1639. false
  1640. query T
  1641. SELECT 'NaN'::numeric <= 'NaN'::numeric;
  1642. ----
  1643. true
  1644. query T
  1645. SELECT 'NaN'::numeric > 'NaN'::numeric;
  1646. ----
  1647. false
  1648. query T
  1649. SELECT 'NaN'::numeric >= 'NaN'::numeric;
  1650. ----
  1651. true
  1652. query T
  1653. SELECT 'NaN'::numeric <> 'NaN'::numeric;
  1654. ----
  1655. false
  1656. # NaN is larger than large numbers
  1657. query T
  1658. SELECT 'NaN'::numeric > 9e38;
  1659. ----
  1660. true
  1661. # Scale doesn't affect equality
  1662. query T
  1663. SELECT 9::numeric(39,5) = 9::numeric;
  1664. ----
  1665. true
  1666. query T
  1667. SELECT 9::numeric(39,5) = 9::numeric(39,10);
  1668. ----
  1669. true
  1670. # Values are rounded before comparison
  1671. query T
  1672. SELECT 123456789012345678901234567890123456789.0 = 123456789012345678901234567890123456789.4999;
  1673. ----
  1674. true
  1675. query T
  1676. SELECT 1.00123::numeric(39,2) = 1::numeric;
  1677. ----
  1678. true
  1679. query T
  1680. SELECT 1.23456789::numeric(39,2) < 1.23456789::numeric(39,3);
  1681. ----
  1682. true
  1683. query T
  1684. SELECT 1.23456789::numeric(39,5) < 1.23456789::numeric(39,4);
  1685. ----
  1686. true
  1687. query R
  1688. select max(a) from (select a from unnest(ARRAY[1.4::numeric(39,5), 1.8::numeric(39,4)]) a);
  1689. ----
  1690. 1.8
  1691. query R
  1692. select min(a) from (select a from unnest(ARRAY[1.4::numeric(39,5), 1.8::numeric(39,4)]) a);
  1693. ----
  1694. 1.4
  1695. query R
  1696. select max(a) from (select a from unnest(ARRAY['NaN'::numeric(39,5), 1.4::numeric(39,5), 1.8::numeric(39,4)]) a);
  1697. ----
  1698. NaN
  1699. query R
  1700. select min(a) from (select a from unnest(ARRAY['NaN'::numeric(39,5), 1.4::numeric(39,5), 1.8::numeric(39,4)]) a);
  1701. ----
  1702. 1.4
  1703. query R
  1704. select max(a) from (select a from unnest(ARRAY[]::numeric[]) a);
  1705. ----
  1706. NULL
  1707. query R
  1708. select min(a) from (select a from unnest(ARRAY[]::numeric[]) a);
  1709. ----
  1710. NULL
  1711. # Distinct, except
  1712. # regression tests for database-issues#2145 database-issues#2152
  1713. query R
  1714. SELECT DISTINCT column1 FROM (
  1715. VALUES
  1716. (0.1),
  1717. (0.10),
  1718. (0.100),
  1719. (0.1000),
  1720. (0.10000)
  1721. );
  1722. ----
  1723. 0.1
  1724. query R
  1725. SELECT column1 FROM (
  1726. SELECT * FROM (
  1727. VALUES (0.1)
  1728. ) EXCEPT ALL
  1729. SELECT * FROM (
  1730. VALUES (0.1000)
  1731. )
  1732. )
  1733. ----
  1734. # regression test for https://github.com/MaterializeInc/database-issues/issues/2298
  1735. statement ok
  1736. CREATE TABLE A (f1 DECIMAL);
  1737. statement ok
  1738. INSERT INTO A VALUES ('-999999999999999999999999999999999999999'), ('-999999999999999999999999999999999999999');
  1739. query R
  1740. SELECT sum(f1) FROM A;
  1741. ----
  1742. -Infinity
  1743. # sqllogictest rounding/truncation behavior.
  1744. #
  1745. # Note: this behavior is called out in the developer docs, so if it ever changes be sure to update
  1746. # those docs.
  1747. query I
  1748. SELECT '1.9'::numeric
  1749. ----
  1750. 2
  1751. query I
  1752. SELECT '1.5'::numeric
  1753. ----
  1754. 2
  1755. query I
  1756. SELECT '1.1'::numeric
  1757. ----
  1758. 1
  1759. mode standard
  1760. # For SQLite compatibility, we truncate Numerics when interpreting as an Int.
  1761. query I
  1762. SELECT '1.9'::numeric
  1763. ----
  1764. 1
  1765. query I
  1766. SELECT '1.5'::numeric
  1767. ----
  1768. 1
  1769. query I
  1770. SELECT '1.1'::numeric
  1771. ----
  1772. 1