4

mysqlでデータベースを作成しています。最初に、テーブルごとに平均30列のプリンシパルテーブルを作成します。また、ログテーブルの標準は、参照されるテーブルのpkと各列*2です。次のようになります。

参照表:

Field   |   Type      |   Null   |   Key   |   Default   |   Extra
--------+-------------+----------+---------+-------------+----------------
TableID | int(11)     | No       | PRI     | Null        | auto_increment
Col1    | varchar(50) | No       |         | Null        |

ログテーブル:

Field       |   Type      |   Null   |   Key   |   Default   |   Extra
------------+-------------+----------+---------+-------------+----------------
LogTableID  | int(11)     | No       | PRI     | Null        | auto_increment
TableID     | int(11)     | No       | MUL     | Null        |
NewCol1     | varchar(50) | No       |         | Null        |
UpdatedCol1 | varchar(50) | No       |         | Null        |

ここで必要なのは、テーブル名をパラメーターとして渡し、テーブルログクエリの作成を生成して実行するプロシージャを作成することです。

これを行うための最良の方法は何ですか?

4

1 に答える 1

7

文字列がテーブル(またはデータベース)名を表すようにするには、クエリ文字列を変数と連結し、ストアドプロシージャでステートメントを準備/実行する必要があります。これが基本的な例です。

-- DROP PROCEDURE IF EXISTS createLogTable;
DELIMITER //
CREATE PROCEDURE createLogTable(tblName VARCHAR(255))
BEGIN
    SET @tableName = tblName;
    SET @q = CONCAT('
        CREATE TABLE IF NOT EXISTS `' , @tableName, '` (
            `id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
            `something` VARCHAR(10) NOT NULL,
            `somedate` DATETIME NOT NULL,
            PRIMARY KEY (`id`)
        ) ENGINE=MyISAM DEFAULT CHARSET=utf8
    ');
    PREPARE stmt FROM @q;
    EXECUTE stmt;
    DEALLOCATE PREPARE stmt;
    -- and you're done. Table is created.
    -- process it here if you like (INSERT etc)
END //

それで…CALL createLogTable('exampleTable');

つまり、基本的な考え方は

  1. 必要に応じて、プロシージャパラメータをクエリと連結します
  2. このクエリ文字列からステートメントを準備/実行します
于 2013-01-17T14:15:21.420 に答える