Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

PHP के माध्यम से mysql ट्रिगर बनाएं?

जबकि mysqli DELIMITER के साथ कुछ भी नहीं करता है multi-query . में कथन, यह वास्तव में सामान्य प्रश्नों में किसी भी सीमांकक के साथ कुछ भी नहीं करता है, इसलिए बस अपने ट्रिगर्स को एक-एक करके आगे बढ़ाएं:

$ cat i.php 
<?php
$mysqli = new mysqli('localhost', 'test', '', 'test');
$sql = "
CREATE TRIGGER `_foo_fulltext_update` AFTER UPDATE ON `foo`
  FOR EACH ROW BEGIN
    DELETE FROM `bar` WHERE `bar`=NEW.`bar`;
    INSERT INTO `bar` (bar) SELECT bar FROM `foo` WHERE `bar`=NEW.`bar`;
  END;
";
$mysqli->query($sql);
var_dump($mysqli->error);
$ php i.php 
string(0) ""
$ mysql
mysql> use test;

Database changed
mysql> show triggers\G
*************************** 1. row ***************************
             Trigger: _foo_fulltext_update
               Event: UPDATE
               Table: foo
           Statement: BEGIN
    DELETE FROM `bar` WHERE `bar`=NEW.`bar`;
    INSERT INTO `bar` (bar) SELECT bar FROM `foo` WHERE `bar`=NEW.`bar`;
  END
              Timing: AFTER
             Created: NULL
            sql_mode: 
             Definer: [email protected]
character_set_client: latin1
collation_connection: latin1_swedish_ci
  Database Collation: utf8_general_ci
1 row in set (0.00 sec)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL अनुक्रमण और फाइलों का उपयोग करना

  2. स्प्रिंटफ () एसक्यूएल इंजेक्शन से कैसे बचाता है?

  3. SQL कर्सर के साथ कार्य करना

  4. MySQL - कस्टम सॉर्ट के लिए उपयोगकर्ता द्वारा परिभाषित फ़ंक्शन बनाना

  5. क्या SQL के लिए कोई प्रकाशित कोडिंग शैली दिशानिर्देश हैं?