sql >> データベース >  >> Database Tools >> phpMyAdmin

mysqlで自動増分をハッシュする方法

    本当にこれが必要な場合は、何らかの理由で、シーケンス用の別のテーブルとBEFOREを使用してこれを実現できます。 トリガー

    テーブルスキーマ:

    CREATE TABLE table1_seq
    (id INT NOT NULL AUTO_INCREMENT PRIMARY KEY);
    CREATE TABLE table1
    (id VARCHAR(32) NOT NULL DEFAULT 0, name VARCHAR(32));
    

    トリガー

    DELIMITER $$
    CREATE TRIGGER tg_bi_table1
    BEFORE INSERT ON table1
    FOR EACH ROW
    BEGIN
      INSERT INTO table1_seq () VALUES ();
      SET NEW.id = MD5(LAST_INSERT_ID());
    END$$
    DELIMITER ;
    

    これで、table1に行を挿入できます テーブル

    INSERT INTO table1 (`name`) VALUES ('New York'),('Chicago'),('Sydney'),('Berlin');
    

    または

    を選択します
    SELECT * FROM table1 WHERE id = MD5(2);
    

    これがSQLFiddle です。 デモ



    1. MySQL REPLACEステートメントが正しくありませんか?新しいステートメントが見つかりましたが、区切り文字がありません

    2. SQL Server Management Studioでローカルデータベースに接続するにはどうすればよいですか?

    3. 外部キーとしての複合キー(sql)

    4. SSMSからSQLServerExpressに接続できません