
org.zoodb.tools.ZooHelper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of parent Show documentation
Show all versions of parent Show documentation
ZooDB Java JDO Object Database.
The newest version!
/*
* Copyright 2009-2013 Tilmann Zaeschke. All rights reserved.
*
* This file is part of ZooDB.
*
* ZooDB is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* ZooDB is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with ZooDB. If not, see .
*
* See the README and COPYING files for further information.
*/
package org.zoodb.tools;
import java.lang.reflect.Constructor;
import javax.jdo.JDOFatalDataStoreException;
import javax.jdo.PersistenceManager;
import org.zoodb.jdo.api.DataStoreManager;
import org.zoodb.jdo.api.ZooConfig;
import org.zoodb.jdo.api.ZooJdoProperties;
import org.zoodb.jdo.api.impl.DBStatistics;
import org.zoodb.jdo.internal.Session;
public class ZooHelper {
private static DataStoreManager INSTANCE = null;
public static DataStoreManager getDataStoreManager() {
if (INSTANCE != null && ZooConfig.getFileManager().equals(INSTANCE.getClass().getName())) {
return INSTANCE;
}
//create a new one
try {
Class> cls = Class.forName(ZooConfig.getFileManager());
Constructor> con = cls.getConstructor();
DataStoreManager dsm = (DataStoreManager) con.newInstance();
INSTANCE = dsm;
return dsm;
} catch (Exception e) {
throw new JDOFatalDataStoreException("", e);
}
}
public static DBStatistics getStatistics(PersistenceManager pm) {
Session s = (Session) pm.getDataStoreConnection().getNativeConnection();
return new DBStatistics(s);
}
/**
* Create a database file.
*
* If only a file name is given, the database will create in %USER_HOME%/zoodb on Windows
* or ~/zoodb on Linux/UNIX.
*
* If a full path is given, the full path will be used instead.
*
* Any necessary parent folders are created automatically.
* It is recommended to use .zdb
as file extension, for example
* myDatabase.zdb
.
*
* @param dbName
* @see ZooJdoProperties#ZooJdoProperties(String)
* @see DataStoreManager#createDb(String)
*/
public static void createDb(String dbName) {
getDataStoreManager().createDb(dbName);
}
/**
* Check if a database exists. This checks only whether the file exists, not whether it is a
* valid database file.
*
* @param dbName
* @return true
if the database exists.
* @see DataStoreManager#dbExists(String)
*/
public static boolean dbExists(String dbName) {
return getDataStoreManager().dbExists(dbName);
}
/**
* Delete a database(-file).
* @param dbName
* @see DataStoreManager#removeDb(String)
*/
public static void removeDb(String dbName) {
getDataStoreManager().removeDb(dbName);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy