hbase里面命令行删除_HBASE命令行演示

进入hbase命令行

./hbase shell

显示hbase中的表

list

创建user表,包含info、data两个列族

create 'user', 'info1', 'data1'

create 'user', {NAME => 'info', VERSIONS => '3'}

向user表中插入信息,row key为rk0001,列族info中添加name列标示符,值为zhangsan

put 'user', 'rk0001', 'info:name', 'zhangsan'

向user表中插入信息,row key为rk0001,列族info中添加gender列标示符,值为female

put 'user', 'rk0001', 'info:gender', 'female'

向user表中插入信息,row key为rk0001,列族info中添加age列标示符,值为20

put 'user', 'rk0001', 'info:age', 20

向user表中插入信息,row key为rk0001,列族data中添加pic列标示符,值为picture

put 'user', 'rk0001', 'data:pic', 'picture'

获取user表中row key为rk0001的所有信息

get 'user', 'rk0001'

获取user表中row key为rk0001,info列族的所有信息

get 'user', 'rk0001', 'info'

获取user表中row key为rk0001,info列族的name、age列标示符的信息

get 'user', 'rk0001', 'info:name', 'info:age'

获取user表中row key为rk0001,info、data列族的信息

get 'user', 'rk0001', 'info', 'data'

get 'user', 'rk0001', {COLUMN => ['info', 'data']}

get 'user', 'rk0001', {COLUMN => ['info:name', 'data:pic']}

获取user表中row key为rk0001,列族为info,版本号最新5个的信息

get 'user', 'rk0001', {COLUMN => 'info', VERSIONS => 2}

get 'user', 'rk0001', {COLUMN => 'info:name', VERSIONS => 5}

get 'user', 'rk0001', {COLUMN => 'info:name', VERSIONS => 5,

TIMERANGE => [1392368783980, 1392380169184]}

获取user表中row key为rk0001,cell的值为zhangsan的信息

get 'people', 'rk0001', {FILTER => "ValueFilter(=, 'binary:图片')"}

获取user表中row key为rk0001,列标示符中含有a的信息

get 'people', 'rk0001', {FILTER =>

"(QualifierFilter(=,'substring:a'))"}

put 'user', 'rk0002', 'info:name', 'fanbingbing'

put 'user', 'rk0002', 'info:gender', 'female'

put 'user', 'rk0002', 'info:nationality', '中国'

get 'user', 'rk0002', {FILTER => "ValueFilter(=, 'binary:中国')"}

查询user表中的所有信息

scan 'user'

查询user表中列族为info的信息

scan 'user', {COLUMNS => 'info'}

scan 'user', {COLUMNS => 'info', RAW => true, VERSIONS => 5}

scan 'persion', {COLUMNS => 'info', RAW => true, VERSIONS =>

3}

查询user表中列族为info和data的信息

scan 'user', {COLUMNS => ['info', 'data']}

scan 'user', {COLUMNS => ['info:name', 'data:pic']}

查询user表中列族为info、列标示符为name的信息

scan 'user', {COLUMNS => 'info:name'}

查询user表中列族为info、列标示符为name的信息,并且版本最新的5个

scan 'user', {COLUMNS => 'info:name', VERSIONS => 5}

查询user表中列族为info和data且列标示符中含有a字符的信息

scan 'user', {COLUMNS => ['info', 'data'], FILTER =>

"(QualifierFilter(=,'substring:a'))"}

查询user表中列族为info,rk范围是[rk0001, rk0003)的数据

scan 'people', {COLUMNS => 'info', STARTROW => 'rk0001', ENDROW =>

'rk0003'}

查询user表中row key以rk字符开头的

scan 'user',{FILTER=>"PrefixFilter('rk')"}

查询user表中指定范围的数据

scan 'user', {TIMERANGE => [1392368783980, 1392380169184]}

删除数据

删除user表row key为rk0001,列标示符为info:name的数据

delete 'people', 'rk0001', 'info:name'

删除user表row key为rk0001,列标示符为info:name,timestamp为1392383705316的数据

delete 'user', 'rk0001', 'info:name', 1392383705316

清空user表中的数据

truncate 'people'

修改表结构

首先停用user表(新版本不用)

disable 'user'

添加两个列族f1和f2

alter 'people', NAME => 'f1'

alter 'user', NAME => 'f2'

启用表

enable 'user'

###disable 'user'(新版本不用)

删除一个列族:

alter 'user', NAME => 'f1', METHOD => 'delete' 或 alter 'user',

'delete' => 'f1'

添加列族f1同时删除列族f2

alter 'user', {NAME => 'f1'}, {NAME => 'f2', METHOD =>

'delete'}

将user表的f1列族版本号改为5

alter 'people', NAME => 'info', VERSIONS => 5

启用表

enable 'user'

删除表

disable 'user'

drop 'user'

get 'person', 'rk0001', {FILTER => "ValueFilter(=, 'binary:中国')"}

get 'person', 'rk0001', {FILTER =>

"(QualifierFilter(=,'substring:a'))"}

