首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mysql删除表数据,表文件大小不变

,因此我今天主要说是表数据, 日常开发中,当我们删除一个表的的数据的时候,发现表空间大小并不会变小,我们要知道为什么会发生这样神奇的事, 参数innodb_file_per_table 表数据可以存在共享表空间里...,也可以在单独的文件中,这个行为由参数innodb_file_per_table控制, 这个参数为OFF的时候,说明表的数据存放在系统共享表空间,也就是跟数据字典放在一起 如果这个参数是ON的时候,说明表的数据放到单独的文件中...假如我删除500这个数据,innodb只会把这个记录标记为删除,如果之后要插入400的时候,就会直接复用这个位置,但是磁盘的文件并不变小,当然我如果删除了在跟个pageA的数据,当然也是被复用的,但是数据页的复用和记录的复用是不一样的...这个时候插入一条id=50的时候,要创建新的数据页的时候,就会复用pageA, 现在我们知道delete 命令只会把记录的位置或数据页标记为可复用,但是磁盘的文件大小不会变小,也就是说delete并不会回收表空间...显然上图中最花时间的步骤是往临时表插入数据的过程,如果整个过程中,有新的数据写入是不被允许的,这个就会造成数据丢失,表A不会有数据的更新,这个DDL不是Online的 但是在mysql5.6版本开始引入

5.1K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    解决sqlite删除数据或者表后,文件大小不变的问题

    原因: sqlite采用的是变长纪录存储,当你从Sqlite删除数据后,未使用的磁盘空间被添加到一个内在的”空闲列表”中用于存储你下次插入的数据,用于提高效率,磁盘空间并没有丢失,但也不向操作系统返回磁盘空间...,这就导致删除数据乃至清空整个数据库后,数据文件大小还是没有任何变化,还是很大 解决方法有以下两种: 1、sqlite3中执行vacuum命令即可。...但是第二个方法同样有缺点,只会从数据库文件中截断空闲列表中的页, 而不会回收数据库中的碎片,也不会像VACUUM 命令那样重新整理数据库内容。...实际上,由于需要在数据库文件中移动页, auto-vacuum 会产生更多的碎片。而且,在执行删除操作的时候,也有那个.db-journal文件产生。...数据库中需要存储一些额外的信息以记录它所跟踪的每个数据库页都找回其指针位置。 所以,auto-vacumm 必须在建表之前就开启。在一个表创建之后, 就不能再开启或关闭 auto-vacumm。

    2.1K20

    TensorFlow 模型优化工具包:模型大小减半,精度几乎不变!

    图 1 IEEE 754 标准下 binary16 的格式 训练后的 float16 quantization 减少了 TensorFlow Lite 模型的大小(高达 50%),同时以少量的精度损失为代价...训练后的 float16 quantization 是量化 TensorFlow Lite 模型很好的方法,因为它对精度的影响极小并且能够使得模型大小显著减小。...图 2 帮助确定合适量化场景的决策树 降低精度的收益 尤其是在部署到边缘时,降低精度将产生很大的收益。 模型尺寸减少 2 倍。...模型尺寸测试结果 训练后的 float16 quantization 对精度的影响很小,并可以使得深度学习模型的大小减小约 2 倍。...图 3 不同模型下模型大小变化 模型精度测试结果 在 ILSVRC 2012 图像分类任务中,我们评估了标准 Mobilenet Float32 模型(和 FP16 变体)。

    1.7K30

    Android ScrollView设置初始position的方法

    刚听到这个需求的时候,觉得这个很简单,直接设置ScrollView的初始滚动值即可。然而,当真正实现的时候却发现,Android压根没有方法可以设置ScrollView的初始滚动值。...但是为难的是如何做到初始化ScrollView的默认滚动值。如果在onCreate里面调用scrollTo是无效的,因为这时候ScrollView都没有布局好。...当我看着上面动画的代码发呆的时候,突然注意到了scrollY这个值,为什么Animator能够通过这个值来调整ScrollView的滚动位置呢?...难道是通过反射scrollY这个成员变量动态修改它的value? 于是自己动手在onCreate的时候通过反射修改ScrollView的scollY属性。...通过断点和查看源码确认,这个保存ScrollView当前滚动位置的scrollY属性全名叫做mScrollY,而这个mScrollY并不是ScrollView的成员,而是其父类View的属性成员。

    4K80

    封装内嵌UICollectionView和UIPageControl的ScrollView

    在需求中涉及到一个比较通用的控件,ScrollView里面嵌入CollectionView,封装一下,后面再有相同交互不用重复造轮子。 一。...接口 接口 init的时候传入view布局相关的TBCollectionViewParamsModel参数;拿到数据后调用setDataList传入数据,展示CollectionScrollView。...大小 @property (nonatomic, assign) CGFloat minimumInteritemSpacing; //collectionView的cell间水平间距 @property...实现 [ ] UICollectionViewUICollectionViewUICollectionViewUICollectionView 灰色的是容器View 紫色的是UIScrollView 蓝色的是...UICollectionView 红色的是UICollectionViewCell 下方小点点是TBScrollPageControl 关键代码: 根据setDataList传入的数据创建CollectionView

    1.7K90

    永恒不变的魅力

    在这个概念的基础上,程序员写下的代码,基本上就是根据外部或者内部的各种事件,对内部的状态不断进行改变。运行中的进程如此,磁盘的文件系统如此,数据库如此,javascript控制下的DOM页面也是如此。...replay是件费时的事情,是对初始状态不断修改,最终达到需要的状态,典型的处理mutation的思维。...想对UI的任意一个状态做测试?太简单不过 —— 事先构造好一个中间状态的UI的EDN,然后进行特定的步骤,测试构造好的EDN是否于实际UI的EDN相等不就得了!...下面这个pixel editor只用了66行代码 [7],就提供了一个完整的undo/redo的功能: 这就是immutability,永恒不变的魅力!...而最美妙的是,牺牲一些运行速度和内存,你的代码是immutable的,是化繁为简的。 而immutable,是如今这个程序世界梦寐以求的。

    1.1K120

    掌握 SwiftUI 中的 ScrollView:滚动几何

    SwiftUI 中的一个基本组件是 ScrollView,它允许用户通过滚动导航内容。然而,管理滚动位置和理解滚动交互可能是一个挑战。...高级滚动几何跟踪ScrollGeometry 提供了许多有价值的属性,如内容偏移、边界、容器大小、可见矩形、内容插入和内容大小。开发者可以提取单个属性或组合多个属性以获得全面的见解。...以下是一个结合内容大小和可见矩形跟踪的示例:struct ContentView: View { struct ScrollData: Equatable { let size: CGSize...完整代码示例分析下面是一个完整的 SwiftUI Demo,其中包含了我们刚刚讨论的 ScrollView、ScrollGeometry 和 onScrollGeometryChange 的使用示例。...AdvancedContentView: 展示更高级的滚动几何追踪功能,追踪内容大小和可见矩形的变化。ScrollViewDemoApp: 包含 TabView,方便在基本和高级示例之间切换。

    17611

    代码的变与不变

    哲学上说变与不变,讲的是绝对运动与相对静止的道理,在代码设计中,也有许多变和不变之间的辩证故事。...较弱的不变模式:指的是一个类的实例状态是不可变化的,但是这个类的引用的实例却可以变化。...当我们享受到代码变化带来的愉悦,也开始追求不变的代码,那一份古朴和单纯。 不变,引伸出对象复用的好处来。...不变,是快速的、简单的、敏捷的,将变化的状态连结起来了。 程序=算法+数据,算法是不变的,数据是可变的。仿佛从软件的一开始,变与不变就给后续的万事万物埋下了伏笔,代码的世界围着这个特殊的视角旋转。...Action 是具备状态的,线程独立的;Service 和 DAO 是无状态的,是可以被池化的。不变得再极致一点,我希望从编译之后它就是不变的,而不是对象创建之后不变,这就是方法。

    54110

    底层逻辑:变化背后的不变

    刘润老师经常说,花一秒钟看透本质的人,和花一生都看不明白的人,是两种截然不同的命运。 这本《底层逻辑》就是讲述事物变化背后那些不变的东西。...当别人还在纠结是对错的时候,你能有一个系统性的方法论来讲明白对错双方是怎么思考的。...比如,一个人心中有三种”对错观“:法学家的对错观;经济学家的对错观;商人的对错观; 举个例子:坏人A诱骗好人B进入C的没有锁门的工地,B失足摔死了。请问,这是谁的错?...法学家认为A的错,证据证明谁犯错就是谁的错。这种思维模式就是管好当下,解决当下的问题。 经济学家认为C的错。谁让他不锁门。...这种思维就是用最小成本去解决问题,谁能用最小成本防止错误发生而没阻止就是谁的错。 商家认为B的错。谁的损失大就是谁的错。这种思维就是谁对谁错都不重要,谁损失最大,谁更应该去防止错误发生。

    35910

    前端之变(二)- 不变的前端

    本周我将继续就前端之变阐述自己的一些思考。 在开始讲前端的技术究竟发生了哪些改变之前,先讲前端『不变』的地方。只有了解了哪些没有改变,我们才能更好的理解哪些改变了。...这是前端之变系列的第二篇,本系列其它文章: 前端之变(一):技术的变与不变 不变的核心 前端技术不管如何改变,但是支撑前端的最核心的三个技术始终是HTML,JavaScript与CSS 由HTML负责页面内容...所以,我们就发现一种非常有意思的现象: 在前端不变的前提下,出现了编码与产物脱节的趋势。编码阶段的技术演进越来越快,先进,但最终产物始终缓慢发展。...不变的前端_1 如上图所示: 这两个阶段之间的异同在于: 相同点 最终产物没有任何变化,都是HTML,JavaScript以及CSS这些东西 各自的职责分工没有改变:HTML负责内容,CSS负责样式,JavaScript...但如果我们认真分析它的本质,JavaScript仍然是一门非常糟糕的语言,基于原型的设计实在称不上先进或是好的,弱类型导致的问题难以查找等各种令人吐嘈的地方,而所谓的ES6或ES7等,一直卡在各种浏览器的支持中

    62210

    android scrollview嵌套listview计算高度的问题

    ScrollView中只能放一个控件,一般都放LinearLayout,orientation属性值为vertical。在LinearLayout中放需要呈现的内容。...但是为啥在scrollview中嵌套listview会出现只显示第一条listitem的高度呢,原因是:scrollview的ontach方法的滚动事件消费处理,ListView控件的高度设定问题 从谷歌那里找到的...ScrollView嵌套ListView只显示一行的解决办法相信很多人都遇到过,然后大部分都是用这位博主的办法解决的吧 刚开始我也是用这个办法解决的,首先感谢这位哥的大私奉献,贴上地址 http:/...;          }      这个代码让控件去计算Listview自己的高度然后设置这个Listview的高度 但是这个代码里面有一个问题,就是这个当你的ListView里面有多行的TextView...方法,我们就可以测量字体的总宽度除与去掉边距的屏幕的大小,就可以算出文字要几行来显示,然后测量字体的高度*行数可以得到字体的总高度,然后在加上上下边距就是TextView真正的高度,然后setMeasuredDimension

    2.3K60

    SwiftUI 中掌握 ScrollView 的使用:滚动可见性

    前言我们的滚动 API 中又有一个重要的新增功能:滚动可见性。现在,你可以获取可见标识符列表,或者快速检查并监控 ScrollView 内视图的可见性状态。...它设计得易于使用,允许你将其附加到具有滚动目标布局的任何 ScrollView 上。让我们通过一个示例来探讨这个修饰符的使用。...要了解有关 scrollTargetLayout 视图修饰符的更多信息,请查看我的文章《掌握 SwiftUI 中的 ScrollView:滚动几何》。...完整示例上面对视图修饰符有了初步了解,它的设计得易于使用,允许你将其附加到具有滚动目标布局的任何 ScrollView 上。让我们通过一个示例来探讨这个修饰符的使用。...运行这个 Demo,你会看到一个带有多个文本视图的 ScrollView,当你滚动时,控制台会打印当前可见的项。

    22421

    css设计中的不变与可变

    ——《一代宗师》 如果重构分里子与面子的话,那么html应该是负责里子的,而css就是负责面子了。在上篇html结构的拆与合说了html之后,我们继续来说下css,这次我们从可变与不变的角度分析。...具体的要求我忘了,大概的意思就是要这个内容在视窗内垂直方向居中,以图片为参考,文字上下延伸,上面文字多了向上撑开,下面文字多了向下撑开,图片大小固定,文字多少不固定(红线是我加的,作为垂直方向的中间线,...所以这里一般设计的是图片固定大小不变,右边文字可变,占满其余空间。...变与不变之道 最后不管是移动端还是pc端,对于动不动就设置一个具体width或height的方式注定可扩展性欠缺。...如果你所有的都是一刀切,那就是固定的一个思维了,无所谓变通了。 如果从一个更高的角度来说,没有什么是恒定的不变,一切皆可变。

    72010

    onTouchEvent(二) 使用Scroller实现黏性滑动的ScrollView

    前言 本篇文章是之前投稿的一位读者的第二篇文章,也是他的实践之路,自己去实现一些滑动的特效,是掌握Android触控知识的一个非常好的方法,希望大家能够从他的Demo中获得一些新的感悟。...上一篇博文onTouchEvent(一) 你所必须知道的坐标详解介绍了onTouchEvent()手势控制相关的一些坐标概念,这篇文章结合上一篇内容加上Scroller实现一个简单的带黏性滑动的ScrollView...思路 滑动的时候判断最终偏移量是不是超出了子view(ViewGroup内容)的范围,如果超出了就限制不让其超出,这样就可以做出一个滑动的ScrollView并且不会滑出界 当松手(action_up)...的时候判断当前偏移量在该子view的什么位置,如果小于三分之一就滑动回该view的头部,如果超出三分之二就滑动到下个view 首先看看我们需要做些什么,自定义View要复写的方法有好几个,我们要复写的有...但其实一个空实现的函数,那怎么做才能达到我们要的效果呢?layout()重新设置布局位置,不过这个太麻烦了用起来,上一篇介绍的scrollTo()、scrollBy()是正统滑动的代码。 ?

    1K30
    领券