Hi David
Does this belong in the release branch as well? I don't mind doing it, I'm just not sure without looking deeper and I thought you might know off hand. Thanks Scott On 06/06/07, [hidden email] <[hidden email]> wrote: > > Author: jonesde > Date: Tue Jun 5 14:24:21 2007 > New Revision: 544640 > > URL: http://svn.apache.org/viewvc?view=rev&rev=544640 > Log: > Change to adjust for Derby bug with null values in a unique index; this > setting just turns off the unique part of maually declared indices when set, > as it is now by default for Derby; now the seed data loading and other > things will work though WARNING: unique indices will not work with Derby; we > don't use these much but we need to watch for it in testing > > Modified: > ofbiz/trunk/framework/entity/config/entityengine.xml > ofbiz/trunk/framework/entity/dtd/entity-config.xsd > > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > > Modified: ofbiz/trunk/framework/entity/config/entityengine.xml > URL: > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/config/entityengine.xml?view=diff&rev=544640&r1=544639&r2=544640 > > ============================================================================== > --- ofbiz/trunk/framework/entity/config/entityengine.xml (original) > +++ ofbiz/trunk/framework/entity/config/entityengine.xml Tue Jun 5 > 14:24:21 2007 > @@ -140,6 +140,7 @@ > check-on-start="true" > add-missing-on-start="true" > use-pk-constraint-names="false" > + use-indices-unique="false" > alias-view-columns="false"> > <read-data reader-name="seed"/> > <read-data reader-name="demo"/> > @@ -161,6 +162,7 @@ > check-on-start="true" > add-missing-on-start="true" > use-pk-constraint-names="false" > + use-indices-unique="false" > alias-view-columns="false"> > <inline-jdbc > jdbc-driver="org.apache.derby.jdbc.EmbeddedDriver" > > Modified: ofbiz/trunk/framework/entity/dtd/entity-config.xsd > URL: > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/dtd/entity-config.xsd?view=diff&rev=544640&r1=544639&r2=544640 > > ============================================================================== > --- ofbiz/trunk/framework/entity/dtd/entity-config.xsd (original) > +++ ofbiz/trunk/framework/entity/dtd/entity-config.xsd Tue Jun 5 14:24:21 > 2007 > @@ -304,6 +304,16 @@ > </xs:simpleType> > </xs:attribute> > <xs:attribute name="use-indices" default="true"> > + <xs:annotation><xs:documentation>Use manually declared > indices (indexes)?</xs:documentation></xs:annotation> > + <xs:simpleType> > + <xs:restriction base="xs:token"> > + <xs:enumeration value="true"/> > + <xs:enumeration value="false"/> > + </xs:restriction> > + </xs:simpleType> > + </xs:attribute> > + <xs:attribute name="use-indices-unique" default="true"> > + <xs:annotation><xs:documentation>For manually declared > indices (if used), use the unique > constraint?</xs:documentation></xs:annotation> > <xs:simpleType> > <xs:restriction base="xs:token"> > <xs:enumeration value="true"/> > > Modified: > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > URL: > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java?view=diff&rev=544640&r1=544639&r2=544640 > > ============================================================================== > --- > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > (original) > +++ > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > Tue Jun 5 14:24:21 2007 > @@ -65,6 +65,7 @@ > public String fkStyle = null; > public boolean useFkInitiallyDeferred = true; > public boolean useIndices = true; > + public boolean useIndicesUnique = true; > public boolean checkIndicesOnStart = false; > public String joinStyle = null; > public boolean aliasViews = true; > @@ -99,6 +100,7 @@ > Debug.logWarning("datasource def not found with name " + > this.name + ", using default for fk-style (name_constraint)", module); > Debug.logWarning("datasource def not found with name " + > this.name + ", using default for use-fk-initially-deferred (true)", > module); > Debug.logWarning("datasource def not found with name " + > this.name + ", using default for use-indices (true)", module); > + Debug.logWarning("datasource def not found with name " + > this.name + ", using default for use-indices-unique (true)", module); > Debug.logWarning("datasource def not found with name " + > this.name + ", using default for check-indices-on-start (false)", module); > Debug.logWarning("datasource def not found with name " + > this.name + ", using default for join-style (ansi)", module); > Debug.logWarning("datasource def not found with name " + > this.name + ", using default for always-use-constraint-keyword (false)", > module); > @@ -144,6 +146,7 @@ > this.useFkInitiallyDeferred = "true".equals( > datasourceElement.getAttribute("use-fk-initially-deferred")); > // anything but false is true > this.useIndices = !"false".equals( > datasourceElement.getAttribute("use-indices")); > + this.useIndices = !"false".equals( > datasourceElement.getAttribute("use-indices-unique")); > // anything but true is false > this.checkIndicesOnStart = "true".equals( > datasourceElement.getAttribute("check-indices-on-start")); > this.joinStyle = datasourceElement.getAttribute > ("join-style"); > > Modified: > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > URL: > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java?view=diff&rev=544640&r1=544639&r2=544640 > > ============================================================================== > --- > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > (original) > +++ > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java Tue > Jun 5 14:24:21 2007 > @@ -2571,7 +2571,7 @@ > } > > StringBuffer indexSqlBuf = new StringBuffer("CREATE "); > - if (modelIndex.getUnique()) { > + if (datasourceInfo.useIndicesUnique && modelIndex.getUnique()) { > indexSqlBuf.append("UNIQUE "); > } > indexSqlBuf.append("INDEX "); > > > |
I don't think this should go into the release branch, but this is a borderline case. It is a new feature that makes it easier to compensate for a problem with Derby unique indices while still leaving those working for other DBs. The motivation for this is a few new indexes that are not in the branch so we don't need it for that reason. -David Scott Gray wrote: > Hi David > > Does this belong in the release branch as well? I don't mind doing it, I'm > just not sure without looking deeper and I thought you might know off hand. > > Thanks > Scott > > On 06/06/07, [hidden email] <[hidden email]> wrote: >> >> Author: jonesde >> Date: Tue Jun 5 14:24:21 2007 >> New Revision: 544640 >> >> URL: http://svn.apache.org/viewvc?view=rev&rev=544640 >> Log: >> Change to adjust for Derby bug with null values in a unique index; this >> setting just turns off the unique part of maually declared indices >> when set, >> as it is now by default for Derby; now the seed data loading and other >> things will work though WARNING: unique indices will not work with >> Derby; we >> don't use these much but we need to watch for it in testing >> >> Modified: >> ofbiz/trunk/framework/entity/config/entityengine.xml >> ofbiz/trunk/framework/entity/dtd/entity-config.xsd >> >> >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java >> >> >> >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java >> >> Modified: ofbiz/trunk/framework/entity/config/entityengine.xml >> URL: >> http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/config/entityengine.xml?view=diff&rev=544640&r1=544639&r2=544640 >> >> >> ============================================================================== >> >> --- ofbiz/trunk/framework/entity/config/entityengine.xml (original) >> +++ ofbiz/trunk/framework/entity/config/entityengine.xml Tue Jun 5 >> 14:24:21 2007 >> @@ -140,6 +140,7 @@ >> check-on-start="true" >> add-missing-on-start="true" >> use-pk-constraint-names="false" >> + use-indices-unique="false" >> alias-view-columns="false"> >> <read-data reader-name="seed"/> >> <read-data reader-name="demo"/> >> @@ -161,6 +162,7 @@ >> check-on-start="true" >> add-missing-on-start="true" >> use-pk-constraint-names="false" >> + use-indices-unique="false" >> alias-view-columns="false"> >> <inline-jdbc >> jdbc-driver="org.apache.derby.jdbc.EmbeddedDriver" >> >> Modified: ofbiz/trunk/framework/entity/dtd/entity-config.xsd >> URL: >> http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/dtd/entity-config.xsd?view=diff&rev=544640&r1=544639&r2=544640 >> >> >> ============================================================================== >> >> --- ofbiz/trunk/framework/entity/dtd/entity-config.xsd (original) >> +++ ofbiz/trunk/framework/entity/dtd/entity-config.xsd Tue Jun 5 >> 14:24:21 >> 2007 >> @@ -304,6 +304,16 @@ >> </xs:simpleType> >> </xs:attribute> >> <xs:attribute name="use-indices" default="true"> >> + <xs:annotation><xs:documentation>Use manually declared >> indices (indexes)?</xs:documentation></xs:annotation> >> + <xs:simpleType> >> + <xs:restriction base="xs:token"> >> + <xs:enumeration value="true"/> >> + <xs:enumeration value="false"/> >> + </xs:restriction> >> + </xs:simpleType> >> + </xs:attribute> >> + <xs:attribute name="use-indices-unique" default="true"> >> + <xs:annotation><xs:documentation>For manually declared >> indices (if used), use the unique >> constraint?</xs:documentation></xs:annotation> >> <xs:simpleType> >> <xs:restriction base="xs:token"> >> <xs:enumeration value="true"/> >> >> Modified: >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java >> >> URL: >> http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java?view=diff&rev=544640&r1=544639&r2=544640 >> >> >> ============================================================================== >> >> --- >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java >> >> (original) >> +++ >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java >> >> Tue Jun 5 14:24:21 2007 >> @@ -65,6 +65,7 @@ >> public String fkStyle = null; >> public boolean useFkInitiallyDeferred = true; >> public boolean useIndices = true; >> + public boolean useIndicesUnique = true; >> public boolean checkIndicesOnStart = false; >> public String joinStyle = null; >> public boolean aliasViews = true; >> @@ -99,6 +100,7 @@ >> Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for fk-style (name_constraint)", module); >> Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for use-fk-initially-deferred (true)", >> module); >> Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for use-indices (true)", module); >> + Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for use-indices-unique (true)", module); >> Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for check-indices-on-start (false)", >> module); >> Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for join-style (ansi)", module); >> Debug.logWarning("datasource def not found with name " + >> this.name + ", using default for always-use-constraint-keyword (false)", >> module); >> @@ -144,6 +146,7 @@ >> this.useFkInitiallyDeferred = "true".equals( >> datasourceElement.getAttribute("use-fk-initially-deferred")); >> // anything but false is true >> this.useIndices = !"false".equals( >> datasourceElement.getAttribute("use-indices")); >> + this.useIndices = !"false".equals( >> datasourceElement.getAttribute("use-indices-unique")); >> // anything but true is false >> this.checkIndicesOnStart = "true".equals( >> datasourceElement.getAttribute("check-indices-on-start")); >> this.joinStyle = datasourceElement.getAttribute >> ("join-style"); >> >> Modified: >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java >> URL: >> http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java?view=diff&rev=544640&r1=544639&r2=544640 >> >> >> ============================================================================== >> >> --- >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java >> (original) >> +++ >> ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java >> Tue >> Jun 5 14:24:21 2007 >> @@ -2571,7 +2571,7 @@ >> } >> >> StringBuffer indexSqlBuf = new StringBuffer("CREATE "); >> - if (modelIndex.getUnique()) { >> + if (datasourceInfo.useIndicesUnique && modelIndex.getUnique()) { >> indexSqlBuf.append("UNIQUE "); >> } >> indexSqlBuf.append("INDEX "); >> >> >> > |
Great, thanks David
On 07/06/07, David E Jones <[hidden email]> wrote: > > > I don't think this should go into the release branch, but this is a > borderline case. It is a new feature that makes it easier to compensate for > a problem with Derby unique indices while still leaving those working for > other DBs. The motivation for this is a few new indexes that are not in the > branch so we don't need it for that reason. > > -David > > > Scott Gray wrote: > > Hi David > > > > Does this belong in the release branch as well? I don't mind doing it, > I'm > > just not sure without looking deeper and I thought you might know off > hand. > > > > Thanks > > Scott > > > > On 06/06/07, [hidden email] <[hidden email]> wrote: > >> > >> Author: jonesde > >> Date: Tue Jun 5 14:24:21 2007 > >> New Revision: 544640 > >> > >> URL: http://svn.apache.org/viewvc?view=rev&rev=544640 > >> Log: > >> Change to adjust for Derby bug with null values in a unique index; this > >> setting just turns off the unique part of maually declared indices > >> when set, > >> as it is now by default for Derby; now the seed data loading and other > >> things will work though WARNING: unique indices will not work with > >> Derby; we > >> don't use these much but we need to watch for it in testing > >> > >> Modified: > >> ofbiz/trunk/framework/entity/config/entityengine.xml > >> ofbiz/trunk/framework/entity/dtd/entity-config.xsd > >> > >> > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > >> > >> > >> > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > >> > >> Modified: ofbiz/trunk/framework/entity/config/entityengine.xml > >> URL: > >> > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/config/entityengine.xml?view=diff&rev=544640&r1=544639&r2=544640 > >> > >> > >> > ============================================================================== > >> > >> --- ofbiz/trunk/framework/entity/config/entityengine.xml (original) > >> +++ ofbiz/trunk/framework/entity/config/entityengine.xml Tue Jun 5 > >> 14:24:21 2007 > >> @@ -140,6 +140,7 @@ > >> check-on-start="true" > >> add-missing-on-start="true" > >> use-pk-constraint-names="false" > >> + use-indices-unique="false" > >> alias-view-columns="false"> > >> <read-data reader-name="seed"/> > >> <read-data reader-name="demo"/> > >> @@ -161,6 +162,7 @@ > >> check-on-start="true" > >> add-missing-on-start="true" > >> use-pk-constraint-names="false" > >> + use-indices-unique="false" > >> alias-view-columns="false"> > >> <inline-jdbc > >> jdbc-driver="org.apache.derby.jdbc.EmbeddedDriver" > >> > >> Modified: ofbiz/trunk/framework/entity/dtd/entity-config.xsd > >> URL: > >> > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/dtd/entity-config.xsd?view=diff&rev=544640&r1=544639&r2=544640 > >> > >> > >> > ============================================================================== > >> > >> --- ofbiz/trunk/framework/entity/dtd/entity-config.xsd (original) > >> +++ ofbiz/trunk/framework/entity/dtd/entity-config.xsd Tue Jun 5 > >> 14:24:21 > >> 2007 > >> @@ -304,6 +304,16 @@ > >> </xs:simpleType> > >> </xs:attribute> > >> <xs:attribute name="use-indices" default="true"> > >> + <xs:annotation><xs:documentation>Use manually declared > >> indices (indexes)?</xs:documentation></xs:annotation> > >> + <xs:simpleType> > >> + <xs:restriction base="xs:token"> > >> + <xs:enumeration value="true"/> > >> + <xs:enumeration value="false"/> > >> + </xs:restriction> > >> + </xs:simpleType> > >> + </xs:attribute> > >> + <xs:attribute name="use-indices-unique" default="true"> > >> + <xs:annotation><xs:documentation>For manually declared > >> indices (if used), use the unique > >> constraint?</xs:documentation></xs:annotation> > >> <xs:simpleType> > >> <xs:restriction base="xs:token"> > >> <xs:enumeration value="true"/> > >> > >> Modified: > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > >> > >> URL: > >> > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java?view=diff&rev=544640&r1=544639&r2=544640 > >> > >> > >> > ============================================================================== > >> > >> --- > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > >> > >> (original) > >> +++ > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/config/DatasourceInfo.java > >> > >> Tue Jun 5 14:24:21 2007 > >> @@ -65,6 +65,7 @@ > >> public String fkStyle = null; > >> public boolean useFkInitiallyDeferred = true; > >> public boolean useIndices = true; > >> + public boolean useIndicesUnique = true; > >> public boolean checkIndicesOnStart = false; > >> public String joinStyle = null; > >> public boolean aliasViews = true; > >> @@ -99,6 +100,7 @@ > >> Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for fk-style (name_constraint)", module); > >> Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for use-fk-initially-deferred (true)", > >> module); > >> Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for use-indices (true)", module); > >> + Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for use-indices-unique (true)", module); > >> Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for check-indices-on-start (false)", > >> module); > >> Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for join-style (ansi)", module); > >> Debug.logWarning("datasource def not found with name " + > >> this.name + ", using default for always-use-constraint-keyword > (false)", > >> module); > >> @@ -144,6 +146,7 @@ > >> this.useFkInitiallyDeferred = "true".equals( > >> datasourceElement.getAttribute("use-fk-initially-deferred")); > >> // anything but false is true > >> this.useIndices = !"false".equals( > >> datasourceElement.getAttribute("use-indices")); > >> + this.useIndices = !"false".equals( > >> datasourceElement.getAttribute("use-indices-unique")); > >> // anything but true is false > >> this.checkIndicesOnStart = "true".equals( > >> datasourceElement.getAttribute("check-indices-on-start")); > >> this.joinStyle = datasourceElement.getAttribute > >> ("join-style"); > >> > >> Modified: > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > >> URL: > >> > http://svn.apache.org/viewvc/ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java?view=diff&rev=544640&r1=544639&r2=544640 > >> > >> > >> > ============================================================================== > >> > >> --- > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > >> (original) > >> +++ > >> > ofbiz/trunk/framework/entity/src/org/ofbiz/entity/jdbc/DatabaseUtil.java > >> Tue > >> Jun 5 14:24:21 2007 > >> @@ -2571,7 +2571,7 @@ > >> } > >> > >> StringBuffer indexSqlBuf = new StringBuffer("CREATE "); > >> - if (modelIndex.getUnique()) { > >> + if (datasourceInfo.useIndicesUnique && modelIndex.getUnique()) > { > >> indexSqlBuf.append("UNIQUE "); > >> } > >> indexSqlBuf.append("INDEX "); > >> > >> > >> > > > |
Free forum by Nabble | Edit this page |