Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Debugowanie wyzwalaczy MySQL

Istnieje alternatywny sposób testowania go poprzez tymczasowe debug stół . W tym przykładzie tworzą go we własnym debug baza danych.

Krok 1: Utwórz tabelę

DROP TABLE IF EXISTS debug;
CREATE TABLE debug (
  proc_id varchar(100) default NULL,
  debug_output text,
  line_id int(11) NOT NULL auto_increment,
  PRIMARY KEY  (line_id)
)

Krok 2: Utwórz debugowania SP, aby wypełnić tabelę debugowania

DELIMITER $$

DROP PROCEDURE IF EXISTS `debug_insert` $$
CREATE PROCEDURE `debug_insert`(in p_proc_id varchar(100),in p_debug_info text)
begin
  insert into debug (proc_id,debug_output)
  values (p_proc_id,p_debug_info);
end $$

DROP PROCEDURE IF EXISTS `debug_on` $$
CREATE PROCEDURE `debug_on`(in p_proc_id varchar(100))
begin
  call debug_insert(p_proc_id,concat('Debug Started :',now()));
end $$

DROP PROCEDURE IF EXISTS `debug_off` $$
CREATE PROCEDURE `debug_off`(in p_proc_id varchar(100))
begin
  call debug_insert(p_proc_id,concat('Debug Ended :',now()));
  select debug_output from debug where proc_id = p_proc_id order by line_id;
  delete from debug where proc_id = p_proc_id;
end $$

Krok 3: Wywołaj SP debugowania w wyzwalaczu

W ten sposób,

CREATE PROCEDURE test_debug()
begin
declare l_proc_id varchar(100) default 'test_debug';
  call debug_on(l_proc_id);
  call debug_insert(l_proc_id,'Testing Debug');
  call debug_off(l_proc_id);
end $$

W rezultacie tabela debugowania zostanie wypełniona w następujący sposób:

+------------------------------------+
| debug_output                       |
+------------------------------------+
| Debug Started :2006-03-24 16:10:33 |
| Testing Debug                      |
| Debug Ended :2006-03-24 16:10:33   |
+------------------------------------+


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Przenieś węzeł w zestawie zagnieżdżonym

  2. Zmień krok auto_increment pól inkrementacji o

  3. Flask-SQLAlchemy:nie można połączyć się ponownie, dopóki nieprawidłowa transakcja nie zostanie wycofana

  4. Warunkowe MySQL ORDER BY ASC/DESC dla kolumny daty

  5. MySQL AUTO_INCREMENT nie wycofuje się