Files
sqlgen/tests/mysql/test_update_dry.cpp
2025-07-27 12:25:12 +02:00

29 lines
678 B
C++

#include <gtest/gtest.h>
#include <sqlgen.hpp>
#include <sqlgen/mysql.hpp>
namespace test_update_dry {
struct TestTable {
std::string field1;
int32_t field2;
sqlgen::PrimaryKey<uint32_t> id;
std::optional<std::string> nullable;
};
TEST(mysql, test_update_dry) {
using namespace sqlgen;
using namespace sqlgen::literals;
const auto query =
update<TestTable>("field1"_c.set("Hello"), "nullable"_c.set("field1"_c)) |
where("field2"_c > 0);
const auto expected =
R"(UPDATE `TestTable` SET `field1` = 'Hello', `nullable` = `field1` WHERE `field2` > 0;)";
EXPECT_EQ(sqlgen::mysql::to_sql(query), expected);
}
} // namespace test_update_dry