sql >> Database >  >> RDS >> Mysql

Een getallentabel maken in MySQL

Je mist puntkomma's, komma's en zelfs na het corrigeren van de syntaxis is het nog steeds geen goed idee om elke keer max uit de tabel te selecteren, alleen om nog een rij in een lus in te voegen.

Laat dat vallen en gebruik generatoren van http:/ /use-the-index-luke.com/blog/2011-07-30/mysql-row-generator :

CREATE OR REPLACE VIEW generator_16
AS SELECT 0 n UNION ALL SELECT 1  UNION ALL SELECT 2  UNION ALL 
   SELECT 3   UNION ALL SELECT 4  UNION ALL SELECT 5  UNION ALL
   SELECT 6   UNION ALL SELECT 7  UNION ALL SELECT 8  UNION ALL
   SELECT 9   UNION ALL SELECT 10 UNION ALL SELECT 11 UNION ALL
   SELECT 12  UNION ALL SELECT 13 UNION ALL SELECT 14 UNION ALL 
   SELECT 15;

CREATE OR REPLACE VIEW generator_256
AS SELECT ( ( hi.n << 4 ) | lo.n ) AS n
     FROM generator_16 lo, generator_16 hi;

CREATE OR REPLACE VIEW generator_4k
AS SELECT ( ( hi.n << 8 ) | lo.n ) AS n
     FROM generator_256 lo, generator_16 hi;

CREATE OR REPLACE VIEW generator_64k
AS SELECT ( ( hi.n << 8 ) | lo.n ) AS n
     FROM generator_256 lo, generator_256 hi;

CREATE OR REPLACE VIEW generator_1m
AS SELECT ( ( hi.n << 16 ) | lo.n ) AS n
     FROM generator_64k lo, generator_16 hi;

En als je om wat voor reden dan ook echt een tabel met getallen nodig hebt, doe dan gewoon:

INSERT INTO numbers(number)
SELECT n FROM generator_64k WHERE n < 64000


  1. Inleiding tot HDFS | Wat is HDFS en hoe werkt het?

  2. HHVM gebruiken met WordPress

  3. Opgeslagen Oracle-procedure:retourneer zowel de resultaatset als de out-parameters

  4. Tussentijds gelijktijdige gebeurtenissen in een database zoeken