zoukankan      html  css  js  c++  java
  • mysql 约束条件 auto_increment 自动增长 清空表 自动增长情况

    清空表情况:

    mysql> delete from t20;
    Query OK, 7 rows affected (0.00 sec)
    
    mysql> show create table t20G;
    *************************** 1. row ***************************
           Table: t20
    Create Table: CREATE TABLE `t20` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(16) DEFAULT NULL,
      UNIQUE KEY `id` (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8
    1 row in set (0.00 sec)

    清空表后   AUTO_INCREMENT=11 没有改变 自增长字段的值没有置为1

     

    对于自增字段,在用delete删除后,再插入值,该字段仍然按照删除前的位置增长

    从11开始

    mysql> insert into t20(name) values('mike');
    Query OK, 1 row affected (0.01 sec)
    
    mysql> select * from t20;
    +----+------+
    | id | name |
    +----+------+
    | 11 | mike |
    +----+------+
    1 row in set (0.00 sec)
    清空表不要用delete清 
    delete 用在和where语句配合
    delete from t20 where id=3;
    用在删除固定的记录

    用truncate
    truncate是直接清空表,在删除大表时用它


    mysql> show create table t20G;
    *************************** 1. row ***************************
           Table: t20
    Create Table: CREATE TABLE `t20` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(16) DEFAULT NULL,
      UNIQUE KEY `id` (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8
    1 row in set (0.00 sec)
    
    ERROR: 
    No query specified
    
    mysql> truncate t20;
    Query OK, 0 rows affected (0.02 sec)


    自增长字段没有了

    mysql> show create table t20G;
    *************************** 1. row ***************************
           Table: t20
    Create Table: CREATE TABLE `t20` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(16) DEFAULT NULL,
      UNIQUE KEY `id` (`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8
    1 row in set (0.00 sec)

    再插入记录
    mysql> insert into t20(name) values('jack');
    Query OK, 1 row affected (0.00 sec)
    
    mysql> select * from t20;
    +----+------+
    | id | name |
    +----+------+
    |  1 | jack |
    +----+------+
    1 row in set (0.00 sec)

    从1开始了

    清空表:

    delete from t1; #如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始。

    truncate table t1;数据量大,删除速度比上一条快,且直接从零开始,



     
     
  • 相关阅读:
    babel初学教程
    手机cs端改变跳转方式
    web.xml 中的listener、 filter、servlet 加载顺序及其详解
    Linux下cp直接覆盖不提示的方法!
    JAVA中用CALENDAR类计算周和周的起始日期(转)
    [android反编译小结]apktool/ AXMLPrinter2.jar/ dex2jar.bat/ jdgui/
    jquery 新手学习常见问题解决方法
    Linux系统中gb2312与utf8相互切换
    xml解析循环参数实例
    java 计算时间差
  • 原文地址:https://www.cnblogs.com/mingerlcm/p/9851861.html
Copyright © 2011-2022 走看看