如何通过DFC代码获取当前版本标签号?
How to get CURRENT version label number through DFC code?
public static IDfCollection getVersions() {
IDfQuery query = clientX.getQuery();// obtain an idfObject
query.setDQL(
"select r_object_id,object_name,r_version_label,owner_name from dm_document(all) where i_chronicle_id='090008868006d5be'");
IDfCollection collection = null;
try {
collection = query.execute(SessionFile.getSession(), IDfQuery.DF_READ_QUERY);
} catch (DfException e) {
e.printStackTrace();
}
return collection;
}
public class Versions {
public static void main(String[] args) {
IDfCollection collection = AllOperations.getVersions();
try {
int versionsCount = collection.getValueCount("r_object_id");
//IDfSysObject dfSysObject=(IDfSysObject) SessionFile.getSession().getObject(new DfId("09000886800a143e"));
while (collection.next()) {
//String versionNum = dfSysObject.getVersionLabels().getImplicitVersionLabel();
int i = 0;
while (i < versionsCount) {
System.out.println(collection.getRepeatingValue("r_version_label", i));
i++;
}
}
} catch (DfException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Output of the above code is:
1.0,
1.1,
1.2,
CURRENT
代替 "CURRENT" 标签,我想 "get version number" 像 2.0 或 3.0 等,这是最新的文档版本号。
需要如下输出:
首先,这一行:
int versionsCount = collection.getValueCount("r_object_id");
应该是
int versionsCount = collection.getValueCount("r_version_label");
并且必须在 while(collection.next()) 循环中,这样它将正确地迭代所有 r_version_label 值,因此代码现在将输出:
1.0
1.1
1.2
CURRENT
2.0
您现在可以删除 CURRENT(或者通常删除所有无法解析为浮点数的非值)。
public static IDfCollection getVersions() {
IDfQuery query = clientX.getQuery();// obtain an idfObject
query.setDQL(
"select r_object_id,object_name,r_version_label,owner_name from dm_document(all) where i_chronicle_id='090008868006d5be'");
IDfCollection collection = null;
try {
collection = query.execute(SessionFile.getSession(), IDfQuery.DF_READ_QUERY);
} catch (DfException e) {
e.printStackTrace();
}
return collection;
}
public class Versions {
public static void main(String[] args) {
IDfCollection collection = AllOperations.getVersions();
try {
int versionsCount = collection.getValueCount("r_object_id");
//IDfSysObject dfSysObject=(IDfSysObject) SessionFile.getSession().getObject(new DfId("09000886800a143e"));
while (collection.next()) {
//String versionNum = dfSysObject.getVersionLabels().getImplicitVersionLabel();
int i = 0;
while (i < versionsCount) {
System.out.println(collection.getRepeatingValue("r_version_label", i));
i++;
}
}
} catch (DfException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
Output of the above code is: 1.0, 1.1, 1.2, CURRENT
代替 "CURRENT" 标签,我想 "get version number" 像 2.0 或 3.0 等,这是最新的文档版本号。
需要如下输出:
首先,这一行:
int versionsCount = collection.getValueCount("r_object_id");
应该是
int versionsCount = collection.getValueCount("r_version_label");
并且必须在 while(collection.next()) 循环中,这样它将正确地迭代所有 r_version_label 值,因此代码现在将输出:
1.0
1.1
1.2
CURRENT
2.0
您现在可以删除 CURRENT(或者通常删除所有无法解析为浮点数的非值)。