我有一个 MariaDB 数据库,其中包含一个表,其中包含有关在具有 Mono JIT 编译器版本 5.4.0.201 和 MySql Connector/NET(最新版本 8.0.13)的 CentOS 7 服务器上运行的移动设备(android 和 ios)的信息。
一切都很好,除了我无法通过连接器/NET 从设备表中删除基于推送令牌的设备。表定义如下:
CREATE TABLE `Devices` (
`idDevices` int(11) NOT NULL AUTO_INCREMENT,
`notificationId` varchar(160) DEFAULT NULL,
`deviceId` varchar(64) NOT NULL,
`isAndroid` tinyint(1) NOT NULL,
`deviceModel` varchar(64) DEFAULT NULL,
`appMajor` tinyint(4) DEFAULT NULL,
`appMinor` tinyint(4) DEFAULT NULL,
PRIMARY KEY (`idDevices`),
UNIQUE KEY `isAndroid` (`isAndroid`,`deviceId`),
UNIQUE KEY `notificationId_UNIQUE` (`isAndroid`,`notificationId`),
KEY `appVersion` (`appMajor`,`appMinor`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
当我从 Mono 应用程序运行 DELETE 语句时,没有发生异常,但是从 ExecuteNonQuery() 返回的 int 值始终为 0,并且没有从表中删除任何行。mariadb.log (log_warning=4) 中不记录任何错误或警告。如果我将完全相同的 SQL 语句复制到 MySql Workbench 并在那里执行该语句,则会按预期删除行。如果我创建一个 PHP 脚本并使用 PDO 连接到同一个数据库,它也可以按预期工作。所有三个测试用例都使用相同的用户(root)。所以这似乎是特定于 Connector/NET 的问题
var tokenCount = 0;
var sql = new StringBuilder ("DELETE FROM Devices WHERE isAndroid = 0 AND notificationId IN ('");
while (...) {
sql.Append (token);
sql.Append ("','");
tokenCount++;
}
sql.Length -= 2;
sql.Append (')');
using (var connection = new MySqlConnection (connectionString)) {
connection.Open ();
using (var command = new MySqlCommand (sql.ToString (), connection)) {
var affectedRows = command.ExecuteNonQuery ();
if (affectedRows != tokenCount) {
//Always logs affectedRows(0)
log.Warn ($"Remove tokenCount({tokenCount}) != affectedRows({affectedRows}). sql={sql}");
}
}
}
更新:我启用了general_log,我看到正确的数据库被初始化并且语句正在运行 - 但表没有改变!日志输出:
3 Init DB mydb
3 Query DELETE FROM Devices WHERE isAndroid = 0 AND notificationId IN ('002B1C477DB4F20868D157A806DF70E05D61D3950562C03E092707CA9C5CCF23')
更新 #2:我尝试使用相同的 WHERE 子句将 DELETE 语句更改为 SELECT 语句,你瞧,没有返回任何行。因此,由于某种原因,notificationId 上的匹配似乎不起作用。会不会是编码问题?为什么它可以在其他客户端工作,但不能在我的 Connector/NET 客户端工作?