Just get column names from hive table

2019-02-05 18:12发布

I know that you can get column names from a table via the following trick in hive:

hive> set hive.cli.print.header=true;
hive> select * from tablename;

Is it also possible to just get the column names from the table?

I dislike having to change a setting for something I only need once.

My current solution is the following:

hive> set hive.cli.print.header=true;
hive> select * from tablename;
hive> set hive.cli.print.header=false;

This seems too verbose and against the DRY-principle.

标签: sql hadoop hive
3条回答
叼着烟拽天下
2楼-- · 2019-02-05 18:46

you could also do show columns in $table or see Hive, how do I retrieve all the database's tables columns for access to hive metadata

查看更多
姐就是有狂的资本
3楼-- · 2019-02-05 19:00

If you simply want to see the column names this one line should provide it without changing any settings:

describe database.tablename;

However, if that doesn't work for your version of hive this code will provide it, but your default database will now be the database you are using:

use database;
describe tablename;
查看更多
smile是对你的礼貌
4楼-- · 2019-02-05 19:08

use desc tablename from Hive CLI or beeline to get all the column names. If you want the column names in a file then run the below command from the shell.

$ hive -e 'desc dbname.tablename;' > ~/columnnames.txt

where dbname is the name of the Hive database where your table is residing You can find the file columnnames.txt in your root directory.

$cd ~
$ls
查看更多
登录 后发表回答