1、存储引擎是什么?

  Mysql中的数据用各种不同的技术存储在文件(或者内存)中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不同的功能和能力。通过选择不同的技术,你能够获得额外的速度或者功能,从而改善你的应用的整体功能。这些不同的技术以及配套的相关功能在MySQL中被称作存储引擎(也称作表类型)。MySql默认配置了许多不同的存储引擎,可以预先设置或者在MySql服务器中启用。

2、MYSQL支持的数据引擎

  MyISAM:默认的MySQL插件式存储引擎,它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。

  InnoDB:用于事务处理应用程序,具有众多特性,包括ACID事务支持。

  BDB:可替代InnoDB的事务引擎,支持COMMIT、ROLLBACK和其他事务特性。

  Memory:将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。

  Merge:允许MySQL DBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。对于诸如数据仓储等VLDB环境十分适合。

  Archive:为大量很少引用的历史、归档、或安全审计信息的存储和检索提供了完美的解决方案。

  Federated:能够将多个分离的MySQL服务器链接起来,从多个物理服务器创建一个逻辑数据库。十分适合于分布式环境或数据集市环境。

  Cluster/NDB:MySQL的簇式数据库引擎,尤其适合于具有高性能查找要求的应用程序,这类查找需求还要求具有最高的正常工作时间和可用性。

  Other:其他存储引擎包括CSV(引用由逗号隔开的用作数据库表的文件),Blackhole(用于临时禁止对数据库的应用程序输入),以及Example引擎(可为快速创建定制的插件式存储引擎提供帮助)。

3:InnoDB详解

  InnoDB是为处理超大型数据量时获得最大性能而设计的。它的CPU效率可能是任何其他基于磁盘的关系数据库引擎所不能匹敌的。

  InnoDB支持ACID事务,支持行级锁定.

4: 行锁   要锁的表的引擎 必须为InnoDB

  分为两种模式的行锁

共享锁 lock in share mode

排他锁 for update

操作:

  set autocommit=0

  function locl_row($sql,$lock_type){

    mysql_query("set autocommit=0");

    mysql_query("begin work");

$res = mysql_query($sql.$lock_type);

retrun $res;

}

 function commit(){

 mysql_query("commit;");
   }

5:案例

注意 数据库 引擎 为innodb

/**
 * 抢代金劵 锁行
 */

if (!empty($_REQUEST['act']) && $_REQUEST['act'] == 'juan_qiang')
{

$juan_id=1;

//判断用户是否登录
    if ($user_id=$_SESSION['user_id']) {

//查询是否已经抢过代金劵

$sql = "SELECT id FROM ".$ecs->table("week01_juan_log")." WHERE user_id=".$user_id." AND juan_id=".$juan_id;

//exit($db->getOne($sql));

if (!$db->getOne($sql)) {

unset($sql);

$db->query("set autocommit=0");

$db->query("begin work");
            
            //查询 获取到代金劵的剩余数量

$sql = "SELECT * FROM ".$ecs->table('week01_juan')." WHERE juan_id =".$juan_id." FOR UPDATE";

$arr = $db->getRow($sql);

$num = $arr['juan_num'];

unset($sql);unset($arr);

//判断剩余的数量是否大于0

if ($num>0) {
                
                $sql = "UPDATE ".$ecs->table('week01_juan')." SET juan_num=juan_num-1 WHERE juan_id=".$juan_id;

if ($db->query($sql)) {

unset($sql);

$addtime = time();

$sql = "INSERT INTO ".$ecs->table("week01_juan_log")."(juan_id,user_id,addtime) VALUE($juan_id,$user_id,$addtime)";

if ($db->query($sql)) {

unset($sql);

sleep(10);
                        
                        $db->query("commit");

exit("4");    //抢成功 同时 记录成功
                    }

$db->query("commit");

exit("3");    //抢成功 同时记录失败
                }

$db->query("commit");

exit("2");    //抢失败

}

}

exit("1");    //已经抢过

}

exit("0");    //没有登录
    
}

6 锁表

6.0: 准备:

2个用户操作同一个数据库

6.1: 选择数据库

use test

6.2: 查询数据 两个用户均可以操作

select name from test where id=1;

6.3: 在数据之前锁表 谁锁表 就只有谁可以使用

锁表 有两种模式
    
    表共享读锁: Table Read Lock
        
        仅允许[所有人]读,

[空间外]如需写、更新要等待[空间退出].

[空间内]如需写、更新会引发mysql报错.

表独占写锁: Table Write Lock

仅允许[空间内]读写更新,

[空间外]如需写、更新要等待[空间退出]

操作:
    
    lock tables test read/write;        //锁表

select name from test where id=1;    //执行操作

unlock tables;                //解锁

6.4: 可以封装函数 来简化 //锁表 解锁

//可以添加在cls_mysql页面里;

function lock ($table_name,$lock_type){
        
        mysql_query("lock tables ".$tanble_name." ".$lock_type);

}

