There’s no real way to unit test a database other than asserting that the tables exist, contain the expected columns, and have the appropriate constraints. But that’s usually not really worth doing.
You don’t typically unit test the database. You usually involve the database in integration tests.
You typically use your favourite automated unit testing framework to perform integration tests, which is why some people get confused, but they don’t follow the same rules. You are allowed to involve the concrete implementation of many of your classes (because they’ve been unit tested). You are testing how your concrete classes interact with each other and with the database.