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

做旅游的网站有哪些/怎么做网络宣传推广

做旅游的网站有哪些,怎么做网络宣传推广,网站推广成功案例,wordpress自建站哪里换logo文章目录前言一、准备工作二、展现job_history表的数据三、对hr_job_history表进行范围分区1.根据某个字段值创建分区(1)创建分区表(2)插入数据(3)查询各分区表记录2.根据时间段创建分区(1)创建分区表(2)插…

文章目录

  • 前言
  • 一、准备工作
  • 二、展现job_history表的数据
  • 三、对hr_job_history表进行范围分区
    • 1.根据某个字段值创建分区
      • (1)创建分区表
      • (2)插入数据
      • (3)查询各分区表记录
    • 2.根据时间段创建分区
      • (1)创建分区表
      • (2)插入数据
      • (3)查询各分区表记录
  • 四、对hr_job_history表进行列表分区
    • 1.分区
    • 2.插入数据与查询
  • 五、对hr_job_history表进行散列分区
    • 1.分区
    • 2.插入数据与查询
  • 六、对hr_job_history表进行组合范围散列分区
    • 1.分区
    • 2.插入数据
    • 3.查询各分区表及子分区表
      • (1)查询hr_job_part01分区表及其子分区
  • 七、对hr_job_history表进行复合范围散列分区
    • 1.分区
    • 2.插入数据
    • 3.查询各分区表及子分区表
  • 总结


前言

由于创建一个新的数据表难以做到同时对一个数据表实现不同的分区策略,所以在这里我使用的是oracle的hr用户(系统自带的用户,可能需要进行解锁)下的job_history表中的数据,将其直接插入到一个新的数据表hr_job_history中(目的:为了不改变job_history表),之后实现不同分区策略的源数据表均为hr_job_history。

一、准备工作

oracle自带两个默认的用户:

SCOTT用户密码:tiger
hr用户密码:hr

解锁oracle数据库下的SCOTT和hr用户的方法(这里只阐述解锁hr):
(1)登陆oracle数据库:

Connect /as sysdba

(2)解锁hr用户:(对于SCOTT只需修改用户名即可,下同)

Alter user hr identified by hr account unlock;

(3)连接hr用户下的数据库:

connect hr/hr;

(4)查看hr用户中所有的表:

select table_name from user_tables;

二、展现job_history表的数据

select * 
from job_history;

在这里插入图片描述


三、对hr_job_history表进行范围分区

范围分区将数据基于指定的范围映射到不同分区,创建表时可以创建同时可以创建分区,当范围变大或想让范围变得更小时,可以添加分区。
这个范围是你在创建分区时指定的分区键决定的。这种分区方式是最为常用的,并且分区键经常采用日期。

1.根据某个字段值创建分区

(1)创建分区表

(按照employee_id范围划分)

create table hr_job_history(employee_id number(6) not null,start_date date,end_date date,job_id varchar2(10),department_id number(4)
) 
partition by range(employee_id)(partition hr_job_part01 values less than (140), partition hr_job_part02 values less than (180), partition hr_job_part03 values less than (maxvalue)
);

(2)插入数据

(将job_history表中的数据全部插入到hr_job_history表中)

insert into 
hr_job_history
select * from job_history;

(3)查询各分区表记录

select *
from hr_job_history partition (hr_job_part01);

在这里插入图片描述

select *
from hr_job_history partition (hr_job_part02);

在这里插入图片描述

select *
from hr_job_history partition (hr_job_part03);

在这里插入图片描述

2.根据时间段创建分区

(1)创建分区表

(按照时间start_date范围划分)

create table hr_job_history(employee_id number(6) not null,start_date date,end_date date,job_id varchar2(10),department_id number(4)
) 
partition by range(start_date)(partition hr_job_part01 values less than (to_date('2000-01-01','YYYY-MM-DD')), partition hr_job_part02 values less than (to_date('2005-01-01','YYYY-MM-DD')), partition hr_job_part03 values less than (to_date('2010-01-01','YYYY-MM-DD'))
);

(2)插入数据

(将job_history表中的数据全部插入到hr_job_history表中)

insert into 
hr_job_history
select * from job_history;

(3)查询各分区表记录

select *
from hr_job_history partition (hr_job_part01);

在这里插入图片描述

select *
from hr_job_history partition (hr_job_part02);

在这里插入图片描述

select *
from hr_job_history partition (hr_job_part03);

在这里插入图片描述


四、对hr_job_history表进行列表分区

该分区的特点是某列的值只有几个,基于这样的特点我们可以采用列表分区。

1.分区

(按照department_id这一列的值进行列表分区)

create table hr_job_history(employee_id number(6) not null,start_date date,end_date date,job_id varchar2(10),department_id number(4)
) 
partition by list(department_id)(partition hr_job_part01 values(20,50),partition hr_job_part02 values(60,80),partition hr_job_part03 values(90,110)
);

2.插入数据与查询

(插入数据和查询各分区表数据的sql命令与范围分区的相同)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


五、对hr_job_history表进行散列分区

这类分区是在列值上使用散列算法,以确定将行放入哪个分区中。当列的值没有合适的条件时,建议使用散列分区。
散列分区为通过指定分区编号来均匀分布数据的一种分区类型,因为通过在I/O设备上进行散列分区,使得这些分区大小一致。
Oracle中如果你要使用hash分区,只需指定分区的数量即可。建议分区的数量采用2的n次方,这样可以使得各个分区间数据分布更加均匀。

1.分区

(对employee_id这一列值使用hash算法,分区数量为3)

