Decimal number not showing

There might be a version issue in Metabase.

When I write
SELECT 2/10
it shows 0.00000.

It should show 0.2

Can anyone help here????

I'm using version v1.42.4 Built on 2022-04-07

Hi @shaonyuvi
Most databases would return zero because it's two integers. You can try running the following directly on your database SELECT cast(2/10 as varchar)
You have to do something like SELECT 2::float/10

1 Like

It is not my database issue, because I used sample database for this query.

@shaonyuvi H2 is a database too.

1 Like

This is my query

SELECT(
SELECT COUNT(*) Active_Projects FROM
(SELECT ProjectID, ProjectStatusID, ClientID
FROM project) a
INNER JOIN 
(SELECT ProjectStatusID, ClientID, ProjectStatusName
FROM ProjectStatus) b
ON (a.ProjectStatusID = b.ProjectStatusID AND a.ClientID = b.ClientID)
WHERE ProjectStatusName LIKE '%active%'
AND a.ClientID = 4)
/
(SELECT COUNT(*) Total_Projects
FROM Project
WHERE ClientID=4)

Can you please help me to rewrite it?

@shaonyuvi Just add ::float to the end

SELECT
  (SELECT COUNT(*) Active_Projects
   FROM
     (SELECT ProjectID, ProjectStatusID, ClientID
      FROM project) a
   INNER JOIN
     (SELECT ProjectStatusID, ClientID, ProjectStatusName
      FROM ProjectStatus) b ON (a.ProjectStatusID = b.ProjectStatusID
                                AND a.ClientID = b.ClientID)
   WHERE ProjectStatusName LIKE '%active%'
     AND a.ClientID = 4)
  /
  (SELECT COUNT(*) Total_Projects
   FROM Project
   WHERE ClientID=4)::float

Float to the END is not working,

But this query is working here.

SELECT 2::float/10
It shows 0.2 in result.

This query is not working

@shaonyuvi

Since I have absolutely no idea which database type you are querying, then I don't know.

Post "Diagnostic Info" from Admin > Troubleshooting.

Try searching you database documentation, or use the CAST(... AS FLOAT) function if your database type has that.

Not working,

I'm trying still.

@shaonyuvi Post "Diagnostic Info" from Admin > Troubleshooting.

{
"browser-info": {
"language": "en-US",
"platform": "MacIntel",
"userAgent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.84 Safari/537.36",
"vendor": "Google Inc."
},
"system-info": {
"file.encoding": "UTF-8",
"java.runtime.name": "OpenJDK Runtime Environment",
"java.runtime.version": "11.0.14.1+1",
"java.vendor": "Eclipse Adoptium",
"java.vendor.url": "https://adoptium.net/",
"java.version": "11.0.14.1",
"java.vm.name": "OpenJDK 64-Bit Server VM",
"java.vm.version": "11.0.14.1+1",
"os.name": "Linux",
"os.version": "4.14.262-200.489.amzn2.x86_64",
"user.language": "en",
"user.timezone": "GMT"
},
"metabase-info": {
"databases": [
"sqlserver",
"h2"
],
"hosting-env": "unknown",
"application-database": "postgres",
"application-database-details": {
"database": {
"name": "PostgreSQL",
"version": "11.13"
},
"jdbc-driver": {
"name": "PostgreSQL JDBC Driver",
"version": "42.2.23"
}
},
"run-mode": "prod",
"version": {
"date": "2022-04-07",
"tag": "v1.42.4",
"branch": "release-x.42.x",
"hash": "7c3ce2d"
},
"settings": {
"report-timezone": null
}
}
}

@shaonyuvi https://stackoverflow.com/questions/11719044/how-to-get-a-float-result-by-dividing-two-integer-values-using-t-sql

1 Like

It worked.

Thanks dear.