django ошибка создания тестовой базы данных (бэкэнд mysql) - PullRequest
0 голосов
/ 04 февраля 2020

Я пытаюсь использовать Django для создания юнит-тестов. (Я использую PyMySQL == 0.9.3) Когда я запускаю

python manage.py test -k

Я получил исключение из базы данных:

Got an error creating the test database: (1064, "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CREATE DATABASE IF NOT EXISTS `test_t` ;\n                    SET sql_no' at line 2")

Я обнаружил Django используйте этот код, чтобы избежать предупреждения "база данных существует": (django / backends / mysql / creation.py)

            if keepdb:
                # If the database should be kept, add "IF NOT EXISTS" to avoid
                # "database exists" error, also temporarily disable "database
                # exists" warning.
                cursor.execute('''
                    SET @_tmp_sql_notes := @@sql_notes, sql_notes = 0;
                    CREATE DATABASE IF NOT EXISTS %(dbname)s %(suffix)s;
                    SET sql_notes = @_tmp_sql_notes;
                ''' % parameters)

Я запускаю каждый SQL, он работает хорошо. Так что я должен настроить для запуска нескольких запросов в Django (Py MySQL)?

...