Es kann keine mySQL Tabelle löschen. (Fehler 1050)
-
04-10-2019 - |
Frage
Ich habe eine nervtötende Tabelle, die nicht gelöscht werden, und es ist meine dev Umgebung refresh hält: (
Ich weiß, dass diese Tabelle existiert. Beispiel ...
mysql> select * from uc_order_products_qty_vw limit 10;
+-----+-------------+---------+---------+---------+---------+
| nid | order_count | avg_qty | sum_qty | max_qty | min_qty |
+-----+-------------+---------+---------+---------+---------+
| 105 | 1 | 1.0000 | 1 | 1 | 1 |
| 110 | 5 | 1.0000 | 5 | 1 | 1 |
| 111 | 1 | 1.0000 | 1 | 1 | 1 |
| 113 | 5 | 1.0000 | 5 | 1 | 1 |
| 114 | 1 | 1.0000 | 1 | 1 | 1 |
| 115 | 1 | 1.0000 | 1 | 1 | 1 |
| 117 | 2 | 1.0000 | 2 | 1 | 1 |
| 119 | 3 | 1.3333 | 4 | 2 | 1 |
| 190 | 5 | 1.0000 | 5 | 1 | 1 |
| 199 | 2 | 1.0000 | 2 | 1 | 1 |
+-----+-------------+---------+---------+---------+---------+
10 rows in set (0.00 sec)
Allerdings, wenn ich versuche, es fallen zu lassen ...
mysql> DROP TABLE IF EXISTS uc_order_products_qty_vw;
Query OK, 0 rows affected, 1 warning (0.00 sec)
Es funktioniert nicht, die Tabelle ist immer noch da, und die Warnung sagt dies ...
mysql> show warnings limit 1;
+-------+------+------------------------------------------+
| Level | Code | Message |
+-------+------+------------------------------------------+
| Note | 1051 | Unknown table 'uc_order_products_qty_vw' |
+-------+------+------------------------------------------+
1 row in set (0.00 sec)
Gefühl ziemlich sprachlos.
Lösung
aus dem Namen zu urteilen könnte es eine Ansicht sein. Versuchen Sie es mit DROP VIEW :
DROP VIEW uc_order_products_qty_vw
DROP TABLE funktioniert nicht für Ansichten:
CREATE VIEW test_vw AS SELECT 1;
SELECT * FROM test_vw; -- works
DROP TABLE test_vw; -- error: Unknown table 'test_vw'
DROP VIEW test_vw; -- works
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow