当前位置: 首页 > news >正文

石家庄桥西区网站建设网站这么做优化

石家庄桥西区网站建设,网站这么做优化,钢铁行业公司网站模板,房产网有哪些网站之前遇到过一个问题,在进行Hive的元数据采集时,因为Hive表的文件已经被删除了,当时是无法删除表,导致元数据采集也发生了问题,所以希望通过删除Hive表的元数据解决上述问题。 之前安装时,经过特定的配置后…

之前遇到过一个问题,在进行Hive的元数据采集时,因为Hive表的文件已经被删除了,当时是无法删除表,导致元数据采集也发生了问题,所以希望通过删除Hive表的元数据解决上述问题。

之前安装时,经过特定的配置后,Hive上所有元数据均保存在Mysql中,所以可以从Mysql上删除表相关信息即可删除hive表,而且不会影响Hdfs上数据。

解决方法:

1、Hive在Mysql上的相关元数据表关系图:

 2、先在Mysql中建存储过程:

DELIMITER $$
ROLLBACK;
DROP PROCEDURE IF EXISTS P_TBL_DATA_DEL$$
CREATE PROCEDURE P_TBL_DATA_DEL(i_tbl_name varchar(100) -- 表id
,out o_outcode integer  -- 输出代码
,out o_outmsg  varchar(500) --输出信息
COMMENT'从mysql数据库中制除Hive的元数据信息'
label_prot:
BEGIN/*====================================================================** 存储名称: 从MySQL数据库中删除Hive元数据                            ** 文件名称: P_TBL_DATA_DEL.sql                                       ** 调用示例:call P_TBL_DATA_DEL(tablename,@o_outcode,@o_outmsg);     **====================================================================*/
-- 自定义变量
DECLARE v_sd_id    int;
DECLARE v_part_id  int;
DECLARE v_cd_id    int;
DECLARE v_serde_id int;
DECLARE v_tbl_id   int;
DECLARE v_tbl_name varchar(100) ;
-- 异常声明
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
SET o_outcode = -1;
SET o_outmsg  ='failuro';
END;
-- 初始化变量
IF
i_tbl_name IS NOT NULL THEN
SET v_tbl_name = i_tbl_name;
ELSE  -- 否则默认赋值0
SET v_tbl_name = 0;
END IF;
-- START TRANSACTION
-- todo begin
-- 根据表名获取表ID
select TBL_ID into v_tbl_id from tbls where TBL_NAME = v_tbl_name;
-- 根据表ID获取存储配置ID(SDS.SD_ID)
select SD_ID into v_sd_id from tbls where TBL_ID = v_tbl_id;
-- 根据表ID获取分区ID(PARTITIONS.part_id)
select part_id into v_part_id from partitions where tbl_id = v_tbl_id:
-- 根据存储配置ID获取表字段信息和序列化类配置ID
select cd_id,serde_id into v_cd_id,v_serde_id from sds where sd_id = v_sd_id;
-- 册除表属性信息数据
delete from table_params where tbl_id = v_tbl id;
-- 删除表信息数据
delete from tbls where tbl_id = v_tbl_id;
-- 删除文件存储的基本信息数据
delete from sds where sd_id = v_sd_id;
-- 删除序列化属性信息数据
delete from serde_params wheras serde_id = v_serde_id;
-- 删除存储序列化使用的类信息数据
delete from serdes where serde_id = v_sd_id;
-- 删除表的字段信息
delete from colum ms_v2 where cd_id = v_cd_id;
-- 判断是否v_part_id值是否为空,如果不为空,表示分区属性和表分区字段值表有值,进行删除
IF v_part_id IS NOT NULL THAN
-- 删除分区属性信息
delete from partition_params where part_id = v_part_id;
-- 删除分区字段值表数据
delete from partition_key_vals where par_id = v_part_id;
END IF;
-- 删除分区信息数据
delete from partitions where tbl_id = v_tbl_id;
-- 删除分区字段信思
delete from partition_keys where tbl_id = v_tbl_id;-- 处理成功后的返回值
SET o_outcode = 0;
SET o_outmsg='succe';
END
$$
DELIMITER;

2、备份Hive的元数据库;

3、删除备份表的外键信息;

4、执行存储过程,即:

call P_TBL_DATA_DEL (‘需要删除的表英文名’,@o_outcode,@o_outmsg);

5、将删除的外键添加回去;

6、验证表hive中表是否还存在,即是否删除成功。

http://www.yayakq.cn/news/970891/

相关文章:

  • 网站开发文件wordpress布局构建器
  • 网站域名买卖营销网站开发找哪家
  • 威宁建设局网站上海专业做网站价格
  • 广丰区建设局网站广州市市场监督管理局
  • c s网站开发模式外贸网站设计模板
  • SEO案例网站建设公司长沙制作网站软件
  • 做网站 业务流程图网上广告设计培训
  • 站长之家怎么查询网站哪家做的wordpress漏洞利用2016
  • wordpress 中英文网站模板wordpress 栏目列表页
  • 增城做网站公司游戏开发需要学多久
  • 网站的文件结构郑州短视频代运营公司
  • 网站项目开发流程微信公众号托管代运营
  • 怎么看网站开发语言打造品牌的三点策略
  • 重庆铜梁网站建设公司百度提交入口
  • 顺德手机网站设计信息网站建设找宙斯站长工具
  • 江宁网站制作如何注册一家投资公司
  • 老板让我做镜像网站犯法吗成品视频直播软件推荐哪个好用
  • 后台管理网站模板linux wordpress 安装
  • 怎么做网站首页弹幕设计师培训体系
  • 网站上登录系统制作电商平台网址
  • 东莞行业网站建设教程网站建设管理工作的总结
  • 芜湖网络科技有限公司西安seo外包工作室
  • 上海福州路附近做网站的公司美术馆网站网页设计方案
  • php网站开发外文翻译四川省建设厅信息平台
  • wordpress pageaction.js位置seo网站优化方法
  • 制作企业网站的方法石家庄市和城乡建设局网站
  • 网站建设的业务范围免费手机
  • 创建手机网站营销策划方案1500字
  • 凡科建站联系电话wordpress+仿简书模板
  • 东莞网站设计与制作公司餐厅网站建设什么科目