mysql学习笔记 第五天

使用分区数据表:
  分区数据表和merge数据表具有相似的作用,但是分区数据表确确实实是一个数据表
  ,不像merge是列出数据表的逻辑关系,并且分区数据表可以包括像myisam以外的
  的数据表。
创建分区数据表:
  create table 里给出数据列和索引,然后用partition by 定义一个用来把数据行分配
  到各个分区的分区函数:[将数据表分成四个区]

create table log_partition(
     dt datetime not null,
     info varchar(100) not null,
     index(dt)
)
   partition by range(year(dt))
        (
          partition p0 values less than (2010),
          partition p1 values less than (2011),
          partition p2 values less than (2012),
          partition p3 values less than maxvalue
        );
将maxvalue再进行分区alter log_partition reorganize partition
into ( partition p4 values less than (2013),
partition p5 values less than (2014),
partition p6 values less than maxvalue
);
  
 

分区被包含在分区数据表所属于的数据库的子目录中,需要使用data_directory和index_dirctory分区选项;

federated(同盟)引擎
      可以访问其他主机由另一个mysql服务器管理的数据表

删除数据表:
      drop table table_name1,table_name2,...]
      在不确定删除的数据库是否存在时,使用drop table if exist table_name,在创建脚本的时候使用if exist 会更加的安全,
      如要删除临时数据表加上temporary关键字:drop temporary table table_name;
创建索引:
    唯一索引:不允许索引项本身出现重复的值(primary,unqiue)
    普通索引:允许索引出现重复值
fulltext索引:全文索引,只适合myisam引擎
spatial索引只能使用与myisam数据表,只用于not null属性,所涉及的列全部带索引
hash(散列索引):这是memory的默认索引类型,但是memory索引还可以使用btree;
        hash是精确查找,比较查找的时候使用btree更好
使用alter table和create index给现有数据表添加索引
     alter table table_name add [index,unique,primary key,fulltext,spatial] index_name(index_columns)     ps:index_name是可选的
如果某个索引是primary key和spatial,那么带索引的必须是not null属性
如果想限制独不能重复的值,可以创建primary key或者unique索引
    (1)但是每一个数据表只有一个primary key,而unique却可以有多
    (2)primary key不能包括null值,但是unqie却可以,而且可以使多个null值
除了primary key,其他的索引几乎都可以使用create index语句:create index index_name on table_name(index_name)(一次只能创建一个索引)
在创建表的时候定义索引:
          

create table table_name
(
id int,
index [index_name](id)
);
对于primary key和unqie来说可以是:
create table table_name
(
id int primary key[unqie]
);

menory的默认索引是hash(散列索引),但用memory数据表进行范围比较(id<100)创建btree比hash更好

create table tb_name
(
id int,
index using btree(id)
)engine=memory;

对某个字符串前缀编辑索引,语法是columns(n)n是前面的n个字符

create table tb_name
(

name char(30) NOT NULL,
adress binary(60) NOT NULL,
index(name(10)),
index(adress(15))
);

对于blob和text数据列则只能创建前缀型索引
重建索引:
    repair table table_name quick;
查看索引:
    show index from table_name或show keys from table_name ps:查看index_name
删除索引:
    drop index index_name on tb_name
    alter table tb_name drop index index_name

    

    

mysql学习笔记 第五天,布布扣,bubuko.com

时间: 2024-10-07 15:21:42

mysql学习笔记 第五天的相关文章

Mysql学习笔记(五)数学与日期时间函数

原文:Mysql学习笔记(五)数学与日期时间函数 学习内容: 1.数学函数 2.日期时间函数 这些函数都是很常用的函数...在这里进行简单的介绍... 数学函数: mysql> SELECT ABS(-32); //取绝对值函数 -> 32 这个函数可安全地使用于 BIGINT 值. mysql> SELECT SIGN(-32);//判断一个数是正数,负数,还是0..根据实际情况返回指定的数值.. -> -1 mysql> SELECT MOD(234, 10);//取模函

MySQL学习笔记(五)—— 子查询及联结

