要想还原建表DDL就必须从元数据入手,我们知道,hive的元数据并不存放在hdfs上,而是存放在传统的RDBMS中,典型的如mysql,derby等,这里我们以mysql为元数据库,结合0.4.2版本的...连接上mysql后可以看到hive元数据对应的表约有20个,其中和表结构信息有关的有9张,其余的10多张或为空,或只有简单的几条记录,以下是部分主要表的简要说明。...(键值) PART_ID 除了上面几张表外,还有两张表非常有趣:NUCLEUS_TABLES和SEQUENCE_TABLE NUCLEUS_TABLES表中保存了元数据表和hive中class类的对应关系...注意:其中mysql连接信息请根据实际环境进行配置。
关系模型 外键 在 students 表中,通过 class_id 的字段,可以把数据与另一张表关联起来,这种列称为外键。...这个时候,就可以给该列添加一个唯一索引。...,我们假设 students 表的 name 不能重复: ALTER TABLE students ADD UNIQUE INDEX uni_name (name); 通过 UNIQUE 关键字我们就添加了一个唯一索引...也可以只对某一列添加一个唯一约束而不创建唯一索引: ALTER TABLE students ADD CONSTRAINT uni_name UNIQUE (name); 这种情况下,name 列没有索引...无论是否创建索引,对于用户和应用程序来说,使用关系数据库不会有任何区别。
1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.添加UNIQUE(唯一索引...) mysql>ALTER TABLE `table_name` ADD UNIQUE ( `column` ) 3.添加INDEX(普通索引) mysql>ALTER TABLE `table_name...` ADD INDEX index_name ( `column` ) 4.添加FULLTEXT(全文索引) mysql>ALTER TABLE `table_name` ADD FULLTEXT...( `column`) 5.添加多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`,
首先用以root用户连入MYSQL,然后键入以下命令: grant select,insert,update,delete on *.* to test1@”%” Identified by “abc”...; 但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。...例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),...这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过MYSQL主机上的web页来访问了。
1.PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.UNIQUE(唯一索引...) mysql>ALTER TABLE `table_name` ADD UNIQUE (`column` ) 3.INDEX(普通索引) mysql>ALTER TABLE `table_name...` ADD INDEX index_name ( `column` ) 4.FULLTEXT(全文索引) mysql>ALTER TABLE `table_name` ADD FULLTEXT...( `column` ) 5.多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`
添加引用是using的必备条件 只有添加了对程序集的引用,此程序集内的命名空间才能被using 项目添加引用的目的是引入程序集 程序集的概念是什么?...举例来说 命名空间 System.Data 来自文件System.Data.DLL 命名空间System.Data.SqlClient 同样来自System.Data.DLL 那么意味着你一旦添加了...System.Data 程序集 文件的引用(无论你是从 GAC 添加还是直接添加的 DLL 到项目) 你就可以使用 System.Data 和 System.Data.SqlClient 下的各种类...DataSet(); 方法二: 没有 using 直接 System.Data.DataSet mySet = new System.Data.DataSet(); 当然,两种方法都要求你对项目添加了对...1.system.io属于system下面的一个模块,所以引用中只有system,而没有单独的system.io 2.程序自动添加的引用是在.net框架的安装目录下调用的dll,所以程序集在安装了对应版本
创建脚本 1.PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.UNIQUE...(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE (`column` ) 3.INDEX(普通索引) mysql>ALTER TABLE `...table_name` ADD INDEX index_name ( `column` ) 4.FULLTEXT(全文索引) mysql>ALTER TABLE `table_name`...ADD FULLTEXT ( `column` ) 5.多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1
mysql 添加远程用户 添加用户 创建 mysql 用户 CREATE USER 'user1'@'localhost' IDENTIFIED BY 'user1_password'; 创建数据库:...privileges; 开启远程访问 GRANT ALL PRIVILEGES ON test_db.* TO user1@'%' IDENTIFIED BY 'user1_password'; #mysql...8.0 ALTER USER ‘zheng’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘zhengzongwei’; flush privileges...; 并开启mysql允许远程访问配置,在 my.cnf 47行, bind-address 前增加 # 号,注释掉 bind-address = 127.0.0.1 sudo vi /etc/mysql.../my.cnf #bind-address = 127.0.0.1 重启 mysql sodu service mysql restart mysql 修改用户名密码 use mysql
数据库表有三种关系: 多对一 多对多 一对一 多对一 外键在“多”侧 比如有两个表,分别是书籍表和出版社表。书籍和出版社是典型的多对一关系,即一本书只能由一个出版社出版,一个出版社可以出版多本书。...| 1 | +----+-----------------+----------+ 3 rows in set (0.00 sec) 多对多 多对多因为都存在外键的依赖关系...需要第三张表来建立他们的外键关系,如下: ?...,一个客户有可能变成一个学生,即一对一的关系 关联方式:foreign key+unique 对于多对一的关系而言:关联表中的外键无需指定为unique,因为存在多个记录的外键指向被关联表的同一个记录...但对于一对一的关系而言:为了保证两张表记录的一一对应,需要把关联表的外键约束为unique ?
1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 例:alter table yx_marketing_details...add index(id); 2.添加UNIQUE(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE (`column` ) 3.添加INDEX...(普通索引) mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 4.添加FULLTEXT(全文索引) mysql...>ALTER TABLE `table_name` ADD FULLTEXT ( `column`) 5.添加多列索引 mysql>ALTER TABLE `table_name` ADD INDEX
数据库建立完之后,再来添加这个参数就需要用south,具体怎么用,我没研究。因为直接用sql语句就行了。...主要是针对MySql,查看对应表的索引 show index from table_name; 创建索引的语句 ALTER TABLE table_name ADD INDEX index_name (
进入到MySQL安装目录下的bin目录,输入命令: mysqld.exe -install 3.启动mysql服务,输入命令: net start mysql
[toc] 关系的码 候选码 候选码是能够唯一标识关系中某一个元组的一个属性或属性集,也叫候选键 如: 学生关系中,学号可以唯一标识学生,班级+姓名也可以唯一标识一个学生,学号和(班级,姓名)都是候选码...候选码需要满足: 唯一性:唯一标识一个元组(注意不是说候选码只有一个) 最小性:构成候选码的属性个数最少,比如前面的(班级,姓名),再添加一个学号或其他属性就多此一举了 主码 主码是从候选键中选着一个作为查询...) 非主属性:不包含在任何候选码中的属性 外码 关系R1,R2,其中属性集X是R1的非主码属性,但X是R2的主码,则称X是R1的外码(也叫外键、外部关系键),R1为参照关系,R2为被参照关系 外码的取值是由被参照的关系的主码的域决定的...因此学号或课程号不能单独作为主码 而学号和课程号分别是学生和课程的主码,则选课关系中,学号和课程号都是外码,并且学号和课程号是选课关系中的主属性 关系的完整性 为了维护关系数据库中数据与现实的一致性...,第二,在构建选课关系用学号更便捷
mysql添加索引的方法:可以通过【create table】语句来添加,如【CONSTRAINT PRIMARY KEY | INDEX [] [] 】,表示创建一般索引。...在mysql中可以在创建表(CREATE TABLE)的同时创建索引;也可以在创建表后创建索引,使用CREATE INDEX语句或ALTER TABLE 语句。...TABLE)的同时创建,语法格式: 1、创建主键索引CONSTRAINT PRIMARY KEY [索引类型] (,…) 在使用 CREATE TABLE 语句定义列选项的时候,可以通过直接在某个列定义后面添加...具体的做法是在 ALTER TABLE 语句中添加以下语法成分的某一项或几项。...可以通过添加 \G 来格式化输出信息。
1.添加字段 1.在末尾添加字段 (1)语法 ALTER TABLE ADD [约束条件]; 语法格式的说明: 为数据表的名字; 为所要添加的字段的名字...; 为所要添加的字段能存储数据的数据类型; [约束条件] 是可选的,用来对添加的字段进行约束。...这种语法格式默认在表的最后位置(最后一列的后面)添加新字段。...(2)示例 在user表末尾添加字段phone: ALTER TABLE `user` ADD `phone` VARCHAR(11) DEFAULT NULL COMMENT '电话号码'; 2.在开头添加字段...注意:只能在某个已有字段的后面添加新字段,不能在它的前面添加新字段。
这是学习笔记的第 2227 篇文章 关于MySQL的拓扑关系,最近是比较困扰我的,主要是因为最近在思考重构元数据层面的一些东西,发现原来的一些设计方式已经不能够支持现在的业务特点了。...级联实例的关系不好体现 基于双主模式的复制拓扑难以体现 读写分离的关系不好体现 不支持跨机房容灾的复制关系 所以这些问题抛出来,也算是自我革命,整体上来看这种关系的维护是比较复杂的,如果碰到一些略微复杂的场景...如果是这种复制拓扑关系,基本上能够解决我们所说的拓扑关系。 ?...MySQL 8.0有个特性叫做replicaSet,这个特性的名字给了我新的启发,那就是我们可以按照复制集的角度去重新看待原来的拓扑关系。...不支持域名 一主多从的关系不够清晰 级联实例的关系不好体现 基于双主模式的复制拓扑难以体现 读写分离的关系不好体现 不支持跨机房容灾的复制关系 其实2,3,4,6是可以支持的,而对于域名服务的部分,目前看和复制拓扑没有直接的关系
对应关系表 根据表格对应,来理解Elasticsearch Elasticsearch MySQL 索引库(indices) Database 数据库 类型(type) Table 数据表 文档(Document...mappings) 每个列的约束(类型、长度) 对Elasticsearch相关概念说明 概念 说明 索引库(indices) indices是index的复数,代表许多的索引 类型(type) 类型是模拟mysql
选择(SELECT) SELECT 关系名 WHERE 条件,挑选出关系中符合条件的行。...投影(PROJECTION) PROJECTION 关系名 (属性名1,属性名2,... 属性名n),挑选出关系中指定的列。 ? 3....连接(JOIN) JOIN 关系名 1 AND 关系名 2 WHERE 条件,将两个关系中符合条件的行组成一个新的行,用这些新的行生成一个新的表。...除(DIVISION) 关系名 1 ÷ 关系名 2 ,设关系R除以关系S的结果为关系T,T需要满足两个条件: (1). T包含所有在R但不在S中的属性及其值。 (2).
1.使用root账户登录到mysql: mysql -uroot -p 2.创建用户名和密码: grant all on *.* to 用户名@’127.0.0.1′ identified by...首先切换到mysql数据库: use mysql; 4.修改新建用户的权限: update user set host = ‘%’ where user = ‘attckness’; 5.查看user
http://mpvideo.qpic.cn/0bf2jyaacaaazqajzrtomzpvatwdafhaaaia.f10002.mp4?dis_k=96f...
领取专属 10元无门槛券
手把手带您无忧上云