sql >> Databáze >  >> RDS >> Mysql

Ladění spouštěčů MySQL

Existuje alternativní způsob testování pomocí dočasného debug tabulka . Ve zde uvedeném příkladu jej vytvoří ve vlastním debug databáze.

Krok 1: Vytvořte tabulku

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: Vytvořte ladicí SP k vyplnění tabulky ladění

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: Vyvolejte ladicí SP ve vašem spouštěči

Takhle,

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 $$

V důsledku toho by ladicí tabulka byla vyplněna následovně,

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


  1. Zavedení ovladače Easysoft Oracle® do vašeho prostředí SOA

  2. Jak vyřešit problém s kódováním znaků MySQL?

  3. základní hromadná vložka pyodbc

  4. MySQLi - deklarování proměnné po bind_param?