MySQL のみを使用して、テーブルが新しい場合にのみ挿入ステートメントを実行できるかどうかを確認しています。テーブルが存在するかどうかを確認するためのユーザー変数を正常に作成しました。問題は、insert ステートメントと一緒に「WHERE」を使用できないことです。これを機能させる方法についてのアイデアはありますか?
// See if the "country" table exists -- saving the result to a variable
SELECT
@table_exists := COUNT(*)
FROM
information_schema.TABLES
WHERE
TABLE_SCHEMA = DATABASE() AND TABLE_NAME = 'country';
// Create the table if it doesn't exist
CREATE TABLE IF NOT EXISTS country (
id INT unsigned auto_increment primary key,
name VARCHAR(64)
);
// Insert data into the table if @table_exists > 0
INSERT INTO country (name) VALUES ('Afghanistan'),('Aland Islands') WHERE 0 < @table_exists;