From 952af410972157f919b7254301a4000a6ec674ac Mon Sep 17 00:00:00 2001
From: Ngoc Khuat <qn.khuat@gmail.com>
Date: Mon, 20 Mar 2023 14:29:48 +0700
Subject: [PATCH] db/select-* to toucan 2 (#29319)

* db/select-one-field -> t2/select-one-fn

* `db/select-field` -> `t2/select-fn-set`

* db/select-ids -> t2/select-pk-set

* db/select-field->field -> t2/select-fn->fn

* db/select-field->id -> t2/select-fn->pk

* `db/select-id->field` -> `t2/select-pk->field`

* add discourage var
---
 .clj-kondo/config.edn                         | 37 +++++++++++--------
 dev/src/dev.clj                               |  1 +
 .../models/permissions/group_manager.clj      |  7 ++--
 .../metabase_enterprise/sandbox/api/user.clj  |  2 +-
 .../metabase_enterprise/sandbox/api/util.clj  |  7 ++--
 .../sandbox/models/params/field_values.clj    |  4 +-
 .../middleware/row_level_restrictions.clj     |  2 +-
 .../serialization/api/serialize.clj           |  4 +-
 .../serialization/v2/extract.clj              |  2 +-
 .../api/group_manager_test.clj                |  4 +-
 .../permissions/block_permissions_test.clj    | 13 ++++---
 .../models/permissions_test.clj               |  4 +-
 .../serialization/load_test.clj               |  2 +-
 .../serialization/v2/backfill_ids_test.clj    |  8 ++--
 .../serialization/v2/e2e_test.clj             |  2 +-
 .../serialization/v2/load_test.clj            |  6 +--
 .../sso/integrations/jwt_test.clj             |  4 +-
 .../sso/integrations/saml_test.clj            |  4 +-
 .../oracle/test/metabase/test/data/oracle.clj |  2 +-
 .../test/metabase/driver/redshift_test.clj    |  4 +-
 src/metabase/api/activity.clj                 | 13 ++++---
 src/metabase/api/collection.clj               |  2 +-
 src/metabase/api/dashboard.clj                | 12 +++---
 src/metabase/api/database.clj                 | 22 +++++------
 src/metabase/api/metric.clj                   |  4 +-
 src/metabase/api/persist.clj                  |  2 +-
 src/metabase/api/table.clj                    |  4 +-
 src/metabase/cmd/rotate_encryption_key.clj    |  7 ++--
 src/metabase/db/data_migrations.clj           |  2 +-
 src/metabase/db/util.clj                      |  2 +-
 src/metabase/driver/sql_jdbc/actions.clj      |  5 ++-
 src/metabase/email/messages.clj               |  9 ++---
 src/metabase/integrations/common.clj          | 11 +++---
 src/metabase/models/card.clj                  |  2 +-
 src/metabase/models/collection.clj            | 22 +++++------
 src/metabase/models/collection/graph.clj      |  7 ++--
 src/metabase/models/dashboard.clj             |  2 +-
 src/metabase/models/database.clj              |  2 +-
 src/metabase/models/field_values.clj          |  4 +-
 src/metabase/models/permissions.clj           | 10 ++---
 src/metabase/models/persisted_info.clj        |  6 +--
 src/metabase/models/pulse_channel.clj         |  6 +--
 src/metabase/models/query/permissions.clj     |  3 +-
 src/metabase/models/setting/cache.clj         |  2 +-
 src/metabase/models/table.clj                 |  6 +--
 src/metabase/models/user.clj                  |  5 ++-
 .../middleware/expand_macros.clj              |  5 ++-
 src/metabase/related.clj                      | 24 ++++++------
 test/metabase/api/card_test.clj               |  2 +-
 test/metabase/api/dashboard_test.clj          |  8 ++--
 test/metabase/api/permissions_test.clj        |  2 +-
 test/metabase/api/table_test.clj              |  2 +-
 .../automagic_dashboards/core_test.clj        |  2 +-
 test/metabase/db/schema_migrations_test.clj   |  4 +-
 test/metabase/driver/mysql_test.clj           |  2 +-
 test/metabase/driver/postgres_test.clj        |  5 +--
 test/metabase/integrations/common_test.clj    |  4 +-
 test/metabase/models/collection_test.clj      | 14 +++----
 test/metabase/models/dashboard_card_test.clj  |  2 +-
 test/metabase/models/permissions_test.clj     |  9 ++---
 test/metabase/models/pulse_channel_test.clj   |  3 +-
 test/metabase/models/pulse_test.clj           |  4 +-
 test/metabase/models/user_test.clj            |  2 +-
 .../middleware/results_metadata_test.clj      |  3 +-
 .../sync/analyze/query_results_test.clj       |  4 +-
 test/metabase/sync/analyze_test.clj           |  2 +-
 .../sync/sync_metadata/comments_test.clj      |  2 +-
 .../fields/sync_instances_test.clj            |  6 +--
 .../sync/sync_metadata/fields_test.clj        |  4 +-
 .../sync/sync_metadata/tables_test.clj        |  5 ++-
 test/metabase/test.clj                        |  5 ++-
 test/metabase/test/data/impl.clj              |  6 +--
 test/metabase/test/util.clj                   |  6 +--
 test/metabase/transforms/core_test.clj        |  3 +-
 74 files changed, 220 insertions(+), 211 deletions(-)

diff --git a/.clj-kondo/config.edn b/.clj-kondo/config.edn
index 1f0f72eb32c..0febc00bf54 100644
--- a/.clj-kondo/config.edn
+++ b/.clj-kondo/config.edn
@@ -123,22 +123,27 @@
     schema.core/either                                                           {:namespaces ["metabase.*"]}}}
 
   :discouraged-var
-  {clojure.core/print        {:message "Use clojure.tools.logging instead of clojure.core/print"}
-   clojure.core/println      {:message "Use clojure.tools.logging instead of clojure.core/println"}
-   clojure.core/printf       {:message "Use clojure.tools.logging instead of clojure.core/printf"}
-   clojure.core/prn          {:message "Use clojure.tools.logging instead of clojure.core/prn"}
-   clojure.core/pr           {:message "Use clojure.tools.logging instead of clojure.core/pr"}
-   clojure.pprint/pprint     {:message "Use clojure.tools.logging instead of clojure.pprint/pprint"}
-   clojure.string/lower-case {:message "Use metabase.util/lower-case-en instead of clojure.string/lower-case"}
-   clojure.string/upper-case {:message "Use metabase.util/upper-case-en instead of clojure.string/upper-case"}
-   honeysql.core/call        {:message "Use hx/call instead because it is Honey SQL 2 friendly"}
-   honeysql.core/raw         {:message "Use hx/raw instead because it is Honey SQL 2 friendly"}
-   java-time/with-clock      {:message "Use mt/with-clock"}
-   toucan.db/select-one-id   {:message "Use toucan.db/select-one-id instead of toucan2.core/select-one-pk"}
-   toucan.db/select-one      {:message "Use toucan.db/select-one instead of toucan2.core/select-one"}
-   toucan.db/select-one-field  {:message "Use t2/select-one-fn instead of toucan.db/select-one-field"}
-   toucan.db/query           {:message "Use mdb.query/query instead of toucan.db/query"}
-   toucan.db/reducible-query {:message "Use mdb.query/reducible-query instead of toucan.db/reducible-query"}}
+  {clojure.core/print            {:message "Use clojure.tools.logging instead of clojure.core/print"}
+   clojure.core/println          {:message "Use clojure.tools.logging instead of clojure.core/println"}
+   clojure.core/printf           {:message "Use clojure.tools.logging instead of clojure.core/printf"}
+   clojure.core/prn              {:message "Use clojure.tools.logging instead of clojure.core/prn"}
+   clojure.core/pr               {:message "Use clojure.tools.logging instead of clojure.core/pr"}
+   clojure.pprint/pprint         {:message "Use clojure.tools.logging instead of clojure.pprint/pprint"}
+   clojure.string/lower-case     {:message "Use metabase.util/lower-case-en instead of clojure.string/lower-case"}
+   clojure.string/upper-case     {:message "Use metabase.util/upper-case-en instead of clojure.string/upper-case"}
+   honeysql.core/call            {:message "Use hx/call instead because it is Honey SQL 2 friendly"}
+   honeysql.core/raw             {:message "Use hx/raw instead because it is Honey SQL 2 friendly"}
+   java-time/with-clock          {:message "Use mt/with-clock"}
+   toucan.db/select-one          {:message "Use toucan.db/select-one instead of toucan2.core/select-one"}
+   toucan.db/select-one-id       {:message "Use toucan.db/select-one-id instead of toucan2.core/select-one-pk"}
+   toucan.db/select-one-field    {:message "Use t2/select-one-fn instead of toucan.db/select-one-field"}
+   toucan.db/select-ids          {:message "Use t2/select-pks-set instead of toucan.db/select-ids"}
+   toucan.db/select-field        {:message "Use t2/select-fn instead of toucan.db/select-field"}
+   toucan.db/select-field->field {:message "Use t2/select-fn->fn instead of toucan.db/select-field->field"}
+   toucan.db/select-field->id    {:message "Use t2/select-fn->pk instead of toucan.db/select-field->id"}
+   toucan.db/select-id->field    {:message "Use t2/select-pk->field instead of toucan.db/select-id->field"}
+   toucan.db/query               {:message "Use mdb.query/query instead of toucan.db/query"}
+   toucan.db/reducible-query     {:message "Use mdb.query/reducible-query instead of toucan.db/reducible-query"}}
 
   :discouraged-namespace
   {clojure.tools.logging {:message "Use metabase.util.log instead of clojure.tools.logging directly"}
diff --git a/dev/src/dev.clj b/dev/src/dev.clj
index ece73f18147..92b723785ab 100644
--- a/dev/src/dev.clj
+++ b/dev/src/dev.clj
@@ -27,6 +27,7 @@
    [methodical.core :as methodical]
    [potemkin :as p]
    [toucan.db :as db]
+   [toucan2.core :as t2]
    [toucan2.connection :as t2.connection]
    [toucan2.pipeline :as t2.pipeline]))
 
diff --git a/enterprise/backend/src/metabase_enterprise/advanced_permissions/models/permissions/group_manager.clj b/enterprise/backend/src/metabase_enterprise/advanced_permissions/models/permissions/group_manager.clj
index ec6ed5a2952..0a839b2ed4d 100644
--- a/enterprise/backend/src/metabase_enterprise/advanced_permissions/models/permissions/group_manager.clj
+++ b/enterprise/backend/src/metabase_enterprise/advanced_permissions/models/permissions/group_manager.clj
@@ -6,7 +6,8 @@
    [metabase.models :refer [PermissionsGroupMembership]]
    [metabase.util :as u]
    [metabase.util.i18n :refer [tru]]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 (defn user-group-memberships
   "Return a list of group memberships a User belongs to.
@@ -40,8 +41,8 @@
       ;; prevent groups manager from update membership of groups that they're not manager of
       (when-not (and api/*is-group-manager?*
                      (set/subset? (set (concat to-remove-group-ids to-add-group-ids))
-                                  (db/select-field :group_id PermissionsGroupMembership
-                                                   :user_id api/*current-user-id* :is_group_manager true)))
+                                  (t2/select-fn-set :group_id PermissionsGroupMembership
+                                                    :user_id api/*current-user-id* :is_group_manager true)))
         (throw (ex-info (tru "Not allowed to edit group memberships")
                         {:status-code 403}))))
     (db/transaction
diff --git a/enterprise/backend/src/metabase_enterprise/sandbox/api/user.clj b/enterprise/backend/src/metabase_enterprise/sandbox/api/user.clj
index 8df8cf18f24..fa6d6a023c0 100644
--- a/enterprise/backend/src/metabase_enterprise/sandbox/api/user.clj
+++ b/enterprise/backend/src/metabase_enterprise/sandbox/api/user.clj
@@ -34,7 +34,7 @@
   []
   (->>
    ;; look at the `login_attributes` for the first 1000 users that have them set. Then make a set of the keys
-   (for [login-attributes (db/select-field :login_attributes User :login_attributes [:not= nil] {:limit 1000})
+   (for [login-attributes (t2/select-fn-set :login_attributes User :login_attributes [:not= nil] {:limit 1000})
          :when (seq login-attributes)]
      (set (keys login-attributes)))
    ;; combine all the sets of attribute keys into a single set
diff --git a/enterprise/backend/src/metabase_enterprise/sandbox/api/util.clj b/enterprise/backend/src/metabase_enterprise/sandbox/api/util.clj
index 4d511131890..4ce8b08d405 100644
--- a/enterprise/backend/src/metabase_enterprise/sandbox/api/util.clj
+++ b/enterprise/backend/src/metabase_enterprise/sandbox/api/util.clj
@@ -9,7 +9,8 @@
    [metabase.models.permissions-group-membership
     :refer [PermissionsGroupMembership]]
    [metabase.util.i18n :refer [tru]]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 (defn- enforce-sandbox?
   "Takes the permission set for each group a user is in, and a sandbox, and determines whether the sandbox should be
@@ -41,10 +42,10 @@
   (boolean
    (when-not *is-superuser?*
      (if *current-user-id*
-       (let [group-ids          (db/select-field :group_id PermissionsGroupMembership :user_id *current-user-id*)
+       (let [group-ids          (t2/select-fn-set :group_id PermissionsGroupMembership :user_id *current-user-id*)
              sandboxes          (when (seq group-ids)
                                   (db/select GroupTableAccessPolicy :group_id [:in group-ids]))]
-           (seq (enforced-sandboxes sandboxes group-ids)))
+         (seq (enforced-sandboxes sandboxes group-ids)))
        ;; If no *current-user-id* is bound we can't check for sandboxes, so we should throw in this case to avoid
        ;; returning `false` for users who should actually be sandboxes.
        (throw (ex-info (str (tru "No current user found"))
diff --git a/enterprise/backend/src/metabase_enterprise/sandbox/models/params/field_values.clj b/enterprise/backend/src/metabase_enterprise/sandbox/models/params/field_values.clj
index 023bd13954a..6b3229916de 100644
--- a/enterprise/backend/src/metabase_enterprise/sandbox/models/params/field_values.clj
+++ b/enterprise/backend/src/metabase_enterprise/sandbox/models/params/field_values.clj
@@ -27,7 +27,7 @@
 (defn- table-id->gtap
   "Find the GTAP for current user that apply to table `table-id`."
   [table-id]
-  (let [group-ids (db/select-field :group_id PermissionsGroupMembership :user_id api/*current-user-id*)
+  (let [group-ids (t2/select-fn-set :group_id PermissionsGroupMembership :user_id api/*current-user-id*)
         gtaps     (db/select GroupTableAccessPolicy
                              :group_id [:in group-ids]
                              :table_id table-id)]
@@ -61,7 +61,7 @@
   (when-let [gtap (table-id->gtap table_id)]
     (let [login-attributes     (:login_attributes @api/*current-user*)
           attribute_remappings (:attribute_remappings gtap)
-          field-ids            (db/select-field :id Field :table_id table_id)]
+          field-ids            (t2/select-fn-set :id Field :table_id table_id)]
       [(:card_id gtap)
        (-> gtap :card :updated_at)
        (if (= :native (get-in gtap [:card :query_type]))
diff --git a/enterprise/backend/src/metabase_enterprise/sandbox/query_processor/middleware/row_level_restrictions.clj b/enterprise/backend/src/metabase_enterprise/sandbox/query_processor/middleware/row_level_restrictions.clj
index 7e7599df7a1..935c7574d01 100644
--- a/enterprise/backend/src/metabase_enterprise/sandbox/query_processor/middleware/row_level_restrictions.clj
+++ b/enterprise/backend/src/metabase_enterprise/sandbox/query_processor/middleware/row_level_restrictions.clj
@@ -73,7 +73,7 @@
 (defn- tables->sandboxes [table-ids]
   (qp.store/cached [*current-user-id* table-ids]
     (let [group-ids           (qp.store/cached *current-user-id*
-                                (db/select-field :group_id PermissionsGroupMembership :user_id *current-user-id*))
+                                (t2/select-fn-set :group_id PermissionsGroupMembership :user_id *current-user-id*))
           sandboxes           (when (seq group-ids)
                                (db/select GroupTableAccessPolicy :group_id [:in group-ids]
                                  :table_id [:in table-ids]))
diff --git a/enterprise/backend/src/metabase_enterprise/serialization/api/serialize.clj b/enterprise/backend/src/metabase_enterprise/serialization/api/serialize.clj
index 0b6ab5f31e5..dd2a5034d72 100644
--- a/enterprise/backend/src/metabase_enterprise/serialization/api/serialize.clj
+++ b/enterprise/backend/src/metabase_enterprise/serialization/api/serialize.clj
@@ -8,7 +8,7 @@
    [metabase.models.collection :refer [Collection]]
    [metabase.util.i18n :refer [tru]]
    [metabase.util.schema :as su]
-   [toucan.db :as db]))
+   [toucan2.core :as t2]))
 
 #_{:clj-kondo/ignore [:deprecated-var]}
 (api/defendpoint-schema POST "/data-model"
@@ -29,7 +29,7 @@
    path           (su/with-api-error-message su/NonBlankString
                     "Valid directory to serialize results to")}
   ;; Make sure all the specified collection IDs exist.
-  (let [existing-collection-ids (db/select-ids Collection :id [:in (set collection_ids)])]
+  (let [existing-collection-ids (t2/select-pks-set Collection :id [:in (set collection_ids)])]
     (when-not (= (set collection_ids) (set existing-collection-ids))
       (throw (ex-info (tru "Invalid Collection ID(s). These Collections do not exist: {0}"
                            (pr-str (set/difference (set collection_ids) (set existing-collection-ids))))
diff --git a/enterprise/backend/src/metabase_enterprise/serialization/v2/extract.clj b/enterprise/backend/src/metabase_enterprise/serialization/v2/extract.clj
index 1609175ba58..901d6e66662 100644
--- a/enterprise/backend/src/metabase_enterprise/serialization/v2/extract.clj
+++ b/enterprise/backend/src/metabase_enterprise/serialization/v2/extract.clj
@@ -90,7 +90,7 @@
         dashboards     (db/select Dashboard :collection_id [:in collection-set])
         ;; All cards that are in this collection set.
         cards          (reduce set/union (for [coll-id collection-set]
-                                           (db/select-ids Card :collection_id coll-id)))
+                                           (t2/select-pks-set Card :collection_id coll-id)))
 
         ;; Map of {dashboard-id #{DashboardCard}} for dashcards whose cards OR parameter-bound cards are outside the
         ;; transitive collection set.
diff --git a/enterprise/backend/test/metabase_enterprise/advanced_permissions/api/group_manager_test.clj b/enterprise/backend/test/metabase_enterprise/advanced_permissions/api/group_manager_test.clj
index d6850ea2614..097b841fa7d 100644
--- a/enterprise/backend/test/metabase_enterprise/advanced_permissions/api/group_manager_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/advanced_permissions/api/group_manager_test.clj
@@ -81,7 +81,7 @@
               (delete-group user 204 true)
 
               (testing "admins could view all groups"
-                (is (= (db/select-field :name PermissionsGroup)
+                (is (= (t2/select-fn-set :name PermissionsGroup)
                        (set (map :name (get-groups :crowberto 200)))))))))))))
 
 (deftest memebership-apis-test
@@ -213,7 +213,7 @@
                                                 :is_group_manager true})))))
 
               (testing "Admin can could view all groups"
-                (is (= (db/select-field :id PermissionsGroup)
+                (is (= (t2/select-fn-set :id PermissionsGroup)
                        (membership->groups-ids (get-membership :crowberto 200))))))))))))
 
 (deftest get-users-api-test
diff --git a/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions/block_permissions_test.clj b/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions/block_permissions_test.clj
index 38c120126d5..e09fd9fdffa 100644
--- a/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions/block_permissions_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions/block_permissions_test.clj
@@ -13,7 +13,8 @@
    [metabase.test :as mt]
    [metabase.util :as u]
    [schema.core :as s]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 ;;;; Graph-related stuff
 
@@ -107,11 +108,11 @@
               (is (= {:schemas :block}
                      (test-db-perms group-id)))
               (is (= #{(perms/database-block-perms-path (mt/id))}
-                     (db/select-field :object Permissions {:where [:and
-                                                                   [:or
-                                                                    [:like :object "/block/%"]
-                                                                    [:like :object "/db/%"]]
-                                                                   [:= :group_id group-id]]}))))))))))
+                     (t2/select-fn-set :object Permissions {:where [:and
+                                                                    [:or
+                                                                     [:like :object "/block/%"]
+                                                                     [:like :object "/db/%"]]
+                                                                    [:= :group_id group-id]]}))))))))))
 
 (deftest update-graph-delete-sandboxes-test
   (testing "When setting `:block` permissions any GTAP rows for that Group/Database should get deleted."
diff --git a/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions_test.clj b/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions_test.clj
index 04a44881aa2..d89833d0eee 100644
--- a/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/advanced_permissions/models/permissions_test.clj
@@ -11,7 +11,7 @@
    [metabase.sync.sync-metadata.tables :as sync-tables]
    [metabase.test :as mt]
    [metabase.util :as u]
-   [toucan.db :as db]))
+   [toucan2.core :as t2]))
 
 ;;; +----------------------------------------------------------------------------------------------------------------+
 ;;; |                                          Download permissions                                                  |
@@ -135,7 +135,7 @@
 
       (testing "If a group has granular download perms for a DB, native download perms are removed when a new table is
               found during sync, since the new table has no download perms"
-        (let [table-ids (db/select-ids 'Table :db_id db-id)
+        (let [table-ids (t2/select-pks-set 'Table :db_id db-id)
               limited-downloads-id  (apply min table-ids)
               graph {:schemas {"PUBLIC"
                                (-> (into {} (for [id table-ids] [id :full]))
diff --git a/enterprise/backend/test/metabase_enterprise/serialization/load_test.clj b/enterprise/backend/test/metabase_enterprise/serialization/load_test.clj
index 895d0deee36..253539630da 100644
--- a/enterprise/backend/test/metabase_enterprise/serialization/load_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/serialization/load_test.clj
@@ -58,7 +58,7 @@
   (into {} (for [model [Database Table Field Metric Segment Collection Dashboard DashboardCard Pulse
                         Card DashboardCardSeries FieldValues Dimension PulseCard PulseChannel User
                         NativeQuerySnippet]]
-             [model (db/select-field :id model)])))
+             [model (t2/select-fn-set :id model)])))
 
 (defmacro with-world-cleanup
   [& body]
diff --git a/enterprise/backend/test/metabase_enterprise/serialization/v2/backfill_ids_test.clj b/enterprise/backend/test/metabase_enterprise/serialization/v2/backfill_ids_test.clj
index 284a8002f94..f63eb127c66 100644
--- a/enterprise/backend/test/metabase_enterprise/serialization/v2/backfill_ids_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/serialization/v2/backfill_ids_test.clj
@@ -19,7 +19,7 @@
                                                 :location (str "/" c2-id "/")}]]
 
       (let [coll-ids [c1-id c2-id c3-id c4-id]
-            all-eids #(db/select-field :entity_id Collection :id [:in coll-ids])]
+            all-eids #(t2/select-fn-set :entity_id Collection :id [:in coll-ids])]
         (testing "all collections have entity_ids"
           (is (every? some? (all-eids))))
 
@@ -39,7 +39,7 @@
       (testing "deleting the entity_id for one of them"
         (db/update! Collection c2-id {:entity_id nil})
         (is (= #{c1-eid nil}
-               (db/select-field :entity_id Collection))))
+               (t2/select-fn-set :entity_id Collection))))
 
       (testing "backfill"
         (serdes.backfill/backfill-ids-for Collection)
@@ -55,14 +55,14 @@
       (testing "deleting the entity_id for one of them"
         (db/update! Collection c2-id {:entity_id nil})
         (is (= #{c1-eid nil}
-               (db/select-field :entity_id Collection))))
+               (t2/select-fn-set :entity_id Collection))))
 
       (testing "backfilling twice"
         (serdes.backfill/backfill-ids-for Collection)
         (let [first-eid (t2/select-one-fn :entity_id Collection :id c2-id)]
           (db/update! Collection c2-id {:entity_id nil})
           (is (= #{c1-eid nil}
-                 (db/select-field :entity_id Collection)))
+                 (t2/select-fn-set :entity_id Collection)))
           (serdes.backfill/backfill-ids-for Collection)
           (testing "produces the same entity_id both times"
             (is (= first-eid (t2/select-one-fn :entity_id Collection :id c2-id)))))))))
diff --git a/enterprise/backend/test/metabase_enterprise/serialization/v2/e2e_test.clj b/enterprise/backend/test/metabase_enterprise/serialization/v2/e2e_test.clj
index 269d912e870..e72022d925a 100644
--- a/enterprise/backend/test/metabase_enterprise/serialization/v2/e2e_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/serialization/v2/e2e_test.clj
@@ -220,7 +220,7 @@
                :pulse-channel-recipient (many-random-fks 40 {} {:pulse_channel_id [:pulse-channel 30]
                                                                 :user_id          [:u 100]})}))
 
-          (is (= 100 (count (db/select-field :email 'User))))
+          (is (= 100 (count (t2/select-fn-set :email 'User))))
 
           (testing "extraction"
             (reset! extraction (into [] (extract/extract-metabase {})))
diff --git a/enterprise/backend/test/metabase_enterprise/serialization/v2/load_test.clj b/enterprise/backend/test/metabase_enterprise/serialization/v2/load_test.clj
index 4db5a5c71db..e8c3dd2d8c1 100644
--- a/enterprise/backend/test/metabase_enterprise/serialization/v2/load_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/serialization/v2/load_test.clj
@@ -165,9 +165,9 @@
 
             (is (= 3 (db/count Database)))
             (is (= #{"db1" "db2" "test-data"}
-                   (db/select-field :name Database)))
+                   (t2/select-fn-set :name Database)))
             (is (= #{(:id @db1d) (:id @db2d)}
-                   (db/select-field :db_id Table :name "posts")))
+                   (t2/select-fn-set :db_id Table :name "posts")))
             (is (db/exists? Table :name "posts" :db_id (:id @db1d)))
             (is (db/exists? Table :name "posts" :db_id (:id @db2d)))))))))
 
@@ -837,7 +837,7 @@
             (is (not= (:id @field2s) (:id @field2d))))
 
           (testing "there are 2 FieldValues defined under fields of table1d"
-            (let [fields (db/select-ids Field :table_id (:id @table1d))]
+            (let [fields (t2/select-pks-set Field :table_id (:id @table1d))]
               (is (= 2 (db/count FieldValues :field_id [:in fields])))))
 
           (testing "existing FieldValues are properly found and updated"
diff --git a/enterprise/backend/test/metabase_enterprise/sso/integrations/jwt_test.clj b/enterprise/backend/test/metabase_enterprise/sso/integrations/jwt_test.clj
index 305289f59d3..93eb47ba541 100644
--- a/enterprise/backend/test/metabase_enterprise/sso/integrations/jwt_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/sso/integrations/jwt_test.clj
@@ -245,8 +245,8 @@
                (#'mt.jwt/group-names->ids ["group_2" "group_3"])))))))
 
 (defn- group-memberships [user-or-id]
-  (when-let [group-ids (seq (db/select-field :group_id PermissionsGroupMembership :user_id (u/the-id user-or-id)))]
-    (db/select-field :name PermissionsGroup :id [:in group-ids])))
+  (when-let [group-ids (seq (t2/select-fn-set :group_id PermissionsGroupMembership :user_id (u/the-id user-or-id)))]
+    (t2/select-fn-set :name PermissionsGroup :id [:in group-ids])))
 
 (deftest login-sync-group-memberships-test
   (testing "login should sync group memberships if enabled"
diff --git a/enterprise/backend/test/metabase_enterprise/sso/integrations/saml_test.clj b/enterprise/backend/test/metabase_enterprise/sso/integrations/saml_test.clj
index feab58ab233..ce7c0cb224c 100644
--- a/enterprise/backend/test/metabase_enterprise/sso/integrations/saml_test.clj
+++ b/enterprise/backend/test/metabase_enterprise/sso/integrations/saml_test.clj
@@ -485,8 +485,8 @@
               (db/delete! User :%lower.email "newuser@metabase.com"))))))))
 
 (defn- group-memberships [user-or-id]
-  (when-let [group-ids (seq (db/select-field :group_id PermissionsGroupMembership :user_id (u/the-id user-or-id)))]
-    (db/select-field :name PermissionsGroup :id [:in group-ids])))
+  (when-let [group-ids (seq (t2/select-fn-set :group_id PermissionsGroupMembership :user_id (u/the-id user-or-id)))]
+    (t2/select-fn-set :name PermissionsGroup :id [:in group-ids])))
 
 (deftest login-should-sync-single-group-membership
   (testing "saml group sync works when there's just a single group, which gets interpreted as a string"
diff --git a/modules/drivers/oracle/test/metabase/test/data/oracle.clj b/modules/drivers/oracle/test/metabase/test/data/oracle.clj
index cec773313ab..3a1059ca52b 100644
--- a/modules/drivers/oracle/test/metabase/test/data/oracle.clj
+++ b/modules/drivers/oracle/test/metabase/test/data/oracle.clj
@@ -139,7 +139,7 @@
         (mdb/setup-db!)                 ; if not already setup
         (when-let [existing-db (t2/select-one Database :engine "oracle", :name database-name)]
           (let [existing-db-id (u/the-id existing-db)
-                all-schemas    (db/select-field :schema Table :db_id existing-db-id)]
+                all-schemas    (t2/select-fn-set :schema Table :db_id existing-db-id)]
             (when-not (= all-schemas #{session-schema})
               (log/warn (u/format-color 'yellow
                                         (str "[oracle] At least one table's schema for the existing '%s' Database"
diff --git a/modules/drivers/redshift/test/metabase/driver/redshift_test.clj b/modules/drivers/redshift/test/metabase/driver/redshift_test.clj
index 08e9eafed74..db316942c0a 100644
--- a/modules/drivers/redshift/test/metabase/driver/redshift_test.clj
+++ b/modules/drivers/redshift/test/metabase/driver/redshift_test.clj
@@ -227,7 +227,7 @@
           ;; sync the schema again to pick up the new view (and table, though we aren't checking that)
           (sync/sync-database! database)
           (is (contains?
-               (db/select-field :name Table :db_id (u/the-id database)) ; the new view should have been synced
+               (t2/select-fn-set :name Table :db_id (u/the-id database)) ; the new view should have been synced
                view-nm))
           (let [table-id (t2/select-one-pk Table :db_id (u/the-id database), :name view-nm)]
             ;; and its columns' :base_type should have been identified correctly
@@ -261,7 +261,7 @@
             qual-view-nm)
            (sync/sync-database! database)
            (is (contains?
-                (db/select-field :name Table :db_id (u/the-id database)) ; the new view should have been synced without errors
+                (t2/select-fn-set :name Table :db_id (u/the-id database)) ; the new view should have been synced without errors
                 view-nm))
            (let [table-id (t2/select-one-pk Table :db_id (u/the-id database), :name view-nm)]
              ;; and its columns' :base_type should have been identified correctly
diff --git a/src/metabase/api/activity.clj b/src/metabase/api/activity.clj
index ea70fcd8274..ad7d9bef366 100644
--- a/src/metabase/api/activity.clj
+++ b/src/metabase/api/activity.clj
@@ -14,7 +14,8 @@
    [metabase.models.view-log :refer [ViewLog]]
    [metabase.util.honey-sql-2 :as h2x]
    [toucan.db :as db]
-   [toucan.hydrate :refer [hydrate]]))
+   [toucan.hydrate :refer [hydrate]]
+   [toucan2.core :as t2]))
 
 (defn- dashcard-activity? [activity]
   (#{:dashboard-add-cards :dashboard-remove-cards}
@@ -43,7 +44,7 @@
   [referenced-objects]
   (merge
    (when-let [card-ids (get referenced-objects "card")]
-     (let [id->dataset?                       (db/select-id->field :dataset Card
+     (let [id->dataset?                       (t2/select-pk->fn :dataset Card
                                                                    :id [:in card-ids])
            {dataset-ids true card-ids' false} (group-by (comp boolean id->dataset?)
                                                         ;; only existing ids go back
@@ -54,10 +55,10 @@
    (into {} (for [[model ids] (dissoc referenced-objects "card")
                   :when       (seq ids)]
               [model (case model
-                       "dashboard" (db/select-ids 'Dashboard, :id [:in ids])
-                       "metric"    (db/select-ids 'Metric,    :id [:in ids], :archived false)
-                       "pulse"     (db/select-ids 'Pulse,     :id [:in ids])
-                       "segment"   (db/select-ids 'Segment,   :id [:in ids], :archived false)
+                       "dashboard" (t2/select-pks-set 'Dashboard, :id [:in ids])
+                       "metric"    (t2/select-pks-set 'Metric,    :id [:in ids], :archived false)
+                       "pulse"     (t2/select-pks-set 'Pulse,     :id [:in ids])
+                       "segment"   (t2/select-pks-set 'Segment,   :id [:in ids], :archived false)
                        nil)])))) ; don't care about other models
 
 (defn- add-model-exists-info
diff --git a/src/metabase/api/collection.clj b/src/metabase/api/collection.clj
index 9e1b21433a3..cc5334ce447 100644
--- a/src/metabase/api/collection.clj
+++ b/src/metabase/api/collection.clj
@@ -899,7 +899,7 @@
   [collection-before-update collection-updates]
   (when (api/column-will-change? :archived collection-before-update collection-updates)
     (when-let [alerts (seq (pulse/retrieve-alerts-for-cards
-                            {:card-ids (db/select-ids Card :collection_id (u/the-id collection-before-update))}))]
+                            {:card-ids (t2/select-pks-set Card :collection_id (u/the-id collection-before-update))}))]
       (api.card/delete-alert-and-notify-archived! alerts))))
 
 #_{:clj-kondo/ignore [:deprecated-var]}
diff --git a/src/metabase/api/dashboard.clj b/src/metabase/api/dashboard.clj
index 8def12c8fa9..9578d3bde0a 100644
--- a/src/metabase/api/dashboard.clj
+++ b/src/metabase/api/dashboard.clj
@@ -182,7 +182,7 @@
   another, and thus do not work as one would expect when used as map keys.)"
   [hashes]
   (when (seq hashes)
-    (into {} (for [[k v] (db/select-field->field :query_hash :average_execution_time Query :query_hash [:in hashes])]
+    (into {} (for [[k v] (t2/select-fn->fn :query_hash :average_execution_time Query :query_hash [:in hashes])]
                {(vec k) v}))))
 
 (defn- add-query-average-duration-to-card
@@ -456,7 +456,7 @@
                                             (remove nil?))
                                       parameter-mappings)]
       (when (seq card-ids)
-        (let [card-id->query        (db/select-id->field :dataset_query Card :id [:in card-ids])
+        (let [card-id->query        (t2/select-pk->fn :dataset_query Card :id [:in card-ids])
               field-ids             (set (for [{:keys [target card-id]} parameter-mappings
                                                :when                    card-id
                                                :let                     [query    (or (card-id->query card-id)
@@ -468,9 +468,9 @@
                                                :when                    field-id]
                                            field-id))
               table-ids             (when (seq field-ids)
-                                      (db/select-field :table_id Field :id [:in field-ids]))
+                                      (t2/select-fn-set :table_id Field :id [:in field-ids]))
               table-id->database-id (when (seq table-ids)
-                                      (db/select-id->field :db_id Table :id [:in table-ids]))]
+                                      (t2/select-pk->fn :db_id Table :id [:in table-ids]))]
           (doseq [table-id table-ids
                   :let     [database-id (table-id->database-id table-id)]]
             ;; check whether we'd actually be able to query this Table (do we have ad-hoc data perms for it?)
@@ -515,7 +515,7 @@
   [dashboard-id]
   (m/map-vals (fn [mappings]
                 (into #{} (map #(select-keys % [:target :parameter_id])) mappings))
-              (db/select-id->field :parameter_mappings DashboardCard :dashboard_id dashboard-id)))
+              (t2/select-pk->fn :parameter_mappings DashboardCard :dashboard_id dashboard-id)))
 
 (defn- check-updated-parameter-mapping-permissions
   "In 0.41.0+ you now require data permissions for the Table in question to add or modify Dashboard parameter mappings.
@@ -533,7 +533,7 @@
                                          (assoc mapping :dashcard-id dashcard-id))
         ;; need to add the appropriate `:card-id` for all the new mappings we're going to check.
         dashcard-id->card-id           (when (seq new-mappings)
-                                         (db/select-id->field :card_id DashboardCard
+                                         (t2/select-pk->fn :card_id DashboardCard
                                            :dashboard_id dashboard-id
                                            :id           [:in (set (map :dashcard-id new-mappings))]))
         new-mappings                   (for [{:keys [dashcard-id], :as mapping} new-mappings]
diff --git a/src/metabase/api/database.clj b/src/metabase/api/database.clj
index 2081cc1289f..9b9f0c77ceb 100644
--- a/src/metabase/api/database.clj
+++ b/src/metabase/api/database.clj
@@ -134,7 +134,7 @@
                    (some-> (driver.u/database->driver db-id) (driver/supports? :nested-queries))
                    (catch Throwable e
                      (log/error e (tru "Error determining whether Database supports nested queries")))))
-               (db/select-ids Database))))
+               (t2/select-pks-set Database))))
 
 (defn- source-query-cards
   "Fetch the Cards that can be used as source queries (e.g. presented as virtual tables). Since Cards can be either
@@ -410,7 +410,7 @@
   {id ms/PositiveInt}
   (api/check-superuser)
   (api/check-404 (db/exists? Database :id id))
-  (let [table-ids (db/select-ids Table :db_id id)]
+  (let [table-ids (t2/select-pks-set Table :db_id id)]
     (first (mdb.query/query
              {:select [:*]
               :from   (for [model database-usage-models
@@ -635,7 +635,7 @@
   [id]
   (api/read-check Database id)
   (let [fields (filter mi/can-read? (-> (db/select [Field :id :name :display_name :table_id :base_type :semantic_type]
-                                          :table_id        [:in (db/select-field :id Table, :db_id id)]
+                                          :table_id        [:in (t2/select-fn-set :id Table, :db_id id)]
                                           :visibility_type [:not-in ["sensitive" "retired"]])
                                         (hydrate :table)))]
     (for [{:keys [id name display_name table base_type semantic_type]} fields]
@@ -1055,11 +1055,11 @@
   "Returns a list of all the schemas found for the database `id`"
   [id]
   (api/read-check Database id)
-  (->> (db/select-field :schema Table
-         :db_id id :active true
-         ;; a non-nil value means Table is hidden -- see [[metabase.models.table/visibility-types]]
-         :visibility_type nil
-         {:order-by [[:%lower.schema :asc]]})
+  (->> (t2/select-fn-set :schema Table
+                         :db_id id :active true
+                         ;; a non-nil value means Table is hidden -- see [[metabase.models.table/visibility-types]]
+                         :visibility_type nil
+                         {:order-by [[:%lower.schema :asc]]})
        (filter (partial can-read-schema? id))
        ;; for `nil` schemas return the empty string
        (map #(if (nil? %) "" %))
@@ -1124,7 +1124,7 @@
           :card
           :additional-constraints [(if (= schema (api.table/root-collection-schema-name))
                                      [:= :collection_id nil]
-                                     [:in :collection_id (api/check-404 (not-empty (db/select-ids Collection :name schema)))])])
+                                     [:in :collection_id (api/check-404 (not-empty (t2/select-pks-set Collection :name schema)))])])
          (map api.table/card->virtual-table))))
 
 (api/defendpoint GET ["/:virtual-db/datasets/:schema"
@@ -1136,7 +1136,7 @@
           :dataset
           :additional-constraints [(if (= schema (api.table/root-collection-schema-name))
                                      [:= :collection_id nil]
-                                     [:in :collection_id (api/check-404 (not-empty (db/select-ids Collection :name schema)))])])
+                                     [:in :collection_id (api/check-404 (not-empty (t2/select-pks-set Collection :name schema)))])])
          (map api.table/card->virtual-table))))
 
 (api/defendpoint GET "/db-ids-with-deprecated-drivers"
@@ -1149,6 +1149,6 @@
       (let [info (driver.u/available-drivers-info)
             d    (driver.u/database->driver database)]
         (some? (:superseded-by (d info)))))
-    (db/select-ids Database))))
+    (t2/select-pks-set Database))))
 
 (api/define-routes)
diff --git a/src/metabase/api/metric.clj b/src/metabase/api/metric.clj
index 7ece0ccec14..c3979e31469 100644
--- a/src/metabase/api/metric.clj
+++ b/src/metabase/api/metric.clj
@@ -64,7 +64,7 @@
   "Add `:database_id` fields to `metrics` by looking them up from their `:table_id`."
   [metrics]
   (when (seq metrics)
-    (let [table-id->db-id (db/select-id->field :db_id Table, :id [:in (set (map :table_id metrics))])]
+    (let [table-id->db-id (t2/select-pk->fn :db_id Table, :id [:in (set (map :table_id metrics))])]
       (for [metric metrics]
         (assoc metric :database_id (table-id->db-id (:table_id metric)))))))
 
@@ -126,7 +126,7 @@
   (api/write-check Metric id)
   (api/check (<= (count important_field_ids) 3)
     [400 "A Metric can have a maximum of 3 important fields."])
-  (let [[fields-to-remove fields-to-add] (data/diff (set (db/select-field :field_id 'MetricImportantField :metric_id id))
+  (let [[fields-to-remove fields-to-add] (data/diff (set (t2/select-fn-set :field_id 'MetricImportantField :metric_id id))
                                                     (set important_field_ids))]
 
     ;; delete old fields as needed
diff --git a/src/metabase/api/persist.clj b/src/metabase/api/persist.clj
index a3d6de812df..5702ac6ef65 100644
--- a/src/metabase/api/persist.clj
+++ b/src/metabase/api/persist.clj
@@ -64,7 +64,7 @@
   "List the entries of [[PersistedInfo]] in order to show a status page."
   []
   (validation/check-has-application-permission :monitoring)
-  (let [db-ids (db/select-field :database_id PersistedInfo)
+  (let [db-ids (t2/select-fn-set :database_id PersistedInfo)
         writable-db-ids (when (seq db-ids)
                           (->> (db/select Database :id [:in db-ids])
                                (filter mi/can-write?)
diff --git a/src/metabase/api/table.clj b/src/metabase/api/table.clj
index 951b7721b97..34555c36652 100644
--- a/src/metabase/api/table.clj
+++ b/src/metabase/api/table.clj
@@ -414,7 +414,7 @@
   [id]
   {id ms/PositiveInt}
   (api/read-check Table id)
-  (when-let [field-ids (seq (db/select-ids Field, :table_id id, :visibility_type [:not= "retired"], :active true))]
+  (when-let [field-ids (seq (t2/select-pks-set Field, :table_id id, :visibility_type [:not= "retired"], :active true))]
     (for [origin-field (db/select Field, :fk_target_field_id [:in field-ids], :active true)]
       ;; it's silly to be hydrating some of these tables/dbs
       {:relationship   :Mt1
@@ -445,7 +445,7 @@
   [id]
   {id ms/PositiveInt}
   (api/write-check (t2/select-one Table :id id))
-  (when-let [field-ids (db/select-ids Field :table_id id)]
+  (when-let [field-ids (t2/select-pks-set Field :table_id id)]
     (db/simple-delete! FieldValues :field_id [:in field-ids]))
   {:status :success})
 
diff --git a/src/metabase/cmd/rotate_encryption_key.clj b/src/metabase/cmd/rotate_encryption_key.clj
index 268e52e521e..a90cded0ff3 100644
--- a/src/metabase/cmd/rotate_encryption_key.clj
+++ b/src/metabase/cmd/rotate_encryption_key.clj
@@ -10,7 +10,6 @@
    [metabase.util.encryption :as encryption]
    [metabase.util.i18n :refer [trs]]
    [metabase.util.log :as log]
-   [toucan.db :as db]
    [toucan2.core :as t2]))
 
 (defn rotate-encryption-key!
@@ -34,14 +33,14 @@
                             "setting.\"KEY\" = ?"
                             "setting.key = ?")]
     (t2/with-transaction [t-conn {:datasource (mdb.connection/data-source)}]
-      (doseq [[id details] (db/select-id->field :details Database)]
+      (doseq [[id details] (t2/select-pk->fn :details Database)]
         (when (encryption/possibly-encrypted-string? details)
           (throw (ex-info (trs "Can''t decrypt app db with MB_ENCRYPTION_SECRET_KEY") {:database-id id})))
         (jdbc/update! {:connection t-conn}
                       :metabase_database
                       {:details (encrypt-str-fn (json/encode details))}
                       ["metabase_database.id = ?" id]))
-      (doseq [[key value] (db/select-field->field :key :value Setting)]
+      (doseq [[key value] (t2/select-fn->fn :key :value Setting)]
         (if (= key "settings-last-updated")
           (setting.cache/update-settings-last-updated!)
           (jdbc/update! {:connection t-conn}
@@ -52,7 +51,7 @@
       ;; fortunately, we don't need to fetch the latest secret instance per ID, as we would need to in order to update
       ;; a secret value through the regular database save API path; instead, ALL secret values in the app DB (regardless
       ;; of whether they are the "current version" or not), should be updated with the new key
-      (doseq [[id value] (db/select-id->field :value Secret)]
+      (doseq [[id value] (t2/select-pk->fn :value Secret)]
         (when (encryption/possibly-encrypted-string? value)
           (throw (ex-info (trs "Can''t decrypt secret value with MB_ENCRYPTION_SECRET_KEY") {:secret-id id})))
         (jdbc/update! {:connection t-conn}
diff --git a/src/metabase/db/data_migrations.clj b/src/metabase/db/data_migrations.clj
index d0c0c2bc548..e35385de4d2 100644
--- a/src/metabase/db/data_migrations.clj
+++ b/src/metabase/db/data_migrations.clj
@@ -63,7 +63,7 @@
   "Run all data migrations defined by `defmigration`."
   []
   (log/info "Running all necessary data migrations, this may take a minute.")
-  (let [ran-migrations (db/select-ids DataMigrations)]
+  (let [ran-migrations (t2/select-pks-set DataMigrations)]
     (doseq [migration @data-migrations]
       (run-migration-if-needed! ran-migrations migration)))
   (log/info "Finished running data migrations."))
diff --git a/src/metabase/db/util.clj b/src/metabase/db/util.clj
index bc67f9f032d..c6719ff2717 100644
--- a/src/metabase/db/util.clj
+++ b/src/metabase/db/util.clj
@@ -10,7 +10,7 @@
 (defn join
   "Convenience for generating a HoneySQL `JOIN` clause.
 
-     (db/select-ids FieldValues
+     (t2/select-pks-set FieldValues
        (mdb/join [FieldValues :field_id] [Field :id])
        :active true)"
   [[source-entity fk] [dest-entity pk]]
diff --git a/src/metabase/driver/sql_jdbc/actions.clj b/src/metabase/driver/sql_jdbc/actions.clj
index d5dcc91a65a..6fbbe4fbeae 100644
--- a/src/metabase/driver/sql_jdbc/actions.clj
+++ b/src/metabase/driver/sql_jdbc/actions.clj
@@ -21,7 +21,8 @@
    [metabase.util.i18n :refer [trs tru]]
    [metabase.util.log :as log]
    [schema.core :as s]
-   [toucan.db :as db])
+   [toucan.db :as db]
+   [toucan2.core :as t2])
   (:import
    (java.sql Connection PreparedStatement)))
 
@@ -387,7 +388,7 @@
 (defn- table-id->pk-field-name->id
   "Given a `table-id` return a map of string Field name -> Field ID for the primary key columns for that Table."
   [table-id]
-  (db/select-field->id :name Field
+  (t2/select-fn->pk :name Field
     {:where [:and
              [:= :table_id table-id]
              (mdb.u/isa :semantic_type :type/PK)]}))
diff --git a/src/metabase/email/messages.clj b/src/metabase/email/messages.clj
index 31b22566373..7f8aaa2c432 100644
--- a/src/metabase/email/messages.clj
+++ b/src/metabase/email/messages.clj
@@ -36,7 +36,6 @@
    [metabase.util.urls :as urls]
    [stencil.core :as stencil]
    [stencil.loader :as stencil-loader]
-   [toucan.db :as db]
    [toucan2.core :as t2])
   (:import
    (java.io File IOException OutputStream)
@@ -138,7 +137,7 @@
   []
   (concat (when-let [admin-email (public-settings/admin-email)]
             [admin-email])
-          (db/select-field :email 'User, :is_superuser true, :is_active true, {:order-by [[:id :asc]]})))
+          (t2/select-fn-set :email 'User, :is_superuser true, :is_active true, {:order-by [[:id :asc]]})))
 
 (defn send-user-joined-admin-notification-email!
   "Send an email to the `invitor` (the Admin who invited `new-user`) letting them know `new-user` has joined."
@@ -236,9 +235,9 @@
       (concat
         (all-admin-recipients)
         (when (seq user-ids)
-          (db/select-field :email User {:where [:and
-                                                [:= :is_active true]
-                                                [:in :id user-ids]]}))))))
+          (t2/select-fn-set :email User {:where [:and
+                                                 [:= :is_active true]
+                                                 [:in :id user-ids]]}))))))
 
 (defn send-persistent-model-error-email!
   "Format and send an email informing the user about errors in the persistent model refresh task."
diff --git a/src/metabase/integrations/common.clj b/src/metabase/integrations/common.clj
index 63507aed10a..827e7527b87 100644
--- a/src/metabase/integrations/common.clj
+++ b/src/metabase/integrations/common.clj
@@ -10,7 +10,8 @@
    [metabase.util :as u]
    [metabase.util.i18n :refer [trs]]
    [metabase.util.log :as log]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 (defn sync-group-memberships!
   "Update the PermissionsGroups a User belongs to, adding or deleting membership entries as needed so that Users is
@@ -20,10 +21,10 @@
         excluded-group-ids #{(u/the-id (perms-group/all-users))}
         user-id            (u/the-id user-or-id)
         current-group-ids  (when (seq mapped-group-ids)
-                             (db/select-field :group_id PermissionsGroupMembership
-                                              :user_id  user-id
-                                              :group_id [:in mapped-group-ids]
-                                              :group_id [:not-in excluded-group-ids]))
+                             (t2/select-fn-set :group_id PermissionsGroupMembership
+                                               :user_id  user-id
+                                               :group_id [:in mapped-group-ids]
+                                               :group_id [:not-in excluded-group-ids]))
         new-group-ids      (set/intersection (set (map u/the-id new-groups-or-ids))
                                              mapped-group-ids)
         ;; determine what's different between current mapped groups and new mapped groups
diff --git a/src/metabase/models/card.clj b/src/metabase/models/card.clj
index 7f52388f068..6b6606aad7a 100644
--- a/src/metabase/models/card.clj
+++ b/src/metabase/models/card.clj
@@ -329,7 +329,7 @@
 (defn- disable-implicit-action-for-model!
   "Delete all implicit actions of a model if exists."
   [model-id]
-  (when-let [action-ids (t2/select-pks-set 'Action {:select [:action.id]
+  (when-let [action-ids (t2/select-pks-set  'Action {:select [:action.id]
                                                     :from   [:action]
                                                     :join   [:implicit_action
                                                              [:= :action.id :implicit_action.action_id]]
diff --git a/src/metabase/models/collection.clj b/src/metabase/models/collection.clj
index f42c07afbcf..29a87a74729 100644
--- a/src/metabase/models/collection.clj
+++ b/src/metabase/models/collection.clj
@@ -473,7 +473,7 @@
 (s/defn descendant-ids :- (s/maybe #{su/IntGreaterThanZero})
   "Return a set of IDs of all descendant Collections of a `collection`."
   [collection :- CollectionWithLocationAndIDOrRoot]
-  (db/select-ids Collection :location [:like (str (children-location collection) \%)]))
+  (t2/select-pks-set Collection :location [:like (str (children-location collection) \%)]))
 
 (s/defn ^:private effective-children-where-clause
   [collection & additional-honeysql-where-clauses]
@@ -564,7 +564,7 @@
                            (parent collection)
                            (cons
                             collection
-                            (db/select-ids Collection :location [:like (str (children-location collection) "%")])))]
+                            (t2/select-pks-set Collection :location [:like (str (children-location collection) "%")])))]
      (perms/collection-readwrite-path collection-or-id))))
 
 (s/defn perms-for-moving :- #{perms/PathSchema}
@@ -616,7 +616,7 @@
 
 (s/defn ^:private collection->descendant-ids :- (s/maybe #{su/IntGreaterThanZero})
   [collection :- CollectionWithLocationAndIDOrRoot, & additional-conditions]
-  (apply db/select-ids Collection
+  (apply t2/select-pks-set Collection
          :location [:like (str (children-location collection) "%")]
          additional-conditions))
 
@@ -687,10 +687,10 @@
   and write perms for every Group with write perms for the source Collection."
   [source-collection-or-id dest-collections-or-ids]
   ;; figure out who has permissions for the source Collection...
-  (let [group-ids-with-read-perms  (db/select-field :group_id Permissions
-                                     :object (perms/collection-read-path source-collection-or-id))
-        group-ids-with-write-perms (db/select-field :group_id Permissions
-                                     :object (perms/collection-readwrite-path source-collection-or-id))]
+  (let [group-ids-with-read-perms  (t2/select-fn-set :group_id Permissions
+                                                     :object (perms/collection-read-path source-collection-or-id))
+        group-ids-with-write-perms (t2/select-fn-set :group_id Permissions
+                                                     :object (perms/collection-readwrite-path source-collection-or-id))]
     ;; ...and insert corresponding rows for each destination Collection
     (db/insert-many! Permissions
       (concat
@@ -984,11 +984,11 @@
 
 (defmethod serdes/descendants "Collection" [_model-name id]
   (let [location    (t2/select-one-fn :location Collection :id id)
-        child-colls (set (for [child-id (db/select-ids Collection {:where [:like :location (str location id "/%")]})]
+        child-colls (set (for [child-id (t2/select-pks-set Collection {:where [:like :location (str location id "/%")]})]
                            ["Collection" child-id]))
-        dashboards  (set (for [dash-id (db/select-ids 'Dashboard :collection_id id)]
+        dashboards  (set (for [dash-id (t2/select-pks-set 'Dashboard :collection_id id)]
                            ["Dashboard" dash-id]))
-        cards       (set (for [card-id (db/select-ids 'Card      :collection_id id)]
+        cards       (set (for [card-id (t2/select-pks-set 'Card      :collection_id id)]
                            ["Card" card-id]))]
     (set/union child-colls dashboards cards)))
 
@@ -1135,7 +1135,7 @@
   [users]
   (when (seq users)
     ;; efficiently create a map of user ID -> personal collection ID
-    (let [user-id->collection-id (db/select-field->id :personal_owner_id Collection
+    (let [user-id->collection-id (t2/select-fn->pk :personal_owner_id Collection
                                    :personal_owner_id [:in (set (map u/the-id users))])]
       (assert (map? user-id->collection-id))
       ;; now for each User, try to find the corresponding ID out of that map. If it's not present (the personal
diff --git a/src/metabase/models/collection/graph.clj b/src/metabase/models/collection/graph.clj
index ea039b1c04a..df6105b4a46 100644
--- a/src/metabase/models/collection/graph.clj
+++ b/src/metabase/models/collection/graph.clj
@@ -14,7 +14,8 @@
    [metabase.util.honey-sql-2 :as h2x]
    [metabase.util.schema :as su]
    [schema.core :as s]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 ;;; +----------------------------------------------------------------------------------------------------------------+
 ;;; |                                               PERMISSIONS GRAPH                                                |
@@ -60,7 +61,7 @@
   "Return a set of IDs of all Collections that are neither Personal Collections nor descendants of Personal
   Collections (i.e., things that you can set Permissions for, and that should go in the graph.)"
   [collection-namespace :- (s/maybe su/KeywordOrString)]
-  (let [personal-collection-ids (db/select-ids Collection :personal_owner_id [:not= nil])
+  (let [personal-collection-ids (t2/select-pks-set Collection :personal_owner_id [:not= nil])
         honeysql-form           {:select [[:id :id]]
                                  :from   [:collection]
                                  :where  (into [:and
@@ -76,7 +77,7 @@
   ([collection-ids collection-namespace]
    (let [group-id->perms (group-id->permissions-set)]
      {:revision (c-perm-revision/latest-id)
-      :groups   (into {} (for [group-id (db/select-ids PermissionsGroup)]
+      :groups   (into {} (for [group-id (t2/select-pks-set PermissionsGroup)]
                            {group-id (group-permissions-graph collection-namespace
                                                               (group-id->perms group-id)
                                                               collection-ids)}))})))
diff --git a/src/metabase/models/dashboard.clj b/src/metabase/models/dashboard.clj
index b0b25caa822..9a816bfd242 100644
--- a/src/metabase/models/dashboard.clj
+++ b/src/metabase/models/dashboard.clj
@@ -122,7 +122,7 @@
                                       set)
             cards-to-add         (set/difference correct-card-ids stale-card-ids)
             card-id->dashcard-id (when (seq cards-to-add)
-                                   (db/select-field->id :card_id DashboardCard :dashboard_id dashboard-id
+                                   (t2/select-fn->pk :card_id DashboardCard :dashboard_id dashboard-id
                                                         :card_id [:in cards-to-add]))
             positions-for        (fn [pulse-id] (drop (pulse-card/next-position-for pulse-id)
                                                       (range)))
diff --git a/src/metabase/models/database.clj b/src/metabase/models/database.clj
index 72ba23e5347..da1bfa63e0f 100644
--- a/src/metabase/models/database.clj
+++ b/src/metabase/models/database.clj
@@ -252,7 +252,7 @@
 (defn pk-fields
   "Return all the primary key `Fields` associated with this `database`."
   [{:keys [id]}]
-  (let [table-ids (db/select-ids 'Table, :db_id id, :active true)]
+  (let [table-ids (t2/select-pks-set 'Table, :db_id id, :active true)]
     (when (seq table-ids)
       (db/select 'Field, :table_id [:in table-ids], :semantic_type (mdb.u/isa :type/PK)))))
 
diff --git a/src/metabase/models/field_values.clj b/src/metabase/models/field_values.clj
index f7ff0ca9bce..7849082ad4f 100644
--- a/src/metabase/models/field_values.clj
+++ b/src/metabase/models/field_values.clj
@@ -421,9 +421,9 @@
   [table-ids]
   (let [table-ids            (set table-ids)
         table-id->db-id      (when (seq table-ids)
-                               (db/select-id->field :db_id 'Table :id [:in table-ids]))
+                               (t2/select-pk->fn :db_id 'Table :id [:in table-ids]))
         db-id->is-on-demand? (when (seq table-id->db-id)
-                               (db/select-id->field :is_on_demand 'Database
+                               (t2/select-pk->fn :is_on_demand 'Database
                                  :id [:in (set (vals table-id->db-id))]))]
     (into {} (for [table-id table-ids]
                [table-id (-> table-id table-id->db-id db-id->is-on-demand?)]))))
diff --git a/src/metabase/models/permissions.clj b/src/metabase/models/permissions.clj
index 110af250be2..ff561c74cbb 100644
--- a/src/metabase/models/permissions.clj
+++ b/src/metabase/models/permissions.clj
@@ -874,7 +874,7 @@
                            v2 permissions
   "
   []
-  (let [db-ids             (delay (db/select-ids 'Database))
+  (let [db-ids             (delay (t2/select-pks-set 'Database))
         group-id->v1-paths (->> (permissions-by-group-ids [:or
                                                            [:= :object (h2x/literal "/")]
                                                            [:like :object (h2x/literal "%/db/%")]])
@@ -901,7 +901,7 @@
                  |-----------------------------------|
                            v2 permissions"
   []
-  (let [db-ids             (delay (db/select-ids 'Database))
+  (let [db-ids             (delay (t2/select-pks-set 'Database))
         group-id->v2-paths (->> (permissions-by-group-ids [:or
                                                            [:= :object (h2x/literal "/")]
                                                            [:like :object (h2x/literal "%/db/%")]])
@@ -964,7 +964,7 @@
                               [:like path (h2x/concat :object (h2x/literal "%"))]
                               [:like :object (str path "%")]]
                              other-conditions)}]
-    (when-let [revoked (db/select-field :object Permissions where)]
+    (when-let [revoked (t2/select-fn-set :object Permissions where)]
       (log/debug (u/format-color 'red "Revoking permissions for group %d: %s" (u/the-id group-or-id) revoked))
       (db/delete! Permissions where))))
 
@@ -1150,7 +1150,7 @@
 
 (defn- download-permissions-set
   [group-id]
-  (db/select-field :object
+  (t2/select-fn-set :object
                    [Permissions :object]
                    {:where [:and
                             [:= :group_id group-id]
@@ -1186,7 +1186,7 @@
   they are upgraded to EE."
   [group-id :- su/IntGreaterThanZero db-id :- su/IntGreaterThanZero]
   (let [permissions-set (download-permissions-set group-id)
-        table-ids-and-schemas (db/select-id->field :schema 'Table :db_id db-id :active [:= true])
+        table-ids-and-schemas (t2/select-pk->fn :schema 'Table :db_id db-id :active [:= true])
         native-perm-level (reduce (fn [lowest-seen-perm-level [table-id table-schema]]
                                     (let [table-perm-level (download-permissions-level permissions-set
                                                                                        db-id
diff --git a/src/metabase/models/persisted_info.clj b/src/metabase/models/persisted_info.clj
index 4fc198bb00b..c14c46e245b 100644
--- a/src/metabase/models/persisted_info.clj
+++ b/src/metabase/models/persisted_info.clj
@@ -75,9 +75,9 @@
   "Hydrate a card :is_persisted for the frontend."
   [cards]
   (when (seq cards)
-    (let [existing-ids (db/select-field :card_id PersistedInfo
-                                        :card_id [:in (map :id cards)]
-                                        :state [:not-in ["off" "deletable"]])]
+    (let [existing-ids (t2/select-fn-set :card_id PersistedInfo
+                                         :card_id [:in (map :id cards)]
+                                         :state [:not-in ["off" "deletable"]])]
       (map (fn [{id :id :as card}]
              (assoc card :persisted (contains? existing-ids id)))
            cards))))
diff --git a/src/metabase/models/pulse_channel.clj b/src/metabase/models/pulse_channel.clj
index 6077370b10a..38cb7ba82d5 100644
--- a/src/metabase/models/pulse_channel.clj
+++ b/src/metabase/models/pulse_channel.clj
@@ -174,7 +174,7 @@
       ;; be sneaky and pass in a valid User ID but different email so they can send test Pulses out to arbitrary email
       ;; addresses
       (when-let [user-ids (not-empty (into #{} (comp (filter some?) (map :id)) user-recipients))]
-        (let [user-id->email (db/select-id->field :email User, :id [:in user-ids])]
+        (let [user-id->email (t2/select-pk->fn :email User, :id [:in user-ids])]
           (doseq [{:keys [id email]} user-recipients
                   :let               [correct-email (get user-id->email id)]]
             (when-not correct-email
@@ -273,7 +273,7 @@
   {:pre [(integer? id)
          (coll? user-ids)
          (every? integer? user-ids)]}
-  (let [recipients-old (set (db/select-field :user_id PulseChannelRecipient, :pulse_channel_id id))
+  (let [recipients-old (set (t2/select-fn-set :user_id PulseChannelRecipient, :pulse_channel_id id))
         recipients-new (set user-ids)
         recipients+    (set/difference recipients-new recipients-old)
         recipients-    (set/difference recipients-old recipients-new)]
@@ -379,7 +379,7 @@
                                   :let [id (t2/select-one-pk 'User :email email)]]
                               (or id
                                   (:id (user/serdes-synthesize-user! {:email email})))))
-        current-users  (set (db/select-field :user_id PulseChannelRecipient :pulse_channel_id channel-id))
+        current-users  (set (t2/select-fn-set :user_id PulseChannelRecipient :pulse_channel_id channel-id))
         combined       (set/union incoming-users current-users)]
     (when-not (empty? combined)
       (update-recipients! channel-id combined))))
diff --git a/src/metabase/models/query/permissions.clj b/src/metabase/models/query/permissions.clj
index bb171831ced..b322722c5ef 100644
--- a/src/metabase/models/query/permissions.clj
+++ b/src/metabase/models/query/permissions.clj
@@ -15,7 +15,6 @@
    [metabase.util.log :as log]
    [metabase.util.schema :as su]
    [schema.core :as s]
-   [toucan.db :as db]
    [toucan2.core :as t2]))
 
 ;;; ---------------------------------------------- Permissions Checking ----------------------------------------------
@@ -83,7 +82,7 @@
            native-perms-fn]} :- PermsOptions]
   (let [table-ids           (filter integer? tables-or-ids)
         table-id->schema    (when (seq table-ids)
-                              (db/select-id->field :schema Table :id [:in table-ids]))
+                              (t2/select-pk->fn :schema Table :id [:in table-ids]))
         table-or-id->schema #(if (integer? %)
                                (table-id->schema %)
                                (:schema %))
diff --git a/src/metabase/models/setting/cache.clj b/src/metabase/models/setting/cache.clj
index 84e7916ff5b..85416cf86ff 100644
--- a/src/metabase/models/setting/cache.clj
+++ b/src/metabase/models/setting/cache.clj
@@ -138,7 +138,7 @@
   "Populate cache with the latest hotness from the db"
   []
   (log/debug (trs "Refreshing Settings cache..."))
-  (reset! (cache*) (db/select-field->field :key :value 'Setting)))
+  (reset! (cache*) (t2/select-fn->fn :key :value 'Setting)))
 
 (defonce ^:private ^ReentrantLock restore-cache-lock (ReentrantLock.))
 
diff --git a/src/metabase/models/table.clj b/src/metabase/models/table.clj
index f41c4b6648a..557b208c716 100644
--- a/src/metabase/models/table.clj
+++ b/src/metabase/models/table.clj
@@ -113,7 +113,7 @@
 (defn- valid-field-order?
   "Field ordering is valid if all the fields from a given table are present and only from that table."
   [table field-ordering]
-  (= (db/select-ids Field
+  (= (t2/select-pks-set Field
        :table_id (u/the-id table)
        :active   true)
      (set field-ordering)))
@@ -146,12 +146,12 @@
   :field_values
   "Return the FieldValues for all Fields belonging to a single `table`."
   [{:keys [id]}]
-  (let [field-ids (db/select-ids Field
+  (let [field-ids (t2/select-pks-set Field
                     :table_id        id
                     :visibility_type "normal"
                     {:order-by field-order-rule})]
     (when (seq field-ids)
-      (db/select-field->field :field_id :values FieldValues, :field_id [:in field-ids]))))
+      (t2/select-fn->fn :field_id :values FieldValues, :field_id [:in field-ids]))))
 
 (mi/define-simple-hydration-method ^{:arglists '([table])} pk-field-id
   :pk_field
diff --git a/src/metabase/models/user.clj b/src/metabase/models/user.clj
index 62aafc93e1a..b5cc7154314 100644
--- a/src/metabase/models/user.clj
+++ b/src/metabase/models/user.clj
@@ -22,7 +22,8 @@
    [metabase.util.schema :as su]
    [schema.core :as schema]
    [toucan.db :as db]
-   [toucan.models :as models])
+   [toucan.models :as models]
+   [toucan2.core :as t2])
   (:import
    (java.util UUID)))
 
@@ -172,7 +173,7 @@
   "Fetch set of IDs of PermissionsGroup a User belongs to."
   [user-or-id]
   (when user-or-id
-    (db/select-field :group_id PermissionsGroupMembership :user_id (u/the-id user-or-id))))
+    (t2/select-fn-set :group_id PermissionsGroupMembership :user_id (u/the-id user-or-id))))
 
 (def UserGroupMembership
   "Group Membership info of a User.
diff --git a/src/metabase/query_processor/middleware/expand_macros.clj b/src/metabase/query_processor/middleware/expand_macros.clj
index 979e6cfdeee..666f668c55b 100644
--- a/src/metabase/query_processor/middleware/expand_macros.clj
+++ b/src/metabase/query_processor/middleware/expand_macros.clj
@@ -17,7 +17,8 @@
    [metabase.util.log :as log]
    [metabase.util.schema :as su]
    [schema.core :as s]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 ;;; +----------------------------------------------------------------------------------------------------------------+
 ;;; |                                                    SEGMENTS                                                    |
@@ -25,7 +26,7 @@
 
 (defn- segment-clauses->id->definition [segment-clauses]
   (when-let [segment-ids (seq (filter integer? (map second segment-clauses)))]
-    (db/select-id->field :definition Segment, :id [:in (set segment-ids)])))
+    (t2/select-pk->fn :definition Segment, :id [:in (set segment-ids)])))
 
 (defn- replace-segment-clauses [outer-query segment-id->definition]
   (mbql.u/replace-in outer-query [:query]
diff --git a/src/metabase/related.clj b/src/metabase/related.clj
index f2278cf7689..e01b5c437d0 100644
--- a/src/metabase/related.clj
+++ b/src/metabase/related.clj
@@ -117,7 +117,7 @@
 
 (defn- linking-to
   [table]
-  (->> (db/select-field :fk_target_field_id Field
+  (->> (t2/select-fn-set :fk_target_field_id Field
          :table_id           (:id table)
          :fk_target_field_id [:not= nil]
          :active             true)
@@ -130,10 +130,10 @@
 
 (defn- linked-from
   [table]
-  (if-let [fields (not-empty (db/select-field :id Field
-                               :table_id (:id table)
-                               :active   true))]
-    (->> (db/select-field :table_id Field
+  (if-let [fields (not-empty (t2/select-fn-set :id Field
+                                               :table_id (:id table)
+                                               :active   true))]
+    (->> (t2/select-fn-set :table_id Field
            :fk_target_field_id [:in fields]
            :active             true)
          (map (partial t2/select-one Table :id))
@@ -143,11 +143,11 @@
 
 (defn- cards-sharing-dashboard
   [card]
-  (if-let [dashboards (not-empty (db/select-field :dashboard_id DashboardCard
-                                   :card_id (:id card)))]
-    (->> (db/select-field :card_id DashboardCard
-           :dashboard_id [:in dashboards]
-           :card_id      [:not= (:id card)])
+  (if-let [dashboards (not-empty (t2/select-fn-set :dashboard_id DashboardCard
+                                                   :card_id (:id card)))]
+    (->> (t2/select-fn-set :card_id DashboardCard
+                           :dashboard_id [:in dashboards]
+                           :card_id      [:not= (:id card)])
          (map (partial t2/select-one Card :id))
          filter-visible
          (take max-matches))
@@ -307,8 +307,8 @@
 
 (defmethod related Dashboard
   [dashboard]
-  (let [cards (map (partial t2/select-one Card :id) (db/select-field :card_id DashboardCard
-                                                      :dashboard_id (:id dashboard)))]
+  (let [cards (map (partial t2/select-one Card :id) (t2/select-fn-set :card_id DashboardCard
+                                                                      :dashboard_id (:id dashboard)))]
     {:cards (->> cards
                  (mapcat (comp similar-questions))
                  (remove (set cards))
diff --git a/test/metabase/api/card_test.clj b/test/metabase/api/card_test.clj
index cd2ee9193b6..fdaed1e3e8d 100644
--- a/test/metabase/api/card_test.clj
+++ b/test/metabase/api/card_test.clj
@@ -1754,7 +1754,7 @@
     (let [cards               (db/select [Card :collection_id] :id [:in (map u/the-id cards-or-card-ids)])
           collection-ids      (set (filter identity (map :collection_id cards)))
           collection-id->name (when (seq collection-ids)
-                                (db/select-id->field :name Collection :id [:in collection-ids]))]
+                                (t2/select-pk->fn :name Collection :id [:in collection-ids]))]
       (for [card cards]
         (get collection-id->name (:collection_id card))))))
 
diff --git a/test/metabase/api/dashboard_test.clj b/test/metabase/api/dashboard_test.clj
index 7bbeaa738e2..aeef9af35ca 100644
--- a/test/metabase/api/dashboard_test.clj
+++ b/test/metabase/api/dashboard_test.clj
@@ -1152,7 +1152,7 @@
         (let [copy-id (u/the-id (mt/user-http-request :rasta :post 200 (format "dashboard/%d/copy" dashboard-id)))]
           (try
             (is (= 2
-                   (count (db/select-ids DashboardCard, :dashboard_id copy-id))))
+                   (count (t2/select-pks-set DashboardCard, :dashboard_id copy-id))))
             (is (=? [{:name "Category ID" :slug "category_id" :id "_CATEGORY_ID_" :type :category}]
                    (t2/select-one-fn :parameters Dashboard :id copy-id)))
             (is (=? [{:parameter_id "random-id"
@@ -1256,7 +1256,7 @@
                  (map (partial into {})
                       (db/select [DashboardCard :size_x :size_y :col :row], :dashboard_id dashboard-id))))
           (is (= #{0}
-                 (db/select-field :position DashboardCardSeries, :dashboardcard_id (:id dashboard-card)))))))))
+                 (t2/select-fn-set :position DashboardCardSeries, :dashboardcard_id (:id dashboard-card)))))))))
 
 (defn do-with-add-card-parameter-mapping-permissions-fixtures [f]
   (mt/with-temp-copy-of-db
@@ -1383,12 +1383,12 @@
                     DashboardCardSeries [_                 {:dashboardcard_id dashcard-id, :card_id series-id-2, :position 1}]]
       (with-dashboards-in-writeable-collection [dashboard-id]
         (is (= 1
-               (count (db/select-ids DashboardCard, :dashboard_id dashboard-id))))
+               (count (t2/select-pks-set DashboardCard, :dashboard_id dashboard-id))))
         (is (= nil
                (mt/user-http-request :rasta :delete 204
                                      (format "dashboard/%d/cards" dashboard-id) :dashcardId dashcard-id)))
         (is (= 0
-               (count (db/select-ids DashboardCard, :dashboard_id dashboard-id))))))))
+               (count (t2/select-pks-set DashboardCard, :dashboard_id dashboard-id))))))))
 
 
 ;;; +----------------------------------------------------------------------------------------------------------------+
diff --git a/test/metabase/api/permissions_test.clj b/test/metabase/api/permissions_test.clj
index c77dae7da0b..d12b781a48b 100644
--- a/test/metabase/api/permissions_test.clj
+++ b/test/metabase/api/permissions_test.clj
@@ -319,7 +319,7 @@
                         :user_id su/IntGreaterThanZero
                         :is_group_manager s/Bool}]}
                      result))
-        (is (= (db/select-field :id 'User) (set (keys result))))))))
+        (is (= (t2/select-fn-set :id 'User) (set (keys result))))))))
 
 (deftest add-group-membership-test
   (testing "POST /api/permissions/membership"
diff --git a/test/metabase/api/table_test.clj b/test/metabase/api/table_test.clj
index 2c4874f15de..59dbd36fd4b 100644
--- a/test/metabase/api/table_test.clj
+++ b/test/metabase/api/table_test.clj
@@ -518,7 +518,7 @@
                   :dimension_options (default-dimension-options)
                   :fields            (map (comp #(merge (default-card-field-for-venues card-virtual-table-id) %)
                                                 with-field-literal-id)
-                                          (let [id->fingerprint   (db/select-id->field :fingerprint Field :table_id (mt/id :venues))
+                                          (let [id->fingerprint   (t2/select-pk->fn :fingerprint Field :table_id (mt/id :venues))
                                                 name->fingerprint (comp id->fingerprint (partial mt/id :venues))]
                                             [{:name           "NAME"
                                               :display_name   "NAME"
diff --git a/test/metabase/automagic_dashboards/core_test.clj b/test/metabase/automagic_dashboards/core_test.clj
index e700c5ec143..6075eb931f3 100644
--- a/test/metabase/automagic_dashboards/core_test.clj
+++ b/test/metabase/automagic_dashboards/core_test.clj
@@ -109,7 +109,7 @@
     (mt/with-test-user :rasta
       (automagic-dashboards.test/with-dashboard-cleanup
         (doseq [field (db/select Field
-                                 :table_id [:in (db/select-field :id Table :db_id (mt/id))]
+                                 :table_id [:in (t2/select-fn-set :id Table :db_id (mt/id))]
                                  :visibility_type "normal"
                                  {:order-by [[:id :asc]]})]
           (is (pos? (count (:ordered_cards (magic/automagic-analysis field {})))))))))
diff --git a/test/metabase/db/schema_migrations_test.clj b/test/metabase/db/schema_migrations_test.clj
index 75596e8631e..cab3e4f9752 100644
--- a/test/metabase/db/schema_migrations_test.clj
+++ b/test/metabase/db/schema_migrations_test.clj
@@ -829,12 +829,12 @@
         (is (= #{"F1 D1"
                  "F1 D2"
                  "F2 D1"}
-               (db/select-field :name Dimension {:order-by [[:id :asc]]})))
+               (t2/select-fn-set :name Dimension {:order-by [[:id :asc]]})))
         (migrate!)
         (testing "Keep the newest Dimensions"
           (is (= #{"F1 D2"
                    "F2 D1"}
-                 (db/select-field :name Dimension {:order-by [[:id :asc]]}))))))))
+                 (t2/select-fn-set :name Dimension {:order-by [[:id :asc]]}))))))))
 
 (deftest clean-up-gtap-table-test
   (testing "Migrations v46.00-064 to v46.00-067: rename `group_table_access_policy` table, add `permission_id` FK,
diff --git a/test/metabase/driver/mysql_test.clj b/test/metabase/driver/mysql_test.clj
index 9c1c43167a5..bffb4792f1d 100644
--- a/test/metabase/driver/mysql_test.clj
+++ b/test/metabase/driver/mysql_test.clj
@@ -126,7 +126,7 @@
      ["Empty Vending Machine" 0]]]])
 
 (defn- db->fields [db]
-  (let [table-ids (db/select-ids Table :db_id (u/the-id db))]
+  (let [table-ids (t2/select-pks-set Table :db_id (u/the-id db))]
     (set (map (partial into {}) (db/select [Field :name :base_type :semantic_type] :table_id [:in table-ids])))))
 
 (deftest tiny-int-1-test
diff --git a/test/metabase/driver/postgres_test.clj b/test/metabase/driver/postgres_test.clj
index 721491a0ab2..8e0337d5634 100644
--- a/test/metabase/driver/postgres_test.clj
+++ b/test/metabase/driver/postgres_test.clj
@@ -939,10 +939,9 @@
                                                      :percent-email  0.0
                                                      :percent-state  0.0
                                                      :average-length 12.0}}}}
-                 (db/select-field->field :name :fingerprint Field
+                 (t2/select-fn->fn :name :fingerprint Field
                    :table_id (t2/select-one-pk Table :db_id (u/the-id database))))))))))
 
-
 ;;; ----------------------------------------------------- Other ------------------------------------------------------
 
 (deftest exception-test
@@ -1010,7 +1009,7 @@
         (mt/with-temp Database [database {:engine :postgres, :details test-user-details}]
           (sync/sync-database! database)
           (is (= #{"table_with_perms"}
-                 (db/select-field :name Table :db_id (:id database)))))))))
+                 (t2/select-fn-set :name Table :db_id (:id database)))))))))
 
 (deftest json-operator-?-works
   (testing "Make sure the Postgres ? operators (for JSON types) work in native queries"
diff --git a/test/metabase/integrations/common_test.clj b/test/metabase/integrations/common_test.clj
index eee954ee9c0..2e83a217756 100644
--- a/test/metabase/integrations/common_test.clj
+++ b/test/metabase/integrations/common_test.clj
@@ -21,8 +21,8 @@
 (defn- group-memberships
   "Return set of names of PermissionsGroups `user` currently belongs to."
   [user]
-  (when-let [group-ids (seq (db/select-field :group_id PermissionsGroupMembership :user_id (u/the-id user)))]
-    (db/select-field :name PermissionsGroup :id [:in group-ids])))
+  (when-let [group-ids (seq (t2/select-fn-set :group_id PermissionsGroupMembership :user_id (u/the-id user)))]
+    (t2/select-fn-set :name PermissionsGroup :id [:in group-ids])))
 
 (deftest sync-groups-test
   (testing "does syncing group memberships leave existing memberships in place if nothing has changed?"
diff --git a/test/metabase/models/collection_test.clj b/test/metabase/models/collection_test.clj
index 2c6d93202c8..a4f7446f0ac 100644
--- a/test/metabase/models/collection_test.clj
+++ b/test/metabase/models/collection_test.clj
@@ -187,7 +187,7 @@
   (when (seq path)
     (let [ids      (collection/location-path->ids path)
           id->name (when (seq ids)
-                     (db/select-field->field :id :name Collection :id [:in ids]))]
+                     (t2/select-fn->fn :id :name Collection :id [:in ids]))]
       ;; now loop through each ID and replace the ID part like (ex. /10/) with a name (ex. /A/)
       (loop [path path, [id & more] ids]
         (if-not id
@@ -1110,12 +1110,12 @@
   ;; we can reuse the `perms-path-ids->names` helper function from above, just need to stick `collection` in a map
   ;; to simulate the output of the `with-collection-hierarchy` macro
   (perms-path-ids->names
-   (zipmap (map :name collections)
-           collections)
-   (db/select-field :object Permissions
-                    {:where [:and
-                             [:like :object "/collection/%"]
-                             [:= :group_id (u/the-id perms-group)]]})))
+    (zipmap (map :name collections)
+            collections)
+    (t2/select-fn-set :object Permissions
+                      {:where [:and
+                               [:like :object "/collection/%"]
+                               [:= :group_id (u/the-id perms-group)]]})))
 
 (deftest copy-root-collection-perms-test
   (testing (str "Make sure that when creating a new Collection at the Root Level, we copy the group permissions for "
diff --git a/test/metabase/models/dashboard_card_test.clj b/test/metabase/models/dashboard_card_test.clj
index 7bd1f8b03c0..70c935124d9 100644
--- a/test/metabase/models/dashboard_card_test.clj
+++ b/test/metabase/models/dashboard_card_test.clj
@@ -96,7 +96,7 @@
                   Card          [{card-id3 :id} {:name "card3"}]]
     (let [upd-series (fn [series]
                        (dashboard-card/update-dashboard-card-series! {:id dashcard-id} series)
-                       (set (for [card-id (db/select-field :card_id DashboardCardSeries, :dashboardcard_id dashcard-id)]
+                       (set (for [card-id (t2/select-fn-set :card_id DashboardCardSeries, :dashboardcard_id dashcard-id)]
                               (t2/select-one-fn :name Card, :id card-id))))]
       (is (= #{}
              (upd-series [])))
diff --git a/test/metabase/models/permissions_test.clj b/test/metabase/models/permissions_test.clj
index 27fceabd793..7d4f504d3f0 100644
--- a/test/metabase/models/permissions_test.clj
+++ b/test/metabase/models/permissions_test.clj
@@ -12,7 +12,6 @@
    [metabase.test :as mt]
    [metabase.test.fixtures :as fixtures]
    [metabase.util :as u]
-   [toucan.db :as db]
    [toucan2.core :as t2]))
 
 (set! *warn-on-reflection* true)
@@ -814,9 +813,9 @@
 (deftest grant-revoke-root-collection-permissions-test
   (mt/with-temp PermissionsGroup [{group-id :id}]
     (letfn [(perms []
-              (db/select-field :object Permissions {:where [:and
-                                                            [:like :object "/collection/%"]
-                                                            [:= :group_id group-id]]}))]
+              (t2/select-fn-set :object Permissions {:where [:and
+                                                             [:like :object "/collection/%"]
+                                                             [:= :group_id group-id]]}))]
       (is (= nil
              (perms)))
       (testing "Should be able to grant Root Collection perms"
@@ -847,7 +846,7 @@
 (deftest grant-revoke-application-permissions-test
   (mt/with-temp PermissionsGroup [{group-id :id}]
     (letfn [(perms []
-              (db/select-field :object Permissions
+              (t2/select-fn-set :object Permissions
                                {:where [:and [:= :group_id group-id]
                                              [:like :object "/application/%"]]}))]
       (is (= nil (perms)))
diff --git a/test/metabase/models/pulse_channel_test.clj b/test/metabase/models/pulse_channel_test.clj
index 1f6d3754856..c3ee3f92fc7 100644
--- a/test/metabase/models/pulse_channel_test.clj
+++ b/test/metabase/models/pulse_channel_test.clj
@@ -10,7 +10,6 @@
    [metabase.models.user :refer [User]]
    [metabase.test :as mt]
    [metabase.util :as u]
-   [toucan.db :as db]
    [toucan.hydrate :refer [hydrate]]
    [toucan2.core :as t2])
   (:import
@@ -325,7 +324,7 @@
                   PulseChannel [{channel-id :id} {:pulse_id pulse-id}]]
     (letfn [(upd-recipients! [recipients]
               (pulse-channel/update-recipients! channel-id recipients)
-              (db/select-field :user_id PulseChannelRecipient, :pulse_channel_id channel-id))]
+              (t2/select-fn-set :user_id PulseChannelRecipient, :pulse_channel_id channel-id))]
       (doseq [[new-recipients expected] {[]                  nil
                                          [:rasta]            [:rasta]
                                          [:crowberto]        [:crowberto]
diff --git a/test/metabase/models/pulse_test.clj b/test/metabase/models/pulse_test.clj
index 1ea667f52e3..43b8d6d1077 100644
--- a/test/metabase/models/pulse_test.clj
+++ b/test/metabase/models/pulse_test.clj
@@ -125,8 +125,8 @@
                               2 card-2
                               3 card-3))]
                 (pulse/update-notification-cards! pulse (map pulse/card->ref cards)))
-              (when-let [card-ids (seq (db/select-field :card_id PulseCard, :pulse_id (u/the-id pulse)))]
-                (db/select-field :name Card, :id [:in card-ids])))]
+              (when-let [card-ids (seq (t2/select-fn-set :card_id PulseCard, :pulse_id (u/the-id pulse)))]
+                (t2/select-fn-set :name Card, :id [:in card-ids])))]
       (doseq [[cards expected] {[]    nil
                                 [1]   #{"card1"}
                                 [2]   #{"card2"}
diff --git a/test/metabase/models/user_test.clj b/test/metabase/models/user_test.clj
index 865d71fe496..a1020169957 100644
--- a/test/metabase/models/user_test.clj
+++ b/test/metabase/models/user_test.clj
@@ -237,7 +237,7 @@
 
 (defn group-names [groups-or-ids]
   (when (seq groups-or-ids)
-    (db/select-field :name PermissionsGroup :id [:in (map u/the-id groups-or-ids)])))
+    (t2/select-fn-set :name PermissionsGroup :id [:in (map u/the-id groups-or-ids)])))
 
 (defn- do-with-group [group-properties group-members f]
   (mt/with-temp PermissionsGroup [group group-properties]
diff --git a/test/metabase/query_processor/middleware/results_metadata_test.clj b/test/metabase/query_processor/middleware/results_metadata_test.clj
index 39f60d432d8..dd34b4a0325 100644
--- a/test/metabase/query_processor/middleware/results_metadata_test.clj
+++ b/test/metabase/query_processor/middleware/results_metadata_test.clj
@@ -13,7 +13,6 @@
    [metabase.util :as u]
    [metabase.util.schema :as su]
    [schema.core :as s]
-   [toucan.db :as db]
    [toucan2.core :as t2]))
 
 (defn- card-metadata [card]
@@ -25,7 +24,7 @@
   (mt/round-all-decimals 2 data))
 
 (defn- default-card-results []
-  (let [id->fingerprint   (db/select-id->field :fingerprint Field :table_id (mt/id :venues))
+  (let [id->fingerprint   (t2/select-pk->fn :fingerprint Field :table_id (mt/id :venues))
         name->fingerprint (comp id->fingerprint (partial mt/id :venues))]
     [{:name           "ID"
       :display_name   "ID"
diff --git a/test/metabase/sync/analyze/query_results_test.clj b/test/metabase/sync/analyze/query_results_test.clj
index f8afc133423..f4214d72b51 100644
--- a/test/metabase/sync/analyze/query_results_test.clj
+++ b/test/metabase/sync/analyze/query_results_test.clj
@@ -13,7 +13,7 @@
    [metabase.test.sync :as test.sync]
    [metabase.test.util :as tu]
    [metabase.util :as u]
-   [toucan.db :as db]))
+   [toucan2.core :as t2]))
 
 (defn- column->name-keyword [field-or-column-metadata]
   (-> field-or-column-metadata
@@ -64,7 +64,7 @@
 (defn- app-db-venue-fingerprints
   "Get a map of keyword field name (as lowercased keyword) => fingerprint from the app DB."
   []
-  (update-keys (db/select-field->field :name :fingerprint Field :table_id (mt/id :venues))
+  (update-keys (t2/select-fn->fn :name :fingerprint Field :table_id (mt/id :venues))
                (comp keyword u/lower-case-en)))
 
 (deftest mbql-result-metadata-test
diff --git a/test/metabase/sync/analyze_test.clj b/test/metabase/sync/analyze_test.clj
index d64ea9c0242..8a52e10b347 100644
--- a/test/metabase/sync/analyze_test.clj
+++ b/test/metabase/sync/analyze_test.clj
@@ -82,7 +82,7 @@
                                 :last_analyzed       #t "2017-08-09T00:00Z"}]]
         (#'analyze/update-fields-last-analyzed! table)
         (is (= #{"Current fingerprint, not analyzed"}
-               (db/select-field :name Field :table_id (u/the-id table), :last_analyzed [:> #t "2018-01-01"])))))))
+               (t2/select-fn-set :name Field :table_id (u/the-id table), :last_analyzed [:> #t "2018-01-01"])))))))
 
 (deftest survive-fingerprinting-errors
   (testing "Make sure we survive fingerprinting failing"
diff --git a/test/metabase/sync/sync_metadata/comments_test.clj b/test/metabase/sync/sync_metadata/comments_test.clj
index c5b13220c7b..67c2e0a84ae 100644
--- a/test/metabase/sync/sync_metadata/comments_test.clj
+++ b/test/metabase/sync/sync_metadata/comments_test.clj
@@ -14,7 +14,7 @@
    [toucan2.core :as t2]))
 
 (defn- db->fields [db]
-  (let [table-ids (db/select-ids Table :db_id (u/the-id db))]
+  (let [table-ids (t2/select-pks-set Table :db_id (u/the-id db))]
     (set (map (partial into {}) (db/select ['Field :name :description] :table_id [:in table-ids])))))
 
 (tx/defdataset basic-field-comments
diff --git a/test/metabase/sync/sync_metadata/fields/sync_instances_test.clj b/test/metabase/sync/sync_metadata/fields/sync_instances_test.clj
index 294d060989e..a6b165d1ac8 100644
--- a/test/metabase/sync/sync_metadata/fields/sync_instances_test.clj
+++ b/test/metabase/sync/sync_metadata/fields/sync_instances_test.clj
@@ -73,7 +73,7 @@
         (sync-metadata/sync-db-metadata! db)
         ;; field should be added back
         (is (= #{"weight" "age"}
-               (db/select-field :name Field :table_id transactions-table-id, :parent_id details-field-id, :active true))))))
+               (t2/select-fn-set :name Field :table_id transactions-table-id, :parent_id details-field-id, :active true))))))
 
   (testing "Syncing can reactivate a field"
     (tt/with-temp* [Database [db {:engine ::toucanery/toucanery}]]
@@ -88,7 +88,7 @@
         ;; now sync again.
         (sync-metadata/sync-db-metadata! db)
         ;; field should be reactivated
-        (is (db/select-field :active Field :id age-field-id)))))
+        (is (t2/select-fn-set :active Field :id age-field-id)))))
 
   (testing "Nested fields get reactivated if the parent field gets reactivated"
     (tt/with-temp* [Database [db {:engine ::toucanery/toucanery}]]
@@ -103,7 +103,7 @@
         ;; now sync again.
         (sync-metadata/sync-db-metadata! db)
         ;; field should be reactivated
-        (is (db/select-field :active Field :id age-field-id)))))
+        (is (t2/select-fn-set :active Field :id age-field-id)))))
 
   (testing "Nested fields can be marked inactive"
     (tt/with-temp* [Database [db {:engine ::toucanery/toucanery}]]
diff --git a/test/metabase/sync/sync_metadata/fields_test.clj b/test/metabase/sync/sync_metadata/fields_test.clj
index 28c20bd3a40..12add82617f 100644
--- a/test/metabase/sync/sync_metadata/fields_test.clj
+++ b/test/metabase/sync/sync_metadata/fields_test.clj
@@ -60,7 +60,7 @@
                       (set
                        (map (partial into {})
                             (db/select [Field :id :name :active]
-                              :table_id [:in (db/select-ids Table :db_id (u/the-id database))])))))]
+                              :table_id [:in (t2/select-pks-set Table :db_id (u/the-id database))])))))]
       (is (= {:before-sync #{{:name "species",      :active true}
                              {:name "example_name", :active true}}
               :after-sync #{{:name "species",      :active true}
@@ -85,7 +85,7 @@
               (set
                (map (partial into {})
                     (db/select [Field :name :active]
-                      :table_id [:in (db/select-ids Table :db_id (u/the-id database))])))))))))
+                      :table_id [:in (t2/select-pks-set Table :db_id (u/the-id database))])))))))))
 
 (deftest dont-show-deleted-fields-test
   (testing "make sure deleted fields doesn't show up in `:fields` of a table"
diff --git a/test/metabase/sync/sync_metadata/tables_test.clj b/test/metabase/sync/sync_metadata/tables_test.clj
index e16dc1942b5..4c9abac24db 100644
--- a/test/metabase/sync/sync_metadata/tables_test.clj
+++ b/test/metabase/sync/sync_metadata/tables_test.clj
@@ -7,7 +7,8 @@
    [metabase.test :as mt]
    [metabase.test.data.interface :as tx]
    [metabase.util :as u]
-   [toucan.db :as db]))
+   [toucan.db :as db]
+   [toucan2.core :as t2]))
 
 (tx/defdataset db-with-some-cruft
   [["acquired_toucans"
@@ -38,4 +39,4 @@
                     Table    [_       {:name "Table 2", :db_id (u/the-id db)}]]
       (#'sync-tables/retire-tables! db #{{:name "Table 1", :schema (:schema table-1)}})
       (is (= {"Table 1" false, "Table 2" true}
-             (db/select-field->field :name :active Table, :db_id (u/the-id db)))))))
+             (t2/select-fn->fn :name :active Table, :db_id (u/the-id db)))))))
diff --git a/test/metabase/test.clj b/test/metabase/test.clj
index 3b8cdd28150..70121202ad7 100644
--- a/test/metabase/test.clj
+++ b/test/metabase/test.clj
@@ -49,7 +49,8 @@
    [potemkin :as p]
    [toucan.db :as db]
    [toucan.models :as models]
-   [toucan.util.test :as tt]))
+   [toucan.util.test :as tt]
+   [toucan2.core :as t2]))
 
 (set! *warn-on-reflection* true)
 
@@ -309,7 +310,7 @@
   [attributes thunk]
   (let [existing-admin-memberships (db/select PermissionsGroupMembership :group_id (:id (perms-group/admin)))
         _                          (db/simple-delete! PermissionsGroupMembership :group_id (:id (perms-group/admin)))
-        existing-admin-ids         (db/select-ids User :is_superuser true)
+        existing-admin-ids         (t2/select-pks-set User :is_superuser true)
         _                          (when (seq existing-admin-ids)
                                      (db/update-where! User {:id [:in existing-admin-ids]} :is_superuser false))
         temp-admin                 (db/insert! User (merge (with-temp-defaults User)
diff --git a/test/metabase/test/data/impl.clj b/test/metabase/test/data/impl.clj
index c597c97b27e..8876737df30 100644
--- a/test/metabase/test/data/impl.clj
+++ b/test/metabase/test/data/impl.clj
@@ -203,7 +203,7 @@
           (throw
            (Exception. (format "No Table %s found for %s Database %d %s.\nFound: %s"
                                (pr-str table-name) driver db-id (pr-str db-name)
-                               (u/pprint-to-str (db/select-id->field :name Table, :db_id db-id, :active true)))))))))
+                               (u/pprint-to-str (t2/select-pk->fn :name Table, :db_id db-id, :active true)))))))))
 
 (defn- qualified-field-name [{parent-id :parent_id, field-name :name}]
   (if parent-id
@@ -256,8 +256,8 @@
     (for [field (db/select Field :table_id old-table-id {:order-by [[:id :asc]]})]
       (-> field (dissoc :id :fk_target_field_id) (assoc :table_id new-table-id))))
   ;; now copy the FieldValues as well.
-  (let [old-field-id->name (db/select-id->field :name Field :table_id old-table-id)
-        new-field-name->id (db/select-field->id :name Field :table_id new-table-id)
+  (let [old-field-id->name (t2/select-pk->fn :name Field :table_id old-table-id)
+        new-field-name->id (t2/select-fn->pk :name Field :table_id new-table-id)
         old-field-values   (db/select FieldValues :field_id [:in (set (keys old-field-id->name))])]
     (db/insert-many! FieldValues
       (for [{old-field-id :field_id, :as field-values} old-field-values
diff --git a/test/metabase/test/util.clj b/test/metabase/test/util.clj
index 488d13a0c1b..5f6b7bffe34 100644
--- a/test/metabase/test/util.clj
+++ b/test/metabase/test/util.clj
@@ -729,8 +729,8 @@
   (initialize/initialize-if-needed! :db)
   (let [read-path                   (perms/collection-read-path collection-or-id)
         readwrite-path              (perms/collection-readwrite-path collection-or-id)
-        groups-with-read-perms      (db/select-field :group_id Permissions :object read-path)
-        groups-with-readwrite-perms (db/select-field :group_id Permissions :object readwrite-path)]
+        groups-with-read-perms      (t2/select-fn-set :group_id Permissions :object read-path)
+        groups-with-readwrite-perms (t2/select-fn-set :group_id Permissions :object readwrite-path)]
     (hawk.parallel/assert-test-is-not-parallel "with-discarded-collections-perms-changes")
     (try
       (f)
@@ -762,7 +762,7 @@
     (finally
       (when (and (:metabase.models.collection.root/is-root? collection)
                  (not (:namespace collection)))
-        (doseq [group-id (db/select-ids PermissionsGroup :id [:not= (u/the-id (perms-group/admin))])]
+        (doseq [group-id (t2/select-pks-set PermissionsGroup :id [:not= (u/the-id (perms-group/admin))])]
           (when-not (db/exists? Permissions :group_id group-id, :object "/collection/root/")
             (perms/grant-collection-readwrite-permissions! group-id collection/root-collection)))))))
 
diff --git a/test/metabase/transforms/core_test.clj b/test/metabase/transforms/core_test.clj
index c529107f069..eae966b865a 100644
--- a/test/metabase/transforms/core_test.clj
+++ b/test/metabase/transforms/core_test.clj
@@ -15,7 +15,6 @@
    [metabase.transforms.core :as tf]
    [metabase.transforms.specs :as tf.specs]
    [metabase.util :as u]
-   [toucan.db :as db]
    [toucan2.core :as t2]))
 
 (use-fixtures :each (fn [thunk]
@@ -61,7 +60,7 @@
 
 (deftest tableset-test
   (testing "Can we get a tableset for a given schema?"
-    (is (= (db/select-ids Table :db_id (mt/id))
+    (is (= (t2/select-pks-set Table :db_id (mt/id))
            (set (map u/the-id (#'tf/tableset (mt/id) "PUBLIC")))))))
 
 (deftest find-tables-with-domain-entity-test
-- 
GitLab