PDO statements with named parameters VS question mark parameters

后端 未结 3 1159
闹比i
闹比i 2021-01-23 16:43

I have a class for database management, and one of my sub-classes (the one that defines a query) is defined like this (just a sample, many other functions are actually stripped

相关标签:
3条回答
  • 2021-01-23 16:51

    In your case it should make no difference.

    0 讨论(0)
  • 2021-01-23 17:05

    The difference between named an unamed parameters is that with unnamed parameters you'll have to take care about the order in which they will be bound to the query.

    Especially in your example unnamed params will fit very good as it eases the function call.


    Further note that you won't need to call return $this; in a constructor method.

    0 讨论(0)
  • 2021-01-23 17:13

    Although there is no technical difference (as PDO will just replace named placeholders to question marks internally), there is a usability issue

    For the sprintf-like function question marks seems a lot better solution. As they will let you to use indeed sprintf-style (dunno why you're creating a whole class for the query):

    $query = new Query("SELECT * FROM t WHERE a=? AND b=?", $ida, $idb);
    

    while with named it will be a lot more verbose

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