Determine MySQL query type in Zend Framework

前端 未结 2 831
旧时难觅i
旧时难觅i 2021-01-26 16:23

Can anyone tell me how to determine query type i.e. select, update, delete or insert before it is executed over MySQL.

I strongly belie

相关标签:
2条回答
  • 2021-01-26 16:44

    I strongly believe internally Zend Framework might be using mysql*_query function to execute them.

    ZF's Database class does not have support for the decrepit mysql extension. It has adapters for PDO and mysqli. You'll know which of these you are using because you have to expressly specify one in your code or configuration.

    So I want to find out which query was executed

    I think that you're going to be better served by rethinking your design. It's not entirely clear what is going on here, nor is it clear why you think you need to know the query type, nor is it clear where you expect to need to know the query type.

    Please review the Zend_Db_Table documentation, as it looks like you might have missed the point somewhere along the way.

    In specific, there are already methods provided by Zend_Db_Table for inserts, deletes and updates. If you need to change the behavior of the appropriate method, you should do so by simply overriding it in your class.

    Further, it looks like you're trying to build some sort of smart column type definition system. You don't need to do that, as again, Zend_Db_Table already provides this information to you, and even lets you hard-code it if you'd rather it not determine this information automatically.

    ZF is a complicated beast. If you're going to use it, I suggest that you fully understand everything it can do. Building non-standard, redundant architecture is only going to complicate things for you later on.

    0 讨论(0)
  • 2021-01-26 16:58

    EDIT : I was looking at the code for the Zend_Db_Table and Zend_Db_Table_Abstract and my second solution seems much more difficult now.

    Hey guys,

    If you want to give yourself a bit of a headache, what you can do is keep using the multidb resource to create two connections, one to the slave and one for the master.

    Set the default connection to the one that will be used the most.

    Then, with the other connection you can fetch it manually every time you need to use it and deal directly with the adapter instead of going through the DbTable class.

    For example, create another method for the mapper classes called getOtherDbAdapter() that gets the other adapter. Then you can use the adapter from there to perform selects or inserts.

    OH!

    Another solution is that you can extend extend the class Zend_Db_Table or Zend_Db_Table_Abstract and create another variable for the second db connection.

    Then, copy and paste the implementation code for all the fetch/select/insert/update methods from the Zend_Db_Table_Abstract class and have it use the the other adapter whenever you see the code performing the operations you want to have redirected to the other db.

    0 讨论(0)
提交回复
热议问题