From 15bf47434aa6845218158300f2e09ce545bef96c Mon Sep 17 00:00:00 2001 From: Jacyking <791026912@qq.com> Date: Thu, 4 Jan 2024 11:45:15 +0800 Subject: [PATCH] fix bool on pg and mysql --- include/mysql.hpp | 18 ++++++++++++++---- include/type_mapping.hpp | 1 - 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/include/mysql.hpp b/include/mysql.hpp index e39a3d08..80f47f33 100644 --- a/include/mysql.hpp +++ b/include/mysql.hpp @@ -177,8 +177,13 @@ class mysql { param.buffer = const_cast(static_cast(&value)); } else if constexpr (std::is_arithmetic_v) { - param.buffer_type = - (enum_field_types)ormpp_mysql::type_to_id(identity{}); + if constexpr (std::is_same_v) { + param.buffer_type = MYSQL_TYPE_TINY; + } + else { + param.buffer_type = + (enum_field_types)ormpp_mysql::type_to_id(identity{}); + } param.buffer = const_cast(static_cast(&value)); } else if constexpr (std::is_same_v) { @@ -214,8 +219,13 @@ class mysql { param_bind.buffer = const_cast(static_cast(&value)); } else if constexpr (std::is_arithmetic_v) { - param_bind.buffer_type = - (enum_field_types)ormpp_mysql::type_to_id(identity{}); + if constexpr (std::is_same_v) { + param_bind.buffer_type = MYSQL_TYPE_TINY; + } + else { + param_bind.buffer_type = + (enum_field_types)ormpp_mysql::type_to_id(identity{}); + } param_bind.buffer = const_cast(static_cast(&value)); } else if constexpr (std::is_same_v) { diff --git a/include/type_mapping.hpp b/include/type_mapping.hpp index fa153770..76995718 100644 --- a/include/type_mapping.hpp +++ b/include/type_mapping.hpp @@ -32,7 +32,6 @@ struct identity {}; #ifdef ORMPP_ENABLE_MYSQL namespace ormpp_mysql { -REGISTER_TYPE(bool, MYSQL_TYPE_BOOL) REGISTER_TYPE(char, MYSQL_TYPE_TINY) REGISTER_TYPE(short, MYSQL_TYPE_SHORT) REGISTER_TYPE(int, MYSQL_TYPE_LONG)