create table hr_job_history(employee_id number(6) not null,start_date date,end_date date,job_id varchar2(10),department_id number(4)
) 
partition by hash(employee_id)(partition hr_job_part01,partition hr_job_part02,partition hr_job_part03
)

2.插入数据与查询

(插入数据和查询各分区表数据的sql命令与范围分区的相同)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


六、对hr_job_history表进行组合范围散列分区

(即:范围-列表分区)

这种分区是基于范围分区和列表分区,表首先按某列进行范围分区,然后再按某列进行列表分区,分区之中的分区被称为子分区。

1.分区

(先对start_date进行范围分区,再对department_id进行列表分区)

create table hr_job_history(employee_id number(6) not null,start_date date,end_date date,job_id varchar2(10),department_id number(4)
) 
partition by range(start_date) subpartition by list(department_id)(partition hr_job_part01 values less than (to_date('2000-01-01','YYYY-MM-DD'))(
subpartition hr_job_part011 values(20,50),
subpartition hr_job_part021 values(60,80),
subpartition hr_job_part031 values(90,110)
),partition hr_job_part02 values less than (to_date('2005-01-01','YYYY-MM-DD'))(
subpartition hr_job_part012 values(20,50),
subpartition hr_job_part022 values(60,80),
subpartition hr_job_part032 values(90,110)
),partition hr_job_part03 values less than (to_date('2010-01-01','YYYY-MM-DD'))(
subpartition hr_job_part013 values(20,50),
subpartition hr_job_part023 values(60,80),
subpartition hr_job_part033 values(90,110)
));

在这里插入图片描述

2.插入数据

insert into 
hr_job_history
select * from job_history;

3.查询各分区表及子分区表

(分区表的记录条数等于其各子分区记录的总条数)

(1)查询hr_job_part01分区表及其子分区

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注:其余两个分区表及其子分区表按查询分区表1的方式进行查询!

七、对hr_job_history表进行复合范围散列分区

(即:范围—散列分区)

这种分区是基于范围分区和散列分区,表首先按某列进行范围分区,然后再按某列进行散列分区。分区之中的分区被称为子分区。

1.分区

(先对start_date进行范围分区,再对employee_id进行列表分区)

create table hr_job_history(employee_id number(6) not null,start_date date,end_date date,job_id varchar2(10),department_id number(4)
) 
partition by range(start_date) subpartition by hash(employee_id)(partition hr_job_part01 values less than (to_date('2000-01-01','YYYY-MM-DD'))(
subpartition hr_job_part011,
subpartition hr_job_part021,
subpartition hr_job_part031
),partition hr_job_part02 values less than (to_date('2005-01-01','YYYY-MM-DD'))(
subpartition hr_job_part012,
subpartition hr_job_part022,
subpartition hr_job_part032
),partition hr_job_part03 values less than (to_date('2010-01-01','YYYY-MM-DD'))(
subpartition hr_job_part013,
subpartition hr_job_part023,
subpartition hr_job_part033
));

在这里插入图片描述

2.插入数据

insert into 
hr_job_history
select * from job_history;

3.查询各分区表及子分区表

(分区表的记录条数等于其各子分区记录的总条数)

查询hr_job_part01分区表及其子分区:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
注:其余两个分区表及其子分区表按查询分区表1的方式进行查询!


到此集中式数据库的三种常见分区方式及两种复合分区方式已全部演示完!


总结

本文讲述了如何在Oacle数据库中创建简单的数据表,对分区键应用不同的分区规则,实现不同的分区策略。
是对上篇博文https://blog.csdn.net/qq_47527477/article/details/120293858?spm=1001.2014.3001.5502
在Win10环境下安装Oracle19c数据库,并使用Navicat与PL/SQL连接上数据库”的延续!


后续会继续更新有关Oracle数据库及分布式数据库的内容!
(注:第六次发文,如有错误和疑问,欢迎在评论区指出,再次感谢!)
——2021.09.23

http://www.jmfq.cn/news/4867597.html

相关文章:

  • 域名解析错误怎么解决/南京网站设计优化公司
  • 我想去澳大利亚做按摩找哪个网站/企业网站管理系统源码
  • 网站开发补充合同范本/seo如何优化网站步骤
  • 如何做网站 百度/网络推广主要工作内容
  • 网站迁移教材/最新国内新闻10条
  • 亿玫网站建设/优化网站软文
  • 广州网站建设app开发/杭州优化建筑设计
  • 青岛营销网站建设/线上推广
  • 网站首页html/seo快速排名上首页
  • 邵阳网站优化/互联网推广营销
  • 微网站和手机网站/seo的基本步骤包括哪些
  • 郴州网站建设推广方案/千锋教育培训机构怎么样
  • 如何在国际上做网站/seo搜索引擎优化知乎
  • 企业地址管理系统/北京seo方法
  • 做网站后台的叫什么/网站访问量
  • 5昌平区网站建设/国内搜索引擎排名第一的是
  • wordpress替换/企业seo顾问公司
  • 未来中森网站建设价格/百度一下就会知道了
  • 台州建站服务/全球网站流量排名100
  • 北京网站建设设计公司浩森宇特/微信搜一搜排名优化
  • 多肉建设网站的目的及功能定位/推广软件赚钱违法吗
  • 友情手机站/全球搜索
  • 网站建设团队武汉/百度站长工具seo
  • 高质量的高密网站建设/常见的线下推广渠道有哪些
  • 深圳福田网站制作/seo交流中心
  • 网页设计与制作html/泾县网站seo优化排名
  • 高端网站设计简介/seo在线短视频发布页运营
  • 莱芜又出大事/郑州seo网站排名
  • 手机网站开发技术路线/百度统计手机app
  • 辽宁工程建设信息网站/网站结构有哪几种