Subquery for FROM clause in MySQL 5.0 views: limitations and workarounds
MySQL 5.0 users may encounter an error when trying to create a view that contains a subquery in the FROM clause. The error message is "ERROR 1349 (HY000): View's SELECT contains a subquery in the FROM clause." This limitation prevents Create views based on complex queries containing subqueries.
One possible workaround is to create separate views for each subquery and then replace the subqueries with these derived views. Consider the following example query:
<code class="language-sql">SELECT temp.UserName FROM ( SELECT u1.name AS UserName, COUNT(m1.UserFromId) AS SentCount FROM Message m1, User u1 WHERE u1.uid = m1.UserFromId GROUP BY u1.name HAVING SentCount > 3 ) AS temp;</code>
To circumvent this limitation, a view can be created for both subqueries:
<code class="language-sql">CREATE VIEW v_user_sent_count AS SELECT u1.name AS UserName, COUNT(m1.UserFromId) AS SentCount FROM Message m1, User u1 WHERE u1.uid = m1.UserFromId GROUP BY u1.name; CREATE VIEW v_users_sent_over_3 AS SELECT UserName FROM v_user_sent_count WHERE SentCount > 3;</code>
In the original query, replace the subquery with the derived view:
<code class="language-sql">SELECT UserName FROM v_users_sent_over_3;</code>
This approach allows creating views based on complex subqueries in versions of MySQL where subquery restrictions in the FROM clause exist. However, it should be noted that not all subqueries can be expressed without the FROM clause. For example, subqueries used for sorting or filtering may require other methods, such as using correlated subqueries or window functions.
The above is the detailed content of MySQL Views and Subqueries in the FROM Clause: How to Overcome the 5.0 Limitation?. For more information, please follow other related articles on the PHP Chinese website!