MySQL: “блокировка ожидает, тайм-аут превысил”

Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.

Например, ниже - класс ученика, который будет использовать его в нашем коде.

public class Student {

    private int id;

    public int getId() {
        return this.id;
    }

    public setId(int newId) {
        this.id = newId;
    }
}

Приведенный ниже код дает вам исключение с нулевым указателем.

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}

Поскольку вы используете Obj_Student, но вы забыли инициализировать его, как в правильном коде, показанном ниже:

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student = new Student();
            obj_Student.setId(12);
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}
12
задан Adrian Dunston 15 September 2008 в 16:53
поделиться

2 ответа

Я соглашаюсь с Erik; TRUNCATE TABLE является способом пойти. Однако, если Вы не можете использовать это по некоторым причинам (например, если Вы действительно не хотите удалять каждую строку в таблице), можно попробовать следующие опции:

  • Удалите строки в меньших пакетах (например, УДАЛИТЕ ИЗ bundle_inclusions ГДЕ идентификатор МЕЖДУ? и?)
  • Если это - таблица MyISAM (на самом деле, это может работать с InnoDB также), попытайтесь выпустить ТАБЛИЦУ БЛОКИРОВКИ перед УДАЛЕНИЕМ. Это должно гарантировать, что у Вас есть эксклюзивный доступ.
  • Если это - таблица InnoDB, то после того, как тайм-аут происходит, используйте ШОУ СОСТОЯНИЕ INNODB. Это должно дать Вам некоторое понимание, почему приобретение блокировки перестало работать.
  • Если у Вас есть СУПЕР полномочие, Вы могли бы попробовать ШОУ PROCESSLIST ВСЕ для наблюдения то, что другие соединения (если таковые имеются) используют таблицу и затем используют, УНИЧТОЖАЮТ для избавлений от одного (s), Вы конкурируете с.

Я уверен, что существует много других возможностей; я надеюсь, что один из них помогает.

22
ответ дан 2 December 2019 в 04:43
поделиться

Предположение: усеченная таблица bundle_inclusions

2
ответ дан 2 December 2019 в 04:43
поделиться
Другие вопросы по тегам:

Похожие вопросы: