设为首页 收藏本站
查看: 379|回复: 0

[经验分享] MYSQL 新增字段 删除字段 修改字段 级联删除 级联更新

[复制链接]

尚未签到

发表于 2016-10-24 00:24:06 | 显示全部楼层 |阅读模式
  //添加字段并设置主键
ALTER TABLE tabelname ADD new_field_id int(5) unsigned default 0 not null auto_increment ,ADD primary key (new_field_id);
  
  //加主关键字的索引
ALTER TABLE tablename ADD primary key(id);
  
  //加索引
ALTER TABLE tablename CHANGE depno depno int(5) not null;
ALTER TABLE tablename ADD INDEX 索引名 (字段名1[,字段名2 …]);
ALTER TABLE tablename ADD INDEX emp_name (name);
  
  //加唯一限制条件的索引
ALTER TABLE tablename ADD UNIQUE emp_name2(cardnumber);
  
  //删除某个索引
ALTER TABLE tablename DROP INDEX emp_name;
  
//增加字段:
ALTER TABLE table_name ADD field_name field_type;
  
  //删除字段
ALTER TABLE table_name DROP field_name;
  
  //重命名列
ALTER TABLE table_name CHANGE field_name1 field_name2 integer;
  
  //调整字段顺序
ALTER TABLE `users` CHANGE `user_password` `user_password` varchar( 20 ) NOT NULL AFTER user_name;
  
  //改变列的类型
ALTER TABLE table_name CHANGE field_name field_name bigint not null;
ALTER TABLE infos CHANGE list list tinyint not null default '0';
  
  //修改原字段名称及类型:
ALTER TABLE table_name CHANGE old_field_name new_field_name field_type;
  
  //重命名表
ALTER TABLE table_name rename new_table_name;
  
  //级联更新 和 删除
DROP TABLE IF EXISTS `mail_model`;create TABLE mail_model(id varchar(50) primary key not null ,mail_filename varchar(200),content varchar(2000))ENGINE=InnoDB DEFAULT CHARSET=gbk;
  DROP TABLE IF EXISTS `mail_model_extend`;create TABLE mail_model_extend(id int(6) auto_increment not null primary key,rid varchar(50) not null,content varchar(2000),INDEX (RID),FOREIGN KEY (RID) REFERENCES mail_model(ID) ON DELETE CASCADE ON UPDATE CASCADE)ENGINE=InnoDB DEFAULT CHARSET=gbk;
  
  //创建表格时添加自增字段
  create table table1(id int auto_increment primary key,...)
  
  //创建表格后添加自增字段
  alter table table1 add id int auto_increment primary key 自增字段,一定要设置为primary key.
  ----------------------------------
  
一些重要的mysql语句用法

  1.增加一个字段(一列)
  alter table table_name add column column_name type default value;   type指该字段的类型,value指该字段的默认值
  例如:alter table mybook add column publish_house varchar(10) default '';
  2.更改一个字段名字(也可以改变类型和默认值)
  alter table table_name change sorce_col_name dest_col_name type default value;   source_col_name指原来的字段名称,dest_col_name指改后的字段名称
  例如:alter table Board_Info change IsMobile IsTelphone int(3) unsigned default 1;
  3.改变一个字段的默认值
  alter table table_name alter column_name set default value;
  例如:alter table book alter flag set default '0';
  4.改变一个字段的数据类型
  alter table table_name change column column_name column_name type;
  例如:alter table userinfo change column username username varchar(20);
  5.向一个表中增加一个列做为主键
  alter table table_name add column column_name type auto_increment PRIMARY KEY;
  例如:alter table book add column id int(10) auto_increment PRIMARY KEY;
  6.数据库某表的备份,在命令行中输入:
  mysqldump -u root -p database_name table_name > bak_file_name
  例如:mysqldump -u root -p f_info user_info > user_info.dat
  7.导出数据
  select_statment into outfile"dest_file";
  例如:select cooperatecode,createtime from publish limit 10 into outfile"/home/mzc/temp/tempbad.txt";
  8.导入数据
  load data infile"file_nameinto table table_name;
  例如:load data infile"/home/mzc/temp/tempbad.txtinto table pad;
  9.将两个表里的数据拼接后插入到另一个表里。下面的例子说明将t1表中的com2和t2表中的com1字段的值拼接后插入到tx表对应的字段里。
  例如:insert into tx select t1.com1,concat(t1.com2,t2.com1from t1,t2;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-290233-1-1.html 上篇帖子: MySQL小误区:关于set global sql_slave_skip_counter=N 命令的一些点 下篇帖子: 使用mysql实现row_number() over(partition by col1 order by col2)函数
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表