--- a/displaySupplier.php +++ b/displaySupplier.php @@ -17,14 +17,42 @@ } include_header(str_replace("%", "", $title)); echo '

' . str_replace("%", "", $title) . '

'; + if (isset($supplierABN)) { + echo "ABN: $supplierABN"; + + $cleansedName = '%'.cleanseName($title).'%'; + $query = 'SELECT DISTINCT ON ("supplierABN") "supplierName","supplierABN" FROM contractnotice WHERE "supplierName" ILIKE :cleansedName and "supplierABN" != :supplierABN'; + $query = $conn->prepare($query); + $query->bindParam(":cleansedName", $cleansedName); + $query->bindParam(":supplierABN", $supplierABN); + $query->execute(); + databaseError($conn->errorInfo()); + echo "
Similar to: "; + foreach ($query->fetchAll() as $row) { + echo " {$row['supplierName']} (ABN: {$row['supplierABN']}), "; + } + $query = 'SELECT distinct on (lower("supplierName")) "supplierName" from contractnotice where "supplierABN" = :supplierABN'; $query = $conn->prepare($query); $query->bindParam(":supplierABN", $supplierABN); $query->execute(); databaseError($conn->errorInfo()); - echo "Also known as: ".implode(', ', $query->fetchAll(PDO::FETCH_COLUMN, 0)); + $names = Array(); + foreach ($query->fetchAll() as $row) { + $names[cleanseName($row[0])] = $row[0]; + } + if (count($names) < 20) { + echo "
Also known as: " . implode(', ', array_values($names))."
"; + } else { + echo "
+ Also known as ... +

".implode(', ', array_values($names))."

+
"; + } + } + $query = ' SELECT @@ -83,17 +111,18 @@ echo "
"; - $query = 'SELECT SUM("value") AS "value", count(*), text_mode(contractnotice."agencyName") AS agencyname FROM contractnotice JOIN agency_nametoabn ON contractnotice."agencyName"=agency_nametoabn."agencyName" + /*$query = 'SELECT SUM("value") AS "value", count(*), text_mode(contractnotice."agencyName") AS agencyname FROM contractnotice JOIN agency_nametoabn ON contractnotice."agencyName"=agency_nametoabn."agencyName" WHERE ' . $yearQ . ' ' . $supplierQ . ' "childCN" IS NULL -GROUP BY abn ORDER BY SUM("value") DESC'; - $query = $conn->prepare($query); - if (count($supplierParts) > 0) { +GROUP BY abn ORDER BY SUM("value") DESC';*/ + $query = 'SELECT SUM("value") AS "value", count(*), "agencyName" AS agencyname FROM contractnotice +WHERE ' . $yearQ . ' ' . $supplierQ . ' "childCN" IS NULL GROUP BY "agencyName" ORDER BY SUM("value") DESC'; + + $query = $conn->prepare($query); if (isset($supplierABN)) { $query->bindParam(":supplierABN", $supplierABN); } else { $query->bindParam(":supplierName", $supplierName); } - } $query->execute(); databaseError($conn->errorInfo()); @@ -197,11 +226,15 @@ FROM contractnotice WHERE ' . $yearQ . ' "childCN" IS NULL GROUP BY supplierID,"supplierABN" -ORDER BY val DESC -LIMIT 100'; - $query = $conn->prepare($query); - $query->execute(); - databaseError($conn->errorInfo()); +ORDER BY val DESC'; +if ($yearQ == '') $query .=' LIMIT 1000'; + $query = $conn->prepare($query); + $query->execute(); + databaseError($conn->errorInfo()); +if ($query->rowCount() > 999 && $yearQ == '') { +// if 1000 records warn too many results +print " More than 1000 results found so only first 1000 shown. Please filter by year to see all results "; +} echo "
Position