scan 'person', {COLUMNS => 'info:name'}

scan 'person', {COLUMNS => ['info', 'data'], FILTER =>

"(QualifierFilter(=,'substring:a'))"}

scan 'person', {COLUMNS => 'info', STARTROW => 'rk0001', ENDROW =>

'rk0003'}

scan 'person', {COLUMNS => 'info', STARTROW => '20140201', ENDROW

=> '20140301'}

scan 'person', {COLUMNS => 'info:name', TIMERANGE => [1395978233636,

1395987769587]}

delete 'person', 'rk0001', 'info:name'

alter 'person', NAME => 'ffff'

alter 'person', NAME => 'info', VERSIONS => 10

get 'user', 'rk0002', {COLUMN => ['info:name', 'data:pic']}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的模拟HBase Shell命令行终端的应用程序,可以实现DDL分组和DML分组的常用操作命令: ```python class HBaseShell: def __init__(self): self.tables = {} # 存储所有表的数据 self.current_table = None # 当前操作的表名 def create_table(self, table_name, column_families): if table_name in self.tables: print(f"Table '{table_name}' already exists.") return self.tables[table_name] = {} for cf in column_families: self.tables[table_name][cf] = {} def list_tables(self): print("TABLE") print("------------------------------") for table_name in self.tables.keys(): print(table_name) def describe_table(self, table_name): if table_name not in self.tables: print(f"Table '{table_name}' does not exist.") return print(f"DESCRIPTION OF '{table_name}'") print("------------------------------") for cf in self.tables[table_name].keys(): print(cf) def put(self, row_key, column_family, column, value): if not self.current_table: print("No table selected.") return if column_family not in self.tables[self.current_table]: print(f"Column family '{column_family}' does not exist in table '{self.current_table}'.") return self.tables[self.current_table][column_family][f"{column}:{row_key}"] = value def get(self, row_key): if not self.current_table: print("No table selected.") return for cf, columns in self.tables[self.current_table].items(): for column, value in columns.items(): if row_key in column: print(f"{cf}:{column.split(':')[0]} {value}") def delete(self, row_key, column_family=None, column=None): if not self.current_table: print("No table selected.") return if column_family and column: del self.tables[self.current_table][column_family][f"{column}:{row_key}"] elif column_family: del self.tables[self.current_table][column_family] else: for cf in self.tables[self.current_table].keys(): for column in list(self.tables[self.current_table][cf].keys()): if row_key in column: del self.tables[self.current_table][cf][column] def select_table(self, table_name): if table_name not in self.tables: print(f"Table '{table_name}' does not exist.") return self.current_table = table_name def exit_shell(self): self.current_table = None print("Goodbye!") def help(self): print("""Available commands: CREATE TABLE <table_name> <column_family1> <column_family2> ... LIST TABLES DESCRIBE <table_name> PUT <row_key> <column_family> <column> <value> GET <row_key> DELETE <row_key> [<column_family> [<column>]] SELECT <table_name> EXIT HELP""") if __name__ == "__main__": shell = HBaseShell() while True: command = input("hbase> ") tokens = command.split() if not tokens: continue if tokens[0].lower() == "create" and len(tokens) >= 4 and tokens[1].lower() == "table": shell.create_table(tokens[2], tokens[3:]) elif tokens[0].lower() == "list" and tokens[1].lower() == "tables": shell.list_tables() elif tokens[0].lower() == "describe" and len(tokens) == 2: shell.describe_table(tokens[1]) elif tokens[0].lower() == "put" and len(tokens) == 5: shell.put(tokens[1], tokens[2], tokens[3], tokens[4]) elif tokens[0].lower() == "get" and len(tokens) == 2: shell.get(tokens[1]) elif tokens[0].lower() == "delete" and len(tokens) >= 2: if len(tokens) == 4: shell.delete(tokens[1], tokens[2], tokens[3]) elif len(tokens) == 3: shell.delete(tokens[1], tokens[2]) else: shell.delete(tokens[1]) elif tokens[0].lower() == "select" and len(tokens) == 2: shell.select_table(tokens[1]) elif tokens[0].lower() == "exit": shell.exit_shell() break elif tokens[0].lower() == "help": shell.help() else: print("Invalid command. Type 'help' for available commands.") ``` 这个程序支持以下命令: - `CREATE TABLE <table_name> <column_family1> <column_family2> ...`:创建一个新的表,包含指定的列族。 - `LIST TABLES`:列出所有已创建的表。 - `DESCRIBE <table_name>`:显示指定表的列族。 - `PUT <row_key> <column_family> <column> <value>`:将一个值存储到表中的指定行、列族和列。 - `GET <row_key>`:检索指定行的所有列族和列。 - `DELETE <row_key> [<column_family> [<column>]]`:删除指定行、列族和列的值。 - `SELECT <table_name>`:选择要操作的表。 - `EXIT`:退出程序。 - `HELP`:列出所有可用的命令。 注意:这个程序只是一个简单的演示,没有实现HBase的所有功能。在实际使用中,可能需要根据具体需求进行扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值