sql >> Databáze >  >> Database Tools >> phpMyAdmin

Jak hashovat automatické přírůstky v mysql

Pokud to z nějakého důvodu opravdu potřebujete, můžete toho dosáhnout pomocí samostatné tabulky pro sekvenování a BEFORE spoušť

Schémata tabulek:

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

Spouštěč

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 ;

Nyní můžete do table1 vkládat řádky tabulka

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

nebo vyberte

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

Zde je SQLFiddle demo



  1. Instance Amazon RDS MySQL funguje velmi pomalu

  2. Změnil jsem port MySQL v XAMPP, jak nyní naslouchám novému portu?

  3. MYSQL 8.0 - nepodporovaný formát redo log

  4. MySQL zobrazuje v dotazu nulové výsledky – s INNER JOIN