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

每日一面 - MySQL添加一列

问题参考自: https://www.zhihu.com/question/440231149 ,mysql中,一张表里有3亿数据,未分,要求是在这个大表里添加一列数据。...答案为个人原创 以前老版本 MySQL 添加一列的方式: ALTER TABLE 你的 ADD COLUMN 新列 char(128); 会造成锁,简易过程如下: 新建一个和 Table1 完全同构的...针对 MySQL 5.6(不包含)之前的版本,通过触发器将一个的更新在另一个上重复,并进行数据同步,当数据同步完成时,业务上修改名为新并发布。业务不会暂停。...UPDATE"; Replace into 新 SELECT * from 原有 where 新.id = 原有.id; END IF; end; MySQL 5.6(包含) 以后的版本引入了在线...这个原理很简单,对于新建一列所有原有数据并不是立刻发生变化,只是在表字典里面记录下这个列和默认值,对于默认的 Dynamic 行格式(其实就是 Compressed 的变种),如果更新了这一列则原有数据标记为删除在末尾追加更新后的记录

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

    啥,又要为增加一列属性?

    需求缘起 产品第一版:用户有用户名、密码、昵称等三个属性,对应设计: user(uid, name, passwd, nick) 第二版,产品经理增加了年龄,性别两个属性,结构可能要变成: user...不太可行,锁时间长 (2)新+触发器?如果数据量太大,新不一定装得下,何况触发器对数据库性能的影响比较高 (3)让dba来搞?新,迁移数据,一致性校验,rename?...dba真苦逼 今天分享2个列扩展性设计上几个小技巧,只占大伙1分钟(下班太晚的话,只能写一分钟系列=_=) 方案一:版本号+通用列 以上面的用户为例,假设只有uid和name上有查询需求,可以设计为...里的字段无法建立索引 (2)ext里的key值有大量冗余,建议key短一些 改进: (1)如果ext里的属性有索引需求,可能Nosql的如MongoDB会更适合 方案二:通过扩展行的方式来扩展属性 以上面的用户为例

    1.7K90

    python pandas VS excel成绩赋值等级

    pandas VS excel成绩赋值等级 【问题】有一张成绩如下 【要求】 在总分后面添加一列,按如下要求输入等级 【知识点】 apply函数 apply函数是`pandas`里面所有函数中自由度最高的函数...这个函数需要自己实现,函数的传入参数根据axis来定,比如axis = 1,就会把一行数据作为Series的数据 结构传入自己实现的函数中,我们在函数中实现对Series不同属性之间的计算,返回一个结果..."B" elif score>=60: return "C" else: return "D" d=pd.read_excel('pandas VS excel成绩赋值等级...) print(d) d['等级']=d['总分'].apply(lambda x: get_letter_grade(x)) print(d) d.to_excel('pandas VS excel成绩赋值等级..._out.xlsx',index=False) print("done") 说明: 1.把Excel成绩读入打印出来为 2.新建一个“等级“的列,并赋值等级如下 3.输出为excel文件内容如下

    2.2K10

    es6的解构赋值_字符串赋值字符指针

    ES6 模板字符串与解构赋值 解构赋值 展开运算符 模板字符串 特点 模板字符串可以换行 模板字符串中变量表达方式 ${变量/表达式} //模板字符串 //特点...document.createElement('ul'); ul.innerHTML=arry.join(''); document.body.appendChild(ul); 解构赋值...特点: 可以定义默认值 可以嵌套 可以不完全解构 好处: 不通过遍历,方便快捷的将元素取出来 //解构赋值 //可以定义默认值 //可以嵌套 //可以不完全解构...//数组用法 let a=[1,2,3] let [b,c,d]=a; console.log(b,c,d)//1,2,3 //数组解构赋值时可以嵌套 let s=[[1,2...],[3,4]] let [[s1,s2],[s3,s4]]=s; console.log(s1,s2,s3,s4)//1,2,3,4 //数组解构赋值可以定义默认值 let b1=[1,2,3

    2.3K20
    领券