金沙国际官网_金沙国际平台登录

因为这个金沙国际官网_金沙国际平台登录网站与很多的大型澳门赌场都有合作,金沙国际官网_金沙国际平台登录尽职尽责,高效执行,保持好奇心,不断学习,追求卓越,点击进入金沙国际官网_金沙国际平台登录马上体验吧,所以现在也正式地开始了营业。

您的位置:金沙国际官网 > 数据库 > 谓词和运算符,MySQL的存储引擎整理

谓词和运算符,MySQL的存储引擎整理

发布时间:2019-11-03 18:18编辑:数据库浏览(147)

    谓词一般有 where和having,check  谓词只计算 TRUE ,FALSE或者UNKNOWN  逻辑表达式  如 AND 和OR

    备份数据库(进入Mysql bin目录下/C:Program FilesMySQLMySQL Server 5.6bin)本地安装mysql数据库

    01.MyISAM

    1.IN 谓词的用法

    备份表结构及数据
    mysqldump -hlocalhost -uroot -proot db_dev>d:db_dev.sql

    MySQL 5.0 以前的默认存储引擎。MyISAM 不支持事务、也不支持外键,其优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT 为主的应用基本上都可以使用这个引擎来创建表。

    SELECT orderid, empid, orderdate
    FROM Sales.Orders
    WHERE orderid IN(10248, 10249, 10250);
    

    mysqldump -hip地址 -ur用户名 -p密码 数据库名>d:导出文件名.sql

    每个MyISAM 在磁盘上存储成3 个文件,其文件名都和表名相同,但扩展名分别是:

    查询返回 订单id等于10248或者10249,10250的订单

    备份表结构
    mysqldump -hlocalhost -uroot -proot -d db_dev>d:db_dev.sql

     .frm(存储表定义);

    2.BETWEEN 谓词的用法

    备份数据
    mysqldump -hlocalhost -uroot -proot -t db_dev>d:db_dev.sql

     .MYD(MYData,存储数据);

    SELECT orderid, empid, orderdate
    FROM Sales.Orders
    WHERE orderid BETWEEN 10300 AND 10310;
    

    数据库数据恢复
    mysqldump -hlocalhost -uroot -proot db_dev<d:db_dev.sql

     .MYI (MYIndex,存储索引)。

    查询包含10300——10310范围订单

    数据文件和索引文件可以放置在不同的目录,平均分布IO,获得更快的速度。  要指定索引文件和数据文件的路径,需要在创建表的时候通过DATA DIRECTORY 和INDEX DIRECTORY 语句指定,也就是说不同MyISAM 表的索引文件和数据文件可以放置到不同的路径下。文件路径需要是绝对路径,并且具有访问权限。

    3.LIKE谓词的用法

    MyISAM 类型的表可能会损坏,原因可能是多种多样的,损坏后的表可能不能访问,会提示需要修复或者访问后返回错误的结果。MyISAM 类型的表提供修复的工具,可以用CHECKTABLE 语句来检查MyISAM 表的健康,并用REPAIR TABLE 语句修复一个损坏的MyISAM 表。表损坏可能导致数据库异常重新启动,需要尽快修复并尽可能地确认损坏的原因。

    SELECT empid, firstname, lastname
    FROM HR.Employees
    WHERE lastname LIKE N'D%';
    

    MyISAM 的表又支持3 种不同的存储格式,分别是:

    注意的是 N  代表  该数据是NCHAR 或者NVARCHAR 而不是常规的字符数据类型 char或varchar

     静态(固定长度)表;

    4.运算符

     动态表;

    select 5/2  结果为2   5/2.0 却是 2.5 为什么呢  

     压缩表。

    图片 1图片 2

    其中,静态表是默认的存储格式。静态表中的字段都是非变长字段,这样每个记录都是固定长度的,这种存储方式的优点是存储非常迅速,容易缓存,出现故障容易恢复;缺点是占用的空间通常比动态表多。静态表的数据在存储的时候会按照列的宽度定义补足空格,但是在应用访问的时候并不会得到这些空格,这些空格在返回给应用之前已经去掉。

    实际上是 数据类型优先级  在同一层计算是 5的优先级会被默认提升为 5.0

    动态表中包含变长字段,记录不是固定长度的,这样存储的优点是占用的空间相对较少,但是频繁地更新删除记录会产生碎片,需要定期执行OPTIMIZE TABLE 语句或myisamchk -r 命令来改善性能,并且出现故障的时候恢复相对比较困难。

    -- 顺序: =, >, <, >=, <=, <>, !=, !>, !< 

    压缩表由myisampack 工具创建,占据非常小的磁盘空间。因为每个记录是被单独压缩的,所以只有非常小的访问开支。

    如果相对数据类型进行显示转换可以用到

     

    select cast(5 as numeric(12,2))
    

     

    图片 3

    02.**InnoDB**

     

    MySQL 5.0开始的默认引擎,InnoDB 存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比MyISAM的存储引擎,InnoDB 写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。

    AUTO_INCREMENT

    InnoDB 表的自动增长列可以手工插入,但是插入的值如果是空或者0,则实际插入的将是自动增长后的值。

    可以通过“ALTER TABLE *** AUTO_INCREMENT = n;”语句强制设置自动增长列的初识值,默认从1 开始,但是该强制的默认值是保留在内存中的,如果该值在使用之前数据库重新启动,那么这个强制的默认值就会丢失,就需要在数据库启动以后重新设置。

    可以使用LAST_INSERT_ID()查询当前线程最后插入记录使用的值。如果一次插入了多条记录,那么返回的是第一条记录使用的自动增长值。

    对于InnoDB 表,自动增长列必须是索引。如果是组合索引,也必须是组合索引的第一列,但是对于MyISAM 表,自动增长列可以是组合索引的其他列,这样插入记录后,自动增长列是按照组合索引的前面几列进行排序后递增的。

    例如,创建一个新的MyISAM 类型的表autoincre_demo,自动增长列d1 作为组合索引的第二列,对该表插入一些记录后,可以发现自动增长列是按照组合索引的第一列d2 进行排序后递增的:

    图片 4

    本文由金沙国际官网发布于数据库,转载请注明出处:谓词和运算符,MySQL的存储引擎整理

    关键词:

上一篇:没有了

下一篇:没有了