Author: jleroux
Date: Fri Sep 29 06:21:16 2017
New Revision: 1810054
URL: http://svn.apache.org/viewvc?rev=1810054&view=rev
Log:
Reverted: Bug SQL Count Distinct command in GenericDAO.java
(OFBIZ-5701)
Reverts
trunk r1804319
R16.11 r1804320
R15.12 r1804321
R14.12 r1804322
R13.07 r1804323
This raised 2 issues:
MSSQL as reported by Wei Zhang in OFBIZ-9676
Dynamic View Entities as reported by Pawan Verma in OFBIZ-5701
I asked kieuanhvu to see if he can provide a new patch taking these 2 issues in
consideration
Modified:
ofbiz/branches/release14.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
ofbiz/branches/release15.12/ (props changed)
ofbiz/branches/release15.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
ofbiz/branches/release16.11/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
ofbiz/ofbiz-framework/trunk/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
Modified:
ofbiz/branches/release14.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
URL:
http://svn.apache.org/viewvc/ofbiz/branches/release14.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java?rev=1810054&r1=1810053&r2=1810054&view=diff
==============================================================================
---
ofbiz/branches/release14.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
(original)
+++
ofbiz/branches/release14.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
Fri Sep 29 06:21:16 2017
@@ -1024,7 +1024,6 @@ public class GenericDAO {
}
boolean isGroupBy = false;
- boolean isCountGroup = false;
ModelViewEntity modelViewEntity = null;
if (modelEntity instanceof ModelViewEntity) {
modelViewEntity = (ModelViewEntity) modelEntity;
@@ -1055,20 +1054,11 @@ public class GenericDAO {
// if the field has a function already we don't want to
count just it, would be meaningless
sqlBuffer.append("COUNT(DISTINCT *) ");
} else {
- isCountGroup = true;
- StringBuilder sqlBufferTMP = new StringBuilder("SELECT
COUNT(*) FROM(");
- sqlBuffer.append("DISTINCT ");
- for (int i = 0; i < selectFields.size() - 1; i++) {
- ModelViewEntity.ModelAlias tmpMA = modelViewEntity !=
null ? modelViewEntity.getAlias(selectFields.get(i).getName()) : null;
- if (tmpMA != null && !tmpMA.getColAlias().isEmpty()) {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ " as " + tmpMA.getColAlias() + ",");
- } else {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ ",");
- }
- }
- sqlBuffer.append(selectFields.get(selectFields.size() -
1).getColValue());
- sqlBufferTMP.append(sqlBuffer);
- sqlBuffer = sqlBufferTMP;
+ sqlBuffer.append("COUNT(DISTINCT ");
+ // this only seems to support a single column, which is
not desirable but seems a lot better than no columns or in certain cases all
columns
+ sqlBuffer.append(firstSelectField.getColValue());
+ //
sqlBuffer.append(modelEntity.colNameString(selectFields, ", ", "",
datasource.aliasViews));
+ sqlBuffer.append(")");
}
} else {
sqlBuffer.append("COUNT(DISTINCT *) ");
@@ -1108,9 +1098,6 @@ public class GenericDAO {
if (isGroupBy) {
sqlBuffer.append(") TEMP_NAME");
}
- if (isCountGroup) {
- sqlBuffer.append(") TEMP_COUNT_NAME");
- }
String sql = sqlBuffer.toString();
if (Debug.verboseOn()) Debug.logVerbose("Count select sql: " + sql,
module);
Propchange: ofbiz/branches/release15.12/
------------------------------------------------------------------------------
--- svn:mergeinfo (original)
+++ svn:mergeinfo Fri Sep 29 06:21:16 2017
@@ -9,5 +9,5 @@
/ofbiz/branches/json-integration-refactoring:1634077-1635900
/ofbiz/branches/multitenant20100310:921280-927264
/ofbiz/branches/release13.07:1547657
-/ofbiz/ofbiz-framework/trunk:1786214,1786525,1787176,1789665,1789863,1789874,1791342,1791634,1796262,1798803,1798808,1799327,1800250,1804319,1805143,1805558,1806951
+/ofbiz/ofbiz-framework/trunk:1786214,1786525,1787176,1789665,1789863,1789874,1791342,1791634,1796262,1798803,1798808,1799327,1800250,1805143,1805558,1806951
/ofbiz/trunk:1722712,1723007,1723248,1724402,1724411,1724566,1724689,1724763,1724916,1724918,1724925,1724930,1724940,1724943,1724946,1724951,1724957,1724975,1724978,1725006,1725217,1725257,1725561,1725574,1726388,1726486,1726493,1726828,1727894,1728398,1728411,1729005,1729078,1729609,1729809,1730035,1730456,1730735-1730736,1730747,1730758,1730882,1730889,1731382,1731396,1732454,1732570,1732721,1733951,1733956,1734246,1734269,1734276,1734912,1734918,1735021,1735244,1735385,1735398,1735569,1735731,1735734,1735750,1735753,1735756,1735759,1735773,1736083,1736087,1736272,1736434,1736628,1736851,1736854,1736890,1737156,1737440,1738235,1738303,1738407,1738902,1739438,1739448,1739571,1740008,1740442,1740629,1741146,1741563,1741684,1741925,1741930,1741960,1742018,1742097,1742103,1742712,1742737,1742741,1743025,1743027,1743230,1743411-1743412,1743656,1743937,1744117,1744198,1744396,1744662,1744768,1744773,1744873,1744911,1745111,1745264,1745428,1745438,1745573,1745577,1745592,1745751,1746228,
1746422,1746459,1746524,1746527,1746536,1746601,1746676,1746714,1746755,1746805,1746832,1746890,1747223,1747349,1747402,1747498,1747639,1747642,1747646,1747650,1747661,1747956,1747959,1747963,1748121,1748133,1748206,1748218,1748223,1748260,1748357,1748394,1748401,1748543,1748559,1748628,1748689,1748693,1748703,1748837,1748854,1748907,1748925,1748929,1748944,1748972,1749026,1749083,1749092,1749111,1749220,1749282,1749519,1749525,1749543,1749546,1749552,1749704,1750045,1750166,1750336,1750555,1750624,1750651,1750922,1750925,1750940,1750959,1750964,1751030,1751042,1751357,1751362,1751423,1752928,1752933,1752941,1752947,1752954,1752956,1752966,1753834,1757963,1757968,1757992,1758017,1758089,1758143,1758280,1759002,1759005,1759014,1759024,1759678,1759941,1760406,1761127,1761170,1761179,1761492,1761618,1761678,1761978,1762331,1762738,1765017,1765038,1765104,1766074,1770481,1772346,1775441,1779724,1782520
Modified:
ofbiz/branches/release15.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
URL:
http://svn.apache.org/viewvc/ofbiz/branches/release15.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java?rev=1810054&r1=1810053&r2=1810054&view=diff
==============================================================================
---
ofbiz/branches/release15.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
(original)
+++
ofbiz/branches/release15.12/framework/entity/src/org/ofbiz/entity/datasource/GenericDAO.java
Fri Sep 29 06:21:16 2017
@@ -1024,7 +1024,6 @@ public class GenericDAO {
}
boolean isGroupBy = false;
- boolean isCountGroup = false;
ModelViewEntity modelViewEntity = null;
if (modelEntity instanceof ModelViewEntity) {
modelViewEntity = (ModelViewEntity) modelEntity;
@@ -1055,20 +1054,11 @@ public class GenericDAO {
// if the field has a function already we don't want to
count just it, would be meaningless
sqlBuffer.append("COUNT(DISTINCT *) ");
} else {
- isCountGroup = true;
- StringBuilder sqlBufferTMP = new StringBuilder("SELECT
COUNT(*) FROM(");
- sqlBuffer.append("DISTINCT ");
- for (int i = 0; i < selectFields.size() - 1; i++) {
- ModelViewEntity.ModelAlias tmpMA = modelViewEntity !=
null ? modelViewEntity.getAlias(selectFields.get(i).getName()) : null;
- if (tmpMA != null && !tmpMA.getColAlias().isEmpty()) {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ " as " + tmpMA.getColAlias() + ",");
- } else {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ ",");
- }
- }
- sqlBuffer.append(selectFields.get(selectFields.size() -
1).getColValue());
- sqlBufferTMP.append(sqlBuffer);
- sqlBuffer = sqlBufferTMP;
+ sqlBuffer.append("COUNT(DISTINCT ");
+ // this only seems to support a single column, which is
not desirable but seems a lot better than no columns or in certain cases all
columns
+ sqlBuffer.append(firstSelectField.getColValue());
+ //
sqlBuffer.append(modelEntity.colNameString(selectFields, ", ", "",
datasource.aliasViews));
+ sqlBuffer.append(")");
}
} else {
sqlBuffer.append("COUNT(DISTINCT *) ");
@@ -1108,9 +1098,6 @@ public class GenericDAO {
if (isGroupBy) {
sqlBuffer.append(") TEMP_NAME");
}
- if (isCountGroup) {
- sqlBuffer.append(") TEMP_COUNT_NAME");
- }
String sql = sqlBuffer.toString();
if (Debug.verboseOn()) Debug.logVerbose("Count select sql: " + sql,
module);
Modified:
ofbiz/branches/release16.11/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
URL:
http://svn.apache.org/viewvc/ofbiz/branches/release16.11/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java?rev=1810054&r1=1810053&r2=1810054&view=diff
==============================================================================
---
ofbiz/branches/release16.11/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
(original)
+++
ofbiz/branches/release16.11/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
Fri Sep 29 06:21:16 2017
@@ -1023,7 +1023,6 @@ public class GenericDAO {
}
boolean isGroupBy = false;
- boolean isCountGroup = false;
ModelViewEntity modelViewEntity = null;
if (modelEntity instanceof ModelViewEntity) {
modelViewEntity = (ModelViewEntity) modelEntity;
@@ -1054,20 +1053,11 @@ public class GenericDAO {
// if the field has a function already we don't want to
count just it, would be meaningless
sqlBuffer.append("COUNT(DISTINCT *) ");
} else {
- isCountGroup = true;
- StringBuilder sqlBufferTMP = new StringBuilder("SELECT
COUNT(*) FROM(");
- sqlBuffer.append("DISTINCT ");
- for (int i = 0; i < selectFields.size() - 1; i++) {
- ModelViewEntity.ModelAlias tmpMA = modelViewEntity !=
null ? modelViewEntity.getAlias(selectFields.get(i).getName()) : null;
- if (tmpMA != null && !tmpMA.getColAlias().isEmpty()) {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ " as " + tmpMA.getColAlias() + ",");
- } else {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ ",");
- }
- }
- sqlBuffer.append(selectFields.get(selectFields.size() -
1).getColValue());
- sqlBufferTMP.append(sqlBuffer);
- sqlBuffer = sqlBufferTMP;
+ sqlBuffer.append("COUNT(DISTINCT ");
+ // this only seems to support a single column, which is
not desirable but seems a lot better than no columns or in certain cases all
columns
+ sqlBuffer.append(firstSelectField.getColValue());
+ //
sqlBuffer.append(modelEntity.colNameString(selectFields, ", ", "",
datasource.aliasViews));
+ sqlBuffer.append(")");
}
} else {
sqlBuffer.append("COUNT(DISTINCT *) ");
@@ -1107,9 +1097,6 @@ public class GenericDAO {
if (isGroupBy) {
sqlBuffer.append(") TEMP_NAME");
}
- if (isCountGroup) {
- sqlBuffer.append(") TEMP_COUNT_NAME");
- }
String sql = sqlBuffer.toString();
if (Debug.verboseOn()) Debug.logVerbose("Count select sql: " + sql,
module);
Modified:
ofbiz/ofbiz-framework/trunk/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
URL:
http://svn.apache.org/viewvc/ofbiz/ofbiz-framework/trunk/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java?rev=1810054&r1=1810053&r2=1810054&view=diff
==============================================================================
---
ofbiz/ofbiz-framework/trunk/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
(original)
+++
ofbiz/ofbiz-framework/trunk/framework/entity/src/main/java/org/apache/ofbiz/entity/datasource/GenericDAO.java
Fri Sep 29 06:21:16 2017
@@ -1024,7 +1024,6 @@ public class GenericDAO {
}
boolean isGroupBy = false;
- boolean isCountGroup = false;
ModelViewEntity modelViewEntity = null;
if (modelEntity instanceof ModelViewEntity) {
modelViewEntity = (ModelViewEntity) modelEntity;
@@ -1055,20 +1054,11 @@ public class GenericDAO {
// if the field has a function already we don't want to
count just it, would be meaningless
sqlBuffer.append("COUNT(DISTINCT *) ");
} else {
- isCountGroup = true;
- StringBuilder sqlBufferTMP = new StringBuilder("SELECT
COUNT(*) FROM(");
- sqlBuffer.append("DISTINCT ");
- for (int i = 0; i < selectFields.size() - 1; i++) {
- ModelViewEntity.ModelAlias tmpMA = modelViewEntity !=
null ? modelViewEntity.getAlias(selectFields.get(i).getName()) : null;
- if (tmpMA != null && !tmpMA.getColAlias().isEmpty()) {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ " as " + tmpMA.getColAlias() + ",");
- } else {
- sqlBuffer.append(selectFields.get(i).getColValue()
+ ",");
- }
- }
- sqlBuffer.append(selectFields.get(selectFields.size() -
1).getColValue());
- sqlBufferTMP.append(sqlBuffer);
- sqlBuffer = sqlBufferTMP;
+ sqlBuffer.append("COUNT(DISTINCT ");
+ // this only seems to support a single column, which is
not desirable but seems a lot better than no columns or in certain cases all
columns
+ sqlBuffer.append(firstSelectField.getColValue());
+ //
sqlBuffer.append(modelEntity.colNameString(selectFields, ", ", "",
datasource.aliasViews));
+ sqlBuffer.append(")");
}
} else {
sqlBuffer.append("COUNT(DISTINCT *) ");
@@ -1108,9 +1098,6 @@ public class GenericDAO {
if (isGroupBy) {
sqlBuffer.append(") TEMP_NAME");
}
- if (isCountGroup) {
- sqlBuffer.append(") TEMP_COUNT_NAME");
- }
String sql = sqlBuffer.toString();
if (Debug.verboseOn()) Debug.logVerbose("Count select sql: " + sql,
module);