子查询: 子查询,即嵌套在其他查询中的查询.例如我们有这样几个表,顾客表,订单表,商品表,我们想知道有哪些客户买了商品A,那么我们就需要先查看哪些订单里包含了商品A,然后根据订单查出是哪些客户. mysql> select cust_id from orders where order_num in (select order_num from orderitems where prod_id = '1'); +---------+ | cust_id | +---------+ |    10

mysql学习笔记(五)--- 字符串函数、日期时间函数

一.常见字符串函数: 1.CHAR_LENGTH  获取长度(字符为单位) 2.FORMAT  格式化 3.INSERT  替换的方式插入 4.INSTR  获取位置 5.LEFT/RIGHT  取左.取右 6.LENGTH   获取长度(字节为单位) 7.LTRIM/RTRIM/TRIM 去空格(左/右/自定义) 8.STRCMP  字符串比较 9.CONCAT  字符串拼接 10.SUBSTRING  字符串截取 1.CHAR_LENGTH:获取长度(字符为单位) CHAR_LENGTH()

菜鸟的MySQL学习笔记(五)

7.自定义函数 用户自定义函数(user-defined function,UDF)是一种对MySQL扩展的途径,其用法与内置函数相同.包含了两个必要条件,参数与返回值.没有必然内在联系. 函数可以返回任意类型的值,同样可以接收这些类型的参数: 创建自定义函数: CREATE FUNCTION function_name             #函数名 RETURNS {STRING | INTEGER | REAL | DECIMAL}        #返回值类型 routine_body

一千行MySQL学习笔记(五)

/* 导入导出 */ ------------- select * into outfile 文件地址 [控制格式] from 表名; -- 导出表数据load data [local] infile 文件地址 [replace|ignore] into table 表名 [控制格式]; -- 导入数据 生成的数据默认的分隔符是制表符 local未指定,则数据文件必须在服务器上 replace 和 ignore 关键词控制对现有的唯一键记录的重复的处理 -- 控制格式 fields 控制字段格式

MYSQL学习笔记 (五)常用的聚合函数

1.COUNT(e1) 语法:COUNT(e1) 参数:e1为一个表达式,可以是任意的数据类型 返回:返回数值型数据 作用:返回e1指定列不为空的记录总数 例子: 1)单独使用 2)与group by搭配使用 2. 语法:SUM(e1) 参数:e1为类型为数值型的表达式 返回:返回数值型数据 作用:对e1指定的列进行求和计算   例子: 1)单独使用 2)与group by联合使用 3.MIN(e1).MAX(e1) 语法:MIN(e1).MAX(e1) 参数:e1为一个字符型.日期型或数值类型

Mysql学习笔记(三)对表数据的增删改查。

写在前面:(一些牢骚,可以直接跳到分割线后) 太过敏感的人不会快乐,不幸的是我正是这种性格的人. 从培训机构毕业后,迫于经济方面的压力,和当时的班里的一个同学住在了一起,我们在一个公司上班.谁知道这都是不开心生活的源头,从每天早晨开始心情就很糟糕.他是个脾气很慢的人,我是个急脾气,特别是在早上上班的时候.由此种种吧,实在是不胜枚举.算了,还是不说了,太痛苦了,我不太喜欢说别人的坏话.我是学心理学的,已经用各种方法去安慰自己,但是都不太奏效. 回想以往和朋友的交往中,我虽然不算十分合群的人,但绝对

MySQL学习笔记之五 有关数据表操作

MySQL在创建表的时候,创建一个.frm文件保存表和列定义.索引存储在一个有.MYI(MYindex)扩展名的文件并且数据存储在有.MYD(MYData)扩展名的文件中.   一.用SHOW/ DESCRIBE语句显示数据表的信息 语法: SHOW TABLES [FROM db_name] [LIKE wild] or SHOW COLUMNS FROM tbl_name [FROM db_name] [LIKE wild] or SHOW INDEX FROM tbl_name [FROM

Mysql学习笔记(二)数据类型 补充

原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与varchar char与varchar的类型相似,但是他们的保存方式和检索方式不同... char的存储结构是固定长度的存储...即指定了几个字节,那么就占用几个字节,如char(4),那么无论存入的是什么字串,那么都占用四个字节...char的 可表示长度范围为0-255的任何值,当保存的字节不