sql >> Database teknologi >  >> Database Tools >> phpMyAdmin

Sådan hash automatisk stigninger i mysql

Hvis du virkelig har brug for dette, af en eller anden grund, kan du opnå det ved hjælp af en separat tabel til sekvensering og en BEFORE trigger

Tabelskemaer:

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));

Udløseren

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 ;

Nu kan du indsætte rækker i din table1 bord

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

eller vælg

SELECT * FROM table1 WHERE id = MD5(2);

Her er SQLFiddle demo



  1. SQL-syntaksfejl nær gunzip ved gendannelse af en database ved hjælp af .sql.gz-fil

  2. Sådan opdaterer du data i en SQL-database

  3. PHP for at hente PostGIS geografityper

  4. Hvordan kan jeg se, hvor tabulatorstoppene er i SQL Server Management Studio-editoren?