git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@4042 6c8d7289-2bf4-0310-a012-ef5d649a1542pull/1/head
parent
5cf634a4a4
commit
3ca8f71cbb
@ -0,0 +1,299 @@
|
|||||||
|
// kelondroSQLTable.java
|
||||||
|
// this class was written by Martin Thelian
|
||||||
|
// (the class was once a sub-class of dbtest.java)
|
||||||
|
//
|
||||||
|
// This is a part of YaCy, a peer-to-peer based web search engine
|
||||||
|
//
|
||||||
|
// $LastChangedDate: 2006-04-02 22:40:07 +0200 (So, 02 Apr 2006) $
|
||||||
|
// $LastChangedRevision: 1986 $
|
||||||
|
// $LastChangedBy: orbiter $
|
||||||
|
//
|
||||||
|
// LICENSE
|
||||||
|
//
|
||||||
|
// This program 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 2 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// This program 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 this program; if not, write to the Free Software
|
||||||
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
package de.anomic.kelondro;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.DriverManager;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import de.anomic.kelondro.kelondroRow.Entry;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Commands to create a database using mysql:
|
||||||
|
*
|
||||||
|
* CREATE database yacy;
|
||||||
|
* USE yacy;
|
||||||
|
* CREATE TABLE hash CHAR(12) not null primary key, value BLOB);
|
||||||
|
* insert into user (Host, User, Password) values ('%','yacy',password('yacy'));
|
||||||
|
* insert into db (User, Db, Select_priv, Insert_priv, Update_priv, Delete_priv) values ('yacy@%','yacy','Y','Y','Y','Y')
|
||||||
|
* grant ALL on yacy.* to yacy;
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class kelondroSQLTable implements kelondroIndex {
|
||||||
|
|
||||||
|
private final String db_driver_str_mysql = "org.gjt.mm.mysql.Driver";
|
||||||
|
private final String db_driver_str_pgsql = "org.postgresql.Driver";
|
||||||
|
|
||||||
|
private final String db_conn_str_mysql = "jdbc:mysql://192.168.0.2:3306/yacy";
|
||||||
|
private final String db_conn_str_pgsql = "jdbc:postgresql://192.168.0.2:5432";
|
||||||
|
|
||||||
|
private final String db_usr_str = "yacy";
|
||||||
|
private final String db_pwd_str = "yacy";
|
||||||
|
|
||||||
|
private Connection theDBConnection = null;
|
||||||
|
private final kelondroOrder order = new kelondroNaturalOrder(true);
|
||||||
|
private kelondroRow rowdef;
|
||||||
|
|
||||||
|
public kelondroSQLTable(String dbType, kelondroRow rowdef) throws Exception {
|
||||||
|
this.rowdef = rowdef;
|
||||||
|
openDatabaseConnection(dbType);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void openDatabaseConnection(String dbType) throws Exception{
|
||||||
|
|
||||||
|
if (dbType == null) throw new IllegalArgumentException();
|
||||||
|
|
||||||
|
String dbDriverStr = null, dbConnStr = null;
|
||||||
|
if (dbType.equalsIgnoreCase("mysql")) {
|
||||||
|
dbDriverStr = db_driver_str_mysql;
|
||||||
|
dbConnStr = db_conn_str_mysql;
|
||||||
|
} else if (dbType.equalsIgnoreCase("pgsql")) {
|
||||||
|
dbDriverStr = db_driver_str_pgsql;
|
||||||
|
dbConnStr = db_conn_str_pgsql;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
Class.forName(dbDriverStr).newInstance();
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new Exception ("Unable to load the jdbc driver: " + e.getMessage(),e);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
this.theDBConnection = DriverManager.getConnection (dbConnStr,this.db_usr_str,this.db_pwd_str);
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new Exception ("Unable to establish a database connection: " + e.getMessage(),e);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public String filename() {
|
||||||
|
return "dbtest." + theDBConnection.hashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void close() {
|
||||||
|
if (this.theDBConnection != null) try {
|
||||||
|
this.theDBConnection.close();
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
this.theDBConnection = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int size() {
|
||||||
|
int size = -1;
|
||||||
|
try {
|
||||||
|
String sqlQuery = new String
|
||||||
|
(
|
||||||
|
"SELECT count(value) from test"
|
||||||
|
);
|
||||||
|
|
||||||
|
PreparedStatement sqlStatement = this.theDBConnection.prepareStatement(sqlQuery);
|
||||||
|
ResultSet result = sqlStatement.executeQuery();
|
||||||
|
|
||||||
|
while (result.next()) {
|
||||||
|
size = result.getInt(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
result.close();
|
||||||
|
sqlStatement.close();
|
||||||
|
|
||||||
|
return size;
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroRow row() {
|
||||||
|
return this.rowdef;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean has(byte[] key) throws IOException {
|
||||||
|
return (get(key) != null);
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroRow.Entry get(byte[] key) throws IOException {
|
||||||
|
try {
|
||||||
|
String sqlQuery = new String
|
||||||
|
(
|
||||||
|
"SELECT value from test where hash = ?"
|
||||||
|
);
|
||||||
|
|
||||||
|
PreparedStatement sqlStatement = this.theDBConnection.prepareStatement(sqlQuery);
|
||||||
|
sqlStatement.setString(1, new String(key));
|
||||||
|
|
||||||
|
byte[] value = null;
|
||||||
|
ResultSet result = sqlStatement.executeQuery();
|
||||||
|
while (result.next()) {
|
||||||
|
value = result.getBytes("value");
|
||||||
|
}
|
||||||
|
|
||||||
|
result.close();
|
||||||
|
sqlStatement.close();
|
||||||
|
|
||||||
|
if (value == null) return null;
|
||||||
|
kelondroRow.Entry entry = this.rowdef.newEntry(value);
|
||||||
|
return entry;
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new IOException(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized void putMultiple(List rows) throws IOException {
|
||||||
|
Iterator i = rows.iterator();
|
||||||
|
while (i.hasNext()) put((Entry) i.next());
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroRow.Entry put(kelondroRow.Entry row, Date entryDate) throws IOException {
|
||||||
|
return put(row);
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroRow.Entry put(kelondroRow.Entry row) throws IOException {
|
||||||
|
try {
|
||||||
|
|
||||||
|
kelondroRow.Entry oldEntry = remove(row.getColBytes(0));
|
||||||
|
|
||||||
|
String sqlQuery = new String
|
||||||
|
(
|
||||||
|
"INSERT INTO test (" +
|
||||||
|
"hash, " +
|
||||||
|
"value) " +
|
||||||
|
"VALUES (?,?)"
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
PreparedStatement sqlStatement = this.theDBConnection.prepareStatement(sqlQuery);
|
||||||
|
|
||||||
|
sqlStatement.setString(1, new String(row.getColString(0, null)));
|
||||||
|
sqlStatement.setBytes(2, row.bytes());
|
||||||
|
sqlStatement.execute();
|
||||||
|
|
||||||
|
sqlStatement.close();
|
||||||
|
|
||||||
|
return oldEntry;
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new IOException(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized void addUnique(kelondroRow.Entry row) throws IOException {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized void addUnique(kelondroRow.Entry row, Date entryDate) {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public synchronized void addUniqueMultiple(List rows) throws IOException {
|
||||||
|
throw new UnsupportedOperationException();
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroRow.Entry remove(byte[] key) throws IOException {
|
||||||
|
try {
|
||||||
|
|
||||||
|
kelondroRow.Entry entry = this.get(key);
|
||||||
|
if (entry == null) return entry;
|
||||||
|
|
||||||
|
String sqlQuery = new String
|
||||||
|
(
|
||||||
|
"DELETE FROM test WHERE hash = ?"
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
PreparedStatement sqlStatement = this.theDBConnection.prepareStatement(sqlQuery);
|
||||||
|
sqlStatement.setString(1, new String(key));
|
||||||
|
sqlStatement.execute();
|
||||||
|
|
||||||
|
return entry;
|
||||||
|
} catch (Exception e) {
|
||||||
|
throw new IOException(e.getMessage());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroRow.Entry removeOne() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroCloneableIterator rows(boolean up, byte[] startKey) throws IOException {
|
||||||
|
// Objects are of type byte[][]
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Iterator keys(boolean up, boolean rotating, byte[] startKey) {
|
||||||
|
// Objects are of type String
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int columns() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int columnSize(int column) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroOrder order() {
|
||||||
|
return this.order;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int primarykey() {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public kelondroProfile profile() {
|
||||||
|
return new kelondroProfile();
|
||||||
|
}
|
||||||
|
|
||||||
|
public final int cacheObjectChunkSize() {
|
||||||
|
// dummy method
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long[] cacheObjectStatus() {
|
||||||
|
// dummy method
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final int cacheNodeChunkSize() {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final int[] cacheNodeStatus() {
|
||||||
|
return new int[]{0,0,0,0,0,0,0,0,0,0};
|
||||||
|
}
|
||||||
|
|
||||||
|
public void reset() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue