Добавление записи в MySQL всегда вызывает - «Входная строка не была в правильном формате ошибка»

Каждый раз, когда я пытаюсь добавить запись в БД, транзакция завершается с ошибкой «Входная строка не была в правильном формате», хотя я пытался без каких-либо строк!

Чтобы дать вам более полное представление о том, что я пытаюсь сделать, в основном пользователь моего приложения запрашивает свой идентификатор сеанса при запуске, который отслеживает его действия, на следующем этапе сервер получил запрос и получил идентификатор сеанса из MySQL, затем он передает его обратно клиенту, который использует этот номер для формирования аутентификации на своем собственном канале.

То, что я вижу из журнала ниже, похоже, является недопустимым преобразованием, которое вызывает это исключение.

Я использую:

  1. .NET Core 2.1
  2. Pomelo.EntityFrameworkCore.MySql 3.1.0
  3. Oracle MySQL 5.1.73 скомпилирован для linux-gnu x86_x64 (нет возможности его обновить)

Я надеюсь, что кто-то может помочь.

Вот проблемный код вместе с определением сущности, дизайна таблицы и журнала ошибок:

    public static uint CreateSession(UsageTracking usageTracking)
    {
        using (MySQL SQL = new MySQL())
        {
            SQL.UsageTracking.Add(usageTracking);
            SQL.SaveChanges();

            return usageTracking.SessionID;
        }
    }

   public class UsageTracking
    {
        [Key]
        public uint SessionID { get; set; }
        [MaxLength(7)] [Required]
        public string USID{ get; set; }
        [Required]
        public long Date { get; set; }
    }


class MySQL : DbContext
{
    public static string connectionHost;
    public static string connectionPort;
    public static string connectionDB;
    public static string connectionUsn;
    public static string connectionPsw;

    public DbSet<DB.UsageTracking> UsageTracking { get; set; }

    protected override void OnConfiguring(DbContextOptionsBuilder options)
    {
        options
            .UseMySql($"server={connectionHost};port={connectionPort};database={connectionDB};user= 
                 {connectionUsn};password={connectionPsw}", mySQLOptions => mySQLOptions
                .ServerVersion(new Version(5,1,73), ServerType.MySql)
            );
    }
}

Таблица отслеживания использования:

CREATE TABLE `UsageTracking` (
`SessionID` int(4) unsigned NOT NULL,
`USID` varchar(7) DEFAULT NULL,
`Date` int(8) DEFAULT NULL,
 PRIMARY KEY (`SessionID`)
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Журнал ошибок:

        <logevent time="2020-01-15 16:24:17.2857" level="ERROR">
          <message>Input string was not in a correct format.</message>
          <type>System.FormatException</type>
          <trace>   at System.Number.StringToNumber(ReadOnlySpan`1 str, NumberStyles options, NumberBuffer&amp; number, NumberFormatInfo info, Boolean parseDecimal)
           at System.Number.ParseUInt32(ReadOnlySpan`1 value, NumberStyles options, NumberFormatInfo numfmt)
           at System.String.System.IConvertible.ToUInt32(IFormatProvider provider)
           at System.Convert.ChangeType(Object value, Type conversionType, IFormatProvider provider)
           at MySql.Data.MySqlClient.MySqlConnectionStringValueOption`1.ChangeType(Object objectValue) in C:projectsmysqlconnectorsrcMySqlConnectorMySql.Data.MySqlClientMySqlConnectionStringBuilder.cs:line 703
           at MySql.Data.MySqlClient.MySqlConnectionStringValueOption`1.GetValue(MySqlConnectionStringBuilder builder) in C:projectsmysqlconnectorsrcMySqlConnectorMySql.Data.MySqlClientMySqlConnectionStringBuilder.cs:line 674
           at MySqlConnector.Core.ConnectionSettings..ctor(MySqlConnectionStringBuilder csb) in C:projectsmysqlconnectorsrcMySqlConnectorCoreConnectionSettings.cs:line 39
           at MySqlConnector.Core.ConnectionPool.GetPool(String connectionString) in C:projectsmysqlconnectorsrcMySqlConnectorCoreConnectionPool.cs:line 405
           at MySql.Data.MySqlClient.MySqlConnection.OpenAsync(Nullable`1 ioBehavior, CancellationToken cancellationToken) in C:projectsmysqlconnectorsrcMySqlConnectorMySql.Data.MySqlClientMySqlConnection.cs:line 292
           at MySql.Data.MySqlClient.MySqlConnection.Open() in C:projectsmysqlconnectorsrcMySqlConnectorMySql.Data.MySqlClientMySqlConnection.cs:line 280
           at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.OpenDbConnection(Boolean errorsExpected)
           at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.Open(Boolean errorsExpected)
           at Pomelo.EntityFrameworkCore.MySql.Storage.Internal.MySqlRelationalConnection.Open(Boolean errorsExpected)
           at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.BeginTransaction(IsolationLevel isolationLevel)
           at Microsoft.EntityFrameworkCore.Storage.RelationalConnection.BeginTransaction()
           at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.Execute(IEnumerable`1 commandBatches, IRelationalConnection connection)
           at Microsoft.EntityFrameworkCore.Storage.RelationalDatabase.SaveChanges(IList`1 entries)
           at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChanges(IList`1 entriesToSave)
           at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChanges(DbContext _, Boolean acceptAllChangesOnSuccess)
           at Pomelo.EntityFrameworkCore.MySql.Storage.Internal.MySqlExecutionStrategy.Execute[TState,TResult](TState state, Func`3 operation, Func`3 verifySucceeded)
           at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChanges(Boolean acceptAllChangesOnSuccess)
           at Microsoft.EntityFrameworkCore.DbContext.SaveChanges(Boolean acceptAllChangesOnSuccess)
           at Microsoft.EntityFrameworkCore.DbContext.SaveChanges()
           at ReportingServer.DB.CreateSession(UsageTracking usageTracking) in C:UsersUsersource
eposReporting ServerMySQL.cs:line 20
           at ReportingServer.APIs.GetSessionID() in C:UsersUsersource
eposReporting ServerAPIs.cs:line 66
           at ReportingServer.APIs.Process() in C:UsersUsersource
eposReporting ServerAPIs.cs:line 41
           at ReportingServer.HTTPServer.&lt;Listen&gt;b__10_0(Object HTTPRequest) in C:UsersUsersource
eposReporting ServerHTTPServer.cs:line 135</trace>
          <source>System.Private.CoreLib</source>
          <location>
          <ReportedIn>ReportingServer.Log</ReportedIn>
          <OnLine>17</OnLine>
        </location>
        </logevent>

Всего 2 ответа


Убедитесь, что ваш код ниже работает нормально. Поставьте точку останова, чтобы проверить.

$ "server = {connectionHost}; порт = {connectionPort}; база данных = {connectionDB}; пользователь = {connectionUsn}; пароль = {connectionPsw}"


Решаемые. Ответ Алексы был верным, я проверил Соединение после конфигурации, и оно было неверным, часть конфигурации была изменена неправильно, и я все время смотрел на неправильную часть кода ...

Благодарность !!


Есть идеи?

10000