您好,欢迎访问一九零五行业门户网

oop - PHP CURD类操作数据库方式(PDO_MYSQL/MySQLi)

php使用pdo_mysql/mysqli的预处理(prepare)方法,已经封装成类,使用数组的方式把参数绑定再执行。
但是数据表比较多时,如果把每个数据表的curd操作都写成独立的函数就太麻烦了,那样的话文件也多,以后维护不方便。
如果把curd封装成类,就可以方便使用了,比如获取用户表、文章表的数据,传入表名、数据和其他查询参数再执行即可。
但是这样不仅没有了灵活性,而且因为是prepare方式执行的,这样就要用很多?来代替参数然后再绑定,反而不知应该怎样写了(主要是select语句)。
比如获取用户表的10个注册用户:
非prepare方式:
select `username` from `users` where `type` = 1 limit 0, 10

如果要把limit换成其他子句,比如order by这些,直接拼接sql语句就行了,没有难度。
但是,下面这种就麻烦了。
prepare方式:
select `?` from `?` where `?` = ? limit ?, ?array('username', 'users', 'type', 1, 0, 10)

但是在有些情况下可能就不需要limit。
这样的话组织curd的代码会很麻烦,如果包括子句,比如worder by这些,将会更麻烦。
有没有简便或者折中的方法?
补充:我已用orm解决。
回复内容: php使用pdo_mysql/mysqli的预处理(prepare)方法,已经封装成类,使用数组的方式把参数绑定再执行。
但是数据表比较多时,如果把每个数据表的curd操作都写成独立的函数就太麻烦了,那样的话文件也多,以后维护不方便。
如果把curd封装成类,就可以方便使用了,比如获取用户表、文章表的数据,传入表名、数据和其他查询参数再执行即可。
但是这样不仅没有了灵活性,而且因为是prepare方式执行的,这样就要用很多?来代替参数然后再绑定,反而不知应该怎样写了(主要是select语句)。
比如获取用户表的10个注册用户:
非prepare方式:
select `username` from `users` where `type` = 1 limit 0, 10

如果要把limit换成其他子句,比如order by这些,直接拼接sql语句就行了,没有难度。
但是,下面这种就麻烦了。
prepare方式:
select `?` from `?` where `?` = ? limit ?, ?array('username', 'users', 'type', 1, 0, 10)

但是在有些情况下可能就不需要limit。
这样的话组织curd的代码会很麻烦,如果包括子句,比如worder by这些,将会更麻烦。
有没有简便或者折中的方法?
补充:我已用orm解决。
select `username` from `users` where `type` = ? limit 0, 10array(1)像上面一样 只设置关键字段就行了
curd用单例做抽象封装,具体到表的数据库操作封装成model层,就是mvc的m
其它类似信息

推荐信息