Heim > Datenbank > MySQL-Tutorial > Erstellen Sie eine gespeicherte MySQL-Prozedur, die den Datenbanknamen als Parameter verwendet und die Tabellen mit detaillierten Informationen in einer bestimmten Datenbank auflistet.

Erstellen Sie eine gespeicherte MySQL-Prozedur, die den Datenbanknamen als Parameter verwendet und die Tabellen mit detaillierten Informationen in einer bestimmten Datenbank auflistet.

王林
Freigeben: 2023-09-10 12:21:07
nach vorne
1224 Leute haben es durchsucht

Erstellen Sie eine gespeicherte MySQL-Prozedur, die den Datenbanknamen als Parameter verwendet und die Tabellen mit detaillierten Informationen in einer bestimmten Datenbank auflistet.

Angenommen, wir verwenden derzeit eine Datenbank namens „query“, die die folgende Tabelle enthält:

mysql> Show tables in query;
+-----------------+
| Tables_in_query |
+-----------------+
| student_detail  |
| student_info    |
+-----------------+
2 rows in set (0.00 sec)
Nach dem Login kopieren

Unten sehen Sie nun eine gespeicherte Prozedur, die den Namen der Datenbank als Parameter akzeptiert und uns die Details der Tabelle bereitstellt Liste der Informationen –

mysql> DELIMITER//
mysql> CREATE procedure tb_list(db_name varchar(40))
   -> BEGIN
   -> SET @z := CONCAT('Select * from information_schema.tables WHERE table_schema = ','\'',db_name,'\'');
   -> Prepare stmt from @z;
   -> EXECUTE stmt;
   -> END //
Query OK, 0 rows affected (0.06 sec)
Nach dem Login kopieren

Rufen Sie nun diese gespeicherte Prozedur auf, indem Sie den Datenbanknamen als Parameter angeben –

mysql> DELIMITER;
mysql> CALL tb_list('query')\G
*************************** 1. row ***************************
        TABLE_CATALOG: def
         TABLE_SCHEMA: query
           TABLE_NAME: student_detail
           TABLE_TYPE: BASE TABLE
               ENGINE: InnoDB
              VERSION: 10
           ROW_FORMAT: Dynamic
           TABLE_ROWS: 4
       AVG_ROW_LENGTH: 4096
          DATA_LENGTH: 16384
      MAX_DATA_LENGTH: 0
         INDEX_LENGTH: 0
            DATA_FREE: 0
       AUTO_INCREMENT: NULL
          CREATE_TIME: 2017-12-13 16:25:44
          UPDATE_TIME: NULL
           CHECK_TIME: NULL
      TABLE_COLLATION: latin1_swedish_ci
             CHECKSUM: NULL
       CREATE_OPTIONS:
        TABLE_COMMENT:
*************************** 2. row ***************************
        TABLE_CATALOG: def
         TABLE_SCHEMA: query
           TABLE_NAME: student_info
           TABLE_TYPE: BASE TABLE
               ENGINE: InnoDB
              VERSION: 10
           ROW_FORMAT: Dynamic
           TABLE_ROWS: 4
       AVG_ROW_LENGTH: 4096
          DATA_LENGTH: 16384
      MAX_DATA_LENGTH: 0
         INDEX_LENGTH: 0
            DATA_FREE: 0
       AUTO_INCREMENT: NULL
          CREATE_TIME: 2017-12-12 09:52:51
          UPDATE_TIME: NULL
           CHECK_TIME: NULL
      TABLE_COLLATION: latin1_swedish_ci
             CHECKSUM: NULL
       CREATE_OPTIONS:
        TABLE_COMMENT:
2 rows in set (0.00 sec)
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonErstellen Sie eine gespeicherte MySQL-Prozedur, die den Datenbanknamen als Parameter verwendet und die Tabellen mit detaillierten Informationen in einer bestimmten Datenbank auflistet.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:tutorialspoint.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage