2017-05-26 04:48:44 +08:00
|
|
|
#
|
|
|
|
# micro_table.py
|
|
|
|
#
|
|
|
|
# This source file is part of the FoundationDB open source project
|
|
|
|
#
|
|
|
|
# Copyright 2013-2018 Apple Inc. and the FoundationDB project authors
|
2018-02-22 02:25:11 +08:00
|
|
|
#
|
2017-05-26 04:48:44 +08:00
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
2018-02-22 02:25:11 +08:00
|
|
|
#
|
2017-05-26 04:48:44 +08:00
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
2018-02-22 02:25:11 +08:00
|
|
|
#
|
2017-05-26 04:48:44 +08:00
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
#
|
|
|
|
|
|
|
|
import fdb
|
|
|
|
fdb.api_version(300)
|
|
|
|
db = fdb.open()
|
|
|
|
|
|
|
|
table = fdb.Subspace(('T',))
|
|
|
|
row_index = table['R']
|
|
|
|
col_index = table['C']
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
def _pack(value):
|
|
|
|
return fdb.tuple.pack((value,))
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
def _unpack(value):
|
|
|
|
return fdb.tuple.unpack(value)[0]
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
@fdb.transactional
|
|
|
|
def table_set_cell(tr, row, column, value):
|
|
|
|
tr[row_index[row][column]] = _pack(value)
|
|
|
|
tr[col_index[column][row]] = _pack(value)
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
@fdb.transactional
|
|
|
|
def table_get_cell(tr, row, column):
|
|
|
|
return tr[row_index[row][column]]
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
@fdb.transactional
|
|
|
|
def table_set_row(tr, row, cols):
|
|
|
|
del tr[row_index[row].range()]
|
|
|
|
for c, v in cols.iteritems():
|
|
|
|
table_set_cell(tr, row, c, v)
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
@fdb.transactional
|
|
|
|
def table_get_row(tr, row):
|
|
|
|
cols = {}
|
|
|
|
for k, v in tr[row_index[row].range()]:
|
|
|
|
r, c = row_index.unpack(k)
|
|
|
|
cols[c] = _unpack(v)
|
|
|
|
return cols
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
@fdb.transactional
|
|
|
|
def table_get_col(tr, col):
|
|
|
|
rows = {}
|
|
|
|
for k, v in tr[col_index[col].range()]:
|
|
|
|
c, r = col_index.unpack(k)
|
|
|
|
rows[r] = _unpack(v)
|
|
|
|
return rows
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
|
2017-05-26 04:48:44 +08:00
|
|
|
@fdb.transactional
|
|
|
|
def clear_subspace(tr, subspace):
|
|
|
|
tr.clear_range_startswith(subspace.key())
|
|
|
|
|
2018-01-25 11:06:58 +08:00
|
|
|
# clear_subspace(db, table)
|