MySql 的数据储存引擎的更多相关文章

  1. (转)MySQL 常用数据存储引擎区别

    MySQL 常用数据存储引擎区别 原文:https://laravel-china.org/articles/4198/mysql-common-data-storage-engine mysql有多 ...

  2. MySQL数据库Innodb储存引擎----储存页的结构

    上一篇博客回顾: 1:数据库拥有众多的储存引擎,现在主要使用的是Inoodb,这个储存引擎有Compact,Redundant,Dynamic,Compressed四种行格式 2:Compact行格式 ...

  3. MySQL 常用数据存储引擎区别

    mysql有多种存储引擎,目前常用的是 MyISAM 和 InnoDB 这两个引擎,除了这两个引擎以为还有许多其他引擎,有官方的,也有一些公司自己研发的.这篇文章主要简单概述一下常用常见的 MySQL ...

  4. MySQL 的数据存储引擎

    MySQL的存储引擎 InnoDB: MySQL5.5之后的默认存储引擎. 采用MVCC来支持高并发,并且实现了四个标准的隔离级别(默认可重复读). 支持事务,支持外键.支持行锁.非锁定读(默认读取操 ...

  5. MySQL之数据存储引擎

    1.什么是存储引擎: 现实生活中我们用来存储数据的文件有不同的类型,每种文件类型对应各自不同的处理机制:比如处 理文本用txt类型,处理表格用excel,处理图片用png等,数据库中的表也应该有不同的 ...

  6. mysql 的 存储结构(储存引擎)

    1 MyISAM:这种引擎是mysql最早提供的.这种引擎又可以分为静态MyISAM.动态MyISAM 和压缩MyISAM三种:    静态MyISAM:如果数据表中的各数据列的长度都是预先固定好的, ...

  7. Mysql 储存引擎

    查看当前版本支持哪些储存引擎 mysql> show engines; InnoDB 支持事务机制 : 保证操作安全性 行级锁定 : 开销大,加锁慢:会出现死锁:锁定粒度最小,发生锁冲突的概率最 ...

  8. MySQL数据库储存引擎Inoodb一--记录储存结构

    在开文我先说明一下,接下来的数据库知识文章都是在微信公众号“我们都是小青蛙”学习然后在通过自己的理解进行书写的.有兴趣的朋友可以去关注这个微信公众号.话不多说,我们在日常使用数据库进行数据持 久化的时 ...

  9. MYSQL索引类型。MYSQLc储存引擎

                                                            MYSQL索引类型,MYSQLc储存引擎 MySQL索引创建与删除 MySQL存储引擎的 ...

随机推荐

  1. javascript测试

    s阿道夫. 撒旦法 sd sad sd 的萨法a dsa发 fds sdfad 电风扇爱的方式爱的方式啊

  2. MVC4方法行为过滤器例子(用户登录)

    在Model文件夹下添加一个类MyActionFilterAttribute继承于ActionFilterAttribute: using System; using System.Collectio ...

  3. python基础——使用@property

    python基础——使用@property 在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改: s = Student() s.score = 9 ...

  4. Codeforces Round #304 C(Div. 2)(模拟)

    题目链接: http://codeforces.com/problemset/problem/546/C 题意: 总共有n张牌,1手中有k1张分别为:x1, x2, x3, ..xk1,2手中有k2张 ...

  5. Jmeter 中使用非GUI启动进行压力测试

    使用非 GUI 模式,即命令行模式运行 JMeter 测试脚本能够大大缩减所需要的系统资源.使用命令jmeter -n -t <testplan filename> -l <list ...

  6. Notice: Only variable references should be returned by reference(PHP版本兼容性问题)

    摘自:http://sushener.spaces.live.com/blog/cns!BB54050A5CFAFCDD!435.entry PHP5一个很让人恼火的一点就是BC(向后兼容)不是很理想 ...

  7. jQuery插件:跨浏览器复制jQuery-zclip(转载)

    转载地址:http://www.cnblogs.com/linjiqin/p/3532451.html jQuery-zclip是一个复制内容到剪贴板的jQuery插件,使用它我们不用考虑不同浏览器和 ...

  8. 没有VisualStudio也要HelloWorld

    前言 在博客园看到Artech的通过3个Hello World应用来了解ASP.NET 5应用是如何运行的(1)这篇文章,于是想跟着教程学习一下.说来惭愧,这篇文章发布于2014年12月,我在2016 ...

  9. 1-01Sql Sever 2008的安装

    Sql Sever 2008对计算机的配置要求: 1:处理器:最低1.4Ghz的处理器,建议使用2.0GHz或更高的处理器  . 2:内存:最小512MB, 建议使用1GB或更高的处理器. 3:磁盘容 ...

  10. Win10 启动模拟器

    不知道怎么解决 答:去bios里设置了.开启了虚拟化hyper,重启.