请教 query builder 实现的意义和目的是什么?
之前做项目,都是 lamp , controller/model/db , model 里的数据库操作其实都是直接写的 sql 语句,后来有公司有项目是在 model 里从 mysql 临时切换到 mango 的,再后来发现 sqlserver 里其实并没有 LIMIT ,原先写死的 sql 换个驱动可能就挂了。后来发现有 ActiveRecord/ORM 这东西,也有独立于 php 框架之外的 ORM 框架,但是发现这东西会生成很多对象,并且表关联和复杂语句并不是太方便。
后来才知道 query builder 的概念,比如原先:
<code>SELECT u.id, i.real_name AS name FROM user AS u INNER JOIN user_info AS i ON u.id = i.user_id WHERE u.id = 1 LIMIT 1 </code>
会类似这样实现:
<code>model('user')->alias('u')->innerJoin('user_info AS i ON u.id = i.user_id')->where('u.id = 1')->limit(1)->find(); </code>
这样实现的目的是不是像他们说的那样:
1 、排版更好阅读性更强
2 、独立于数据库驱动,这样换驱动也不至于硬编码的 sql 不能执行
但是里面有一些一直无法理解地方,比方:
<code>field('id, user_name AS uname') / field('id, COUNT(*) AS count_num') </code>
也可以这样写:
<code>field(array('id', 'user_name' => 'uname')) / field(array('id', 'COUNT(*)' => 'count_num')) </code>
但下面的方式并没有比上面的更易读啊,而且更容易写错。。难道说是为了去掉 AS ,这样某个数据库驱动不用 AS ,这样它就可以自己实现成其它的关键字?但是也不对啊,既然允许上面的写法存在,那别人都写上面那种,那这种写法不就受限于只支持 AS 的驱动了?
类似的还有 thinkphp 的 neq => , nin => not in 等等, Yii 还是 like / not like 。
还有 laravel 实现 join 到这么细:
<code>join('contacts', 'users.id', '=', 'contacts.user_id') </code>
难道说 join 大家不同的数据库还有什么差别吗?为什么要实现到这么细呢,那个引号和逗号难道不比直接一句 join 写起来更麻烦吗?而且也相比之下也不易读啊?
如果说实现 query builder 是为了切换驱动仍然能够运行,那不是应该杜绝 field() 或者 join() 里直接传入字符串吗,而是传入数组或者多个参数,把所有关键字都去掉吗?既然允许输入字符串,那不是就破坏了移植性吗?
求解!
回复内容:
之前做项目,都是 lamp , controller/model/db , model 里的数据库操作其实都是直接写的 sql 语句,后来有公司有项目是在 model 里从 mysql 临时切换到 mango 的,再后来发现 sqlserver 里其实并没有 LIMIT ,原先写死的 sql 换个驱动可能就挂了。后来发现有 ActiveRecord/ORM 这东西,也有独立于 php 框架之外的 ORM 框架,但是发现这东西会生成很多对象,并且表关联和复杂语句并不是太方便。
后来才知道 query builder 的概念,比如原先:
<code>SELECT u.id, i.real_name AS name FROM user AS u INNER JOIN user_info AS i ON u.id = i.user_id WHERE u.id = 1 LIMIT 1 </code>
会类似这样实现:
<code>model('user')->alias('u')->innerJoin('user_info AS i ON u.id = i.user_id')->where('u.id = 1')->limit(1)->find(); </code>
这样实现的目的是不是像他们说的那样:
1 、排版更好阅读性更强
2 、独立于数据库驱动,这样换驱动也不至于硬编码的 sql 不能执行
但是里面有一些一直无法理解地方,比方:
<code>field('id, user_name AS uname') / field('id, COUNT(*) AS count_num') </code>
也可以这样写:
<code>field(array('id', 'user_name' => 'uname')) / field(array('id', 'COUNT(*)' => 'count_num')) </code>
但下面的方式并没有比上面的更易读啊,而且更容易写错。。难道说是为了去掉 AS ,这样某个数据库驱动不用 AS ,这样它就可以自己实现成其它的关键字?但是也不对啊,既然允许上面的写法存在,那别人都写上面那种,那这种写法不就受限于只支持 AS 的驱动了?
类似的还有 thinkphp 的 neq => , nin => not in 等等, Yii 还是 like / not like 。
还有 laravel 实现 join 到这么细:
<code>join('contacts', 'users.id', '=', 'contacts.user_id') </code>
难道说 join 大家不同的数据库还有什么差别吗?为什么要实现到这么细呢,那个引号和逗号难道不比直接一句 join 写起来更麻烦吗?而且也相比之下也不易读啊?
如果说实现 query builder 是为了切换驱动仍然能够运行,那不是应该杜绝 field() 或者 join() 里直接传入字符串吗,而是传入数组或者多个参数,把所有关键字都去掉吗?既然允许输入字符串,那不是就破坏了移植性吗?
求解!
不应该用开发者的角度去研究框架设计的意义。
作为框架,因为不确定使用者和项目需求,所以其代码在保持特色的同时要考虑兼容,这也是为什么所有的DB封装在提供了Query builder的基础上依然支持 query, exec方法的原因。
此外,设计再好也挡不住开发者乱用。很多人不仔细看文档,看到支持string格式的参数就满足了,不会再去更多的研究。例如你的例子里面使用了join,但是通常model是可以定义数据关系的,根本不需要你join,对不对?
就如同你所说的,用数组觉得麻烦,用字符串失去可移植性,问题是代码是你写的,你选择麻烦还是选择可移植呢?框架的设计者不会替你决定。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

在PHP中可以通過使用不可預測的令牌來有效防範CSRF攻擊。具體方法包括:1.生成並在表單中嵌入CSRF令牌;2.在處理請求時驗證令牌的有效性。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP的未來將通過適應新技術趨勢和引入創新特性來實現:1)適應云計算、容器化和微服務架構,支持Docker和Kubernetes;2)引入JIT編譯器和枚舉類型,提升性能和數據處理效率;3)持續優化性能和推廣最佳實踐。
