You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cassandra.apache.org by jb...@apache.org on 2009/04/17 22:08:05 UTC
svn commit: r766133 -
/incubator/cassandra/trunk/src/org/apache/cassandra/service/CassandraServer.java
Author: jbellis
Date: Fri Apr 17 20:08:05 2009
New Revision: 766133
URL: http://svn.apache.org/viewvc?rev=766133&view=rev
Log:
omit tombstones from column_t and supercolumn_t returned to client.
patch by jbellis; reviewed by Eric Evans for #33
Modified:
incubator/cassandra/trunk/src/org/apache/cassandra/service/CassandraServer.java
Modified: incubator/cassandra/trunk/src/org/apache/cassandra/service/CassandraServer.java
URL: http://svn.apache.org/viewvc/incubator/cassandra/trunk/src/org/apache/cassandra/service/CassandraServer.java?rev=766133&r1=766132&r2=766133&view=diff
==============================================================================
--- incubator/cassandra/trunk/src/org/apache/cassandra/service/CassandraServer.java (original)
+++ incubator/cassandra/trunk/src/org/apache/cassandra/service/CassandraServer.java Fri Apr 17 20:08:05 2009
@@ -37,6 +37,7 @@
import org.apache.cassandra.db.IColumn;
import org.apache.cassandra.db.Row;
import org.apache.cassandra.db.RowMutation;
+import org.apache.cassandra.db.Column;
import org.apache.cassandra.utils.LogUtil;
import org.apache.thrift.TException;
@@ -119,9 +120,23 @@
return cfamily;
}
- public ArrayList<column_t> get_columns_since(String tablename, String key, String columnFamily_column, long timeStamp) throws CassandraException,TException
+ public List<column_t> thriftifyColumns(Collection<IColumn> columns)
+ {
+ ArrayList<column_t> thriftColumns = new ArrayList<column_t>(columns.size());
+ for (IColumn column : columns)
+ {
+ if (column.isMarkedForDelete())
+ {
+ continue;
+ }
+ column_t thrift_column = new column_t(column.name(), new String(column.value()), column.timestamp());
+ thriftColumns.add(thrift_column);
+ }
+ return thriftColumns;
+ }
+
+ public List<column_t> get_columns_since(String tablename, String key, String columnFamily_column, long timeStamp) throws CassandraException,TException
{
- ArrayList<column_t> retlist = new ArrayList<column_t>();
long startTime = System.currentTimeMillis();
try
{
@@ -168,14 +183,8 @@
logger_ .info("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
}
- for(IColumn column : columns)
- {
- column_t thrift_column = new column_t();
- thrift_column.columnName = column.name();
- thrift_column.value = new String(column.value()); // This needs to be Utf8ed
- thrift_column.timestamp = column.timestamp();
- retlist.add(thrift_column);
- }
+
+ return thriftifyColumns(columns);
}
catch (Exception ex)
{
@@ -183,14 +192,15 @@
logger_.info( exception );
throw new CassandraException(exception);
}
- logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime) + " ms.");
- return retlist;
+ finally
+ {
+ logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime) + " ms.");
+ }
}
public List<column_t> get_slice_by_names(String tablename, String key, String columnFamily, List<String> columnNames) throws CassandraException, TException
{
- ArrayList<column_t> retlist = new ArrayList<column_t>();
long startTime = System.currentTimeMillis();
try
{
@@ -212,15 +222,8 @@
+ " ColumnFamily:" + columnFamily);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + columnFamily);
}
-
- for(IColumn column : columns)
- {
- column_t thrift_column = new column_t();
- thrift_column.columnName = column.name();
- thrift_column.value = new String(column.value()); // This needs to be Utf8ed
- thrift_column.timestamp = column.timestamp();
- retlist.add(thrift_column);
- }
+
+ return thriftifyColumns(columns);
}
catch (Exception ex)
{
@@ -228,15 +231,14 @@
logger_.info( exception );
throw new CassandraException(exception);
}
-
- logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime)
- + " ms.");
- return retlist;
+ finally
+ {
+ logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime) + " ms.");
+ }
}
- public ArrayList<column_t> get_slice(String tablename, String key, String columnFamily_column, int start, int count) throws CassandraException,TException
+ public List<column_t> get_slice(String tablename, String key, String columnFamily_column, int start, int count) throws CassandraException,TException
{
- ArrayList<column_t> retlist = new ArrayList<column_t>();
long startTime = System.currentTimeMillis();
try
{
@@ -283,14 +285,8 @@
logger_ .info("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
}
- for(IColumn column : columns)
- {
- column_t thrift_column = new column_t();
- thrift_column.columnName = column.name();
- thrift_column.value = new String(column.value()); // This needs to be Utf8ed
- thrift_column.timestamp = column.timestamp();
- retlist.add(thrift_column);
- }
+
+ return thriftifyColumns(columns);
}
catch (Exception ex)
{
@@ -298,14 +294,14 @@
logger_.info( exception );
throw new CassandraException(exception);
}
- logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime)
- + " ms.");
- return retlist;
+ finally
+ {
+ logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime) + " ms.");
+ }
}
public column_t get_column(String tablename, String key, String columnFamily_column) throws CassandraException,TException
{
- column_t ret = null;
try
{
validateTable(tablename);
@@ -357,13 +353,14 @@
+ " ColumnFamily:" + values[0]);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
}
- ret = new column_t();
- for(IColumn column : columns)
- {
- ret.columnName = column.name();
- ret.value = new String(column.value());
- ret.timestamp = column.timestamp();
- }
+
+ assert columns.size() == 1;
+ IColumn column = columns.iterator().next();
+ if (column.isMarkedForDelete())
+ {
+ return null;
+ }
+ return new column_t(column.name(), new String(column.value()), column.timestamp());
}
catch (Exception ex)
{
@@ -371,7 +368,6 @@
logger_.info( exception );
throw new CassandraException(exception);
}
- return ret;
}
@@ -485,7 +481,6 @@
public List<superColumn_t> get_slice_super_by_names(String tablename, String key, String columnFamily, List<String> superColumnNames) throws CassandraException, TException
{
- ArrayList<superColumn_t> retlist = new ArrayList<superColumn_t>();
long startTime = System.currentTimeMillis();
try
@@ -505,26 +500,8 @@
logger_ .info("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + columnFamily);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + columnFamily);
}
-
- for(IColumn column : columns)
- {
- superColumn_t thrift_superColumn = new superColumn_t();
- thrift_superColumn.name = column.name();
- Collection<IColumn> subColumns = column.getSubColumns();
- if(subColumns.size() != 0 )
- {
- thrift_superColumn.columns = new ArrayList<column_t>();
- for( IColumn subColumn : subColumns )
- {
- column_t thrift_column = new column_t();
- thrift_column.columnName = subColumn.name();
- thrift_column.value = new String(subColumn.value());
- thrift_column.timestamp = subColumn.timestamp();
- thrift_superColumn.columns.add(thrift_column);
- }
- }
- retlist.add(thrift_superColumn);
- }
+
+ return thriftifySuperColumns(columns);
}
catch (Exception ex)
{
@@ -532,15 +509,29 @@
logger_.info( exception );
throw new CassandraException(exception);
}
- logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime)
- + " ms.");
- return retlist;
+ finally
+ {
+ logger_.debug("get_slice2: " + (System.currentTimeMillis() - startTime) + " ms.");
+ }
}
-
- public ArrayList<superColumn_t> get_slice_super(String tablename, String key, String columnFamily_superColumnName, int start, int count) throws CassandraException
+ private List<superColumn_t> thriftifySuperColumns(Collection<IColumn> columns)
+ {
+ ArrayList<superColumn_t> thriftSuperColumns = new ArrayList<superColumn_t>(columns.size());
+ for (IColumn column : columns)
+ {
+ if (column.getSubColumns().size() == 0)
+ {
+ continue;
+ }
+ thriftSuperColumns.add(new superColumn_t(column.name(), thriftifyColumns(column.getSubColumns())));
+ }
+ return thriftSuperColumns;
+ }
+
+
+ public List<superColumn_t> get_slice_super(String tablename, String key, String columnFamily_superColumnName, int start, int count) throws CassandraException
{
- ArrayList<superColumn_t> retlist = new ArrayList<superColumn_t>();
try
{
validateTable(tablename);
@@ -581,26 +572,8 @@
+ " ColumnFamily:" + values[0]);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
}
-
- for(IColumn column : columns)
- {
- superColumn_t thrift_superColumn = new superColumn_t();
- thrift_superColumn.name = column.name();
- Collection<IColumn> subColumns = column.getSubColumns();
- if(subColumns.size() != 0 )
- {
- thrift_superColumn.columns = new ArrayList<column_t>();
- for( IColumn subColumn : subColumns )
- {
- column_t thrift_column = new column_t();
- thrift_column.columnName = subColumn.name();
- thrift_column.value = new String(subColumn.value());
- thrift_column.timestamp = subColumn.timestamp();
- thrift_superColumn.columns.add(thrift_column);
- }
- }
- retlist.add(thrift_superColumn);
- }
+
+ return thriftifySuperColumns(columns);
}
catch (Exception ex)
{
@@ -608,8 +581,6 @@
logger_.info( exception );
throw new CassandraException(exception);
}
- return retlist;
-
}
public superColumn_t get_superColumn(String tablename, String key, String columnFamily_column) throws CassandraException
@@ -656,25 +627,18 @@
+ " ColumnFamily:" + values[0]);
throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
}
-
- for(IColumn column : columns)
- {
- ret = new superColumn_t();
- ret.name = column.name();
- Collection<IColumn> subColumns = column.getSubColumns();
- if(subColumns.size() != 0 )
- {
- ret.columns = new ArrayList<column_t>();
- for(IColumn subColumn : subColumns)
- {
- column_t thrift_column = new column_t();
- thrift_column.columnName = subColumn.name();
- thrift_column.value = new String(subColumn.value());
- thrift_column.timestamp = subColumn.timestamp();
- ret.columns.add(thrift_column);
- }
- }
- }
+
+ assert columns.size() == 1;
+ IColumn column = columns.iterator().next();
+ if (column.getSubColumns().size() == 0)
+ {
+ logger_ .info("ERROR Columns are missing.....: "
+ + " key:" + key
+ + " ColumnFamily:" + values[0]);
+ throw new CassandraException("ERROR Columns are missing.....: " + " key:" + key + " ColumnFamily:" + values[0]);
+ }
+
+ return new superColumn_t(column.name(), thriftifyColumns(column.getSubColumns()));
}
catch (Exception ex)
{
@@ -682,8 +646,6 @@
logger_.info( exception );
throw new CassandraException(exception);
}
- return ret;
-
}
public boolean batch_insert_superColumn_blocking(batch_mutation_super_t batchMutationSuper)