重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
mysql修改数据表的语法结构一般来说通过alter语句即可。
创新互联专注于阿拉尔网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供阿拉尔营销型网站建设,阿拉尔网站制作、阿拉尔网页设计、阿拉尔网站官网定制、微信小程序定制开发服务,打造阿拉尔网络公司原创品牌,更为您提供阿拉尔网站排名全网营销落地服务。
1、增加列[add
列名]J
例:alter
table
test
add
username
char(20)
not
null
default
'';
2、删除列[drop
列名]
alter
table
test
drop
pid;
3、修改列[modife
列名]
alter
table
test
modify
gender
char(4)
not
null
default
'';
有时候,会很不小心,在业务运行中执行了一条锁表语句。这时候该怎么办?
例如:修改元数据。
SHOW FULL PROCESSLIST 查看一下:
发现修改之后,锁表了。这时候怎么办? 杀死它 KILL 4623660
然后一切又恢复正常了。
一般对于数据量较大的表,需要修改表结构,或者做一些耗时比较久的锁表操作,建议在晚上(业务闲时)执行。这个时候可以配合使用任务处理一下。
如:修改一个表的字段长度,和添加索引
名词解释:
接着回家睡觉,第二天回来检查结果就好了。
附:添加唯一索引示例
MYSQL存储过程结合任务处理耗时操作
修改mysql数据库表的方法:使用“ALTER TABLE”语句,可以改变原有表的结构,例如增加字段或删减字段、修改原有字段数据类型、重新命名字段或表、修改表字符集等;语法“ALTER TABLE 表名 [修改选项]”。
修改数据表的前提是数据库中已经存在该表。修改表指的是修改数据库中已经存在的数据表的结构。修改数据表的操作也是数据库管理中必不可少的,就像画素描一样,画多了可以用橡皮擦掉,画少了可以用笔加上。
不了解如何修改数据表,就相当于是我们只要画错了就要扔掉重画,这样就增加了不必要的成本。
在 MySQL 中可以使用 ALTER TABLE 语句来改变原有表的结构,例如增加或删减列、更改原有列类型、重新命名列或表等。
工具/材料
Navicat For MySQL
01
打开Navicat for MySQL,找到一个数据库,然后右键单击表,选择新建表选项,如下图所示
02
在弹出的新建表界面,我们给表建一些字段,如下图所示,建好之后保存即可
03
建好的表会在数据库的右侧界面显示出来,需要查看哪个表直接选择即可
04
下面我们在test数据库中新建一个查询,通过alter table语句修改表中的age字段不为空,如下图所示
问题:
我们知道在MySQL中如果要执行ALTER TABLE操作,MySQL会通过制作原来表的一个临时副本来工作。对于表结构的修改在副本上施行,然后将新表替换原始表,此时会产生锁表,用户可以从原始表读取数据,而用户的更新和写入操作都会被lock,待新表准备好后写入新表。
由于在这个过程中会锁表。造成当前操作的表无法写入数据,影响用户使用。由于需要复制原表的数据到中间表,所以表的数据量越大,等待的时候越长,卡死在那里(用户被拒绝执行update和insert操作,表现就是延迟了一直在等待)。
解决方式:
我们这里借助影子拷贝的思想利用mysql load data 与 select into outfile手动导数据:
导出语法:
导入语法:
原表结构:
目标表结构:
在mysql命令行执行命令
这一步可能会报错:
解决方式:
在/etc/my.cnf配置文件中加入 secure-file-priv='' ,然后重启mysql服务器, service mysqld restart
也有可能会报错:
解决方式:
给mysql用户加上/tmp/data目录的rwx权限就可以啦
完成