MySQL操作命令梳理(2)
一、表操作
在mysql运维操作中会经常使用到alter这个修改表的命令,alter tables允许修改一个现有表的结构,比如增加或删除列、创造或消去索引、改变现有列的类型、或重新命名列或表本身,也能改变表的注释和表的类型。
下面就针对alter修改命令的使用做一梳理:
在mysql运维操作中会经常使用到alter这个修改表的命令,alter tables允许修改一个现有表的结构,比如增加或删除列、创造或消去索引、改变现有列的类型、或重新命名列或表本身,也能改变表的注释和表的类型。
下面就针对alter修改命令的使用做一梳理:
1、删除列
alter table 表名 DROP 列名; //或者 alter table 表名 drop column 列名;
-------------------------------------------------------------------------------------
drop database 库名; //删除库
drop table 表名; //删除表
delete from 表名; //清空表中所有数据,但这张表没有删除,保留的是空表。
delete from 表名 where ...; //删除表中字段
------------------------------------------------------------------------------------
2、增加列
alter table 表名 ADD 列名 列的属性(如INT NOT NULL COMMENT '注释说明')
3、修改列的类型信息。
alter table 表名 CHANGE 列名 新列名 新列属性;
alter table 表名 CHANGE 列名 新列名(这里可以用和原来列同名即可) BIGINT NOT NULL COMMENT '注释说明'
4、重命名列
alter table 表名 CHANGE 列名 新列名 BIGINT NOT NULL COMMENT '注释说明'
5、重命名表
alter table 表名 RENAME 表新名
6、删除表中主键
alter table 表名 drop primary key
-------------------------------------------------------------------------------------
如若删除带自增属性的主键,那么要先删除自增长,再删除主键
Alter table haha change id id int(); //删除自增长
Alter table haha drop primary key; //删除主建
-------------------------------------------------------------------------------------
7、添加主键
alter table 表名 ADD CONSTRAINT PK_表名 PRIMARY KEY(列名1,列名2)
-------------------------------------------------------------------------------------
Alter table haha add primary key(id); //将haha表的id列添加主键
Alter table haha change id id int() not null auto_increment; //自增长属性
-------------------------------------------------------------------------------------
sql中constraint前缀的用意(PK、UK、DF、CK、FK)
--主键
constraint PK_字段 primary key(字段),
--唯一约束
constraint UK_字段 unique key(字段),
--默认约束
constrint DF_字段 default('默认值') for 字段,
--检查约束
constraint CK_字段 check(约束。如:len(字段)>),
--主外键关系
constraint FK_主表_从表 foreign(外键字段) references 主表(主表主键字段)
8、添加/创建索引
alter table 表名 add index 索引名 列名; //普通索引
ALTER TABLE 表名 ADD UNIQUE index 索引名 (列名1,列名2); //联合索引
ALTER TABLE 表名 ADD PRIMARY index KEY 索引名 列名; //主键索引
-------------------------------------------------------------------------------------
SHOW INDEX FROM 表名字; //查询索引 删除索引可以使用ALTER TABLE或DROP INDEX语句来实现。DROP INDEX可以在ALTER TABLE内部作为一条语句处理
DROP index 索引名 ON 表名字 列名; //删除普通索引
ALTER TABLE 表名 DROP INDEX 索引名 列名; //删除普通索引
ALTER TABLE 表名 DROP UNIQUE 索引名 (列名1,列名2); //删除联合索引
ALTER TABLE 表名 DROP PRIMARY KEY 索引名 列名; //删除主键索引
-------------------------------------------------------------------------------------
9、添加唯一限制条件索引
alter table 表名 add unique emp_name2(cardnumber); //empname 类型 为String 字符串类型
10、创建联合唯一索引
alter table 表名 ADD UNIQUE INDEX 索引名 (列名1,列名2);
alter ignore table 表名 add unique index(user_id,user_name); //它会删除重复的记录(别怕,会保留一条),然后建立唯一索引,高效而且人性化.(慎用)
11、修改字段属性
alter table 表名 modify column 字段名 类型
alter table 表名 modify column 字段1 类型,字段2 类型
例如:将class表的name列属性改成varchar()
alter table class modify column name varchar();
或者:
alter table 表名 change 列名 列名 varchar();
alter table class change name name varchar()
例:
上面提到了使用alter命令修改表名,修改列名;那么修改字段值,就需要使用update命令,如下:
mysql> select * from huanqiu.haha;
+----+-----------+
| id | name |
+----+-----------+
| | wangshibo |
| | ouou |
| | hahahahha |
+----+-----------+
rows in set (0.00 sec) mysql> update huanqiu.haha set name="wangshikui" where id=;
Query OK, row affected (0.00 sec)
Rows matched: Changed: Warnings: mysql> select * from huanqiu.haha;
+----+------------+
| id | name |
+----+------------+
| | wangshibo |
| | wangshikui |
| | hahahahha |
+----+------------+
rows in set (0.01 sec)
1、修改root登陆密码:
mysql> update mysql.user set password=password("") where host='192.168.1.101' and user="root";
update 表名 set 列名="新的字段值" [where 限制条件1 and 限制条件1];
update 表名 set 列名1="新的字段值",列名2="新的字段值" [where 限制条件1 and 限制条件1] [ORDER BY ...] [LIMIT row_count]; insert into 表名 values(所有字段的插入值);
insert into 表名(指定字段) values(指定字段);
insert into 表名 values(所有字段的插入值),(所有字段的插入值),(所有字段的插入值); //批量插入
mysql> select * from huanqiu.haha;
+----+------------+
| id | name |
+----+------------+
| | wangshikui |
+----+------------+
row in set (0.00 sec) mysql> insert into huanqiu.haha values(,"wangshibo"),(,"wangshikui"),(,"wangjuan"),(,"wangman");
Query OK, rows affected (0.00 sec)
Records: Duplicates: Warnings: mysql> select * from huanqiu.haha;
+----+------------+
| id | name |
+----+------------+
| | wangshibo |
| | wangshikui |
| | wangjuan |
| | wangman |
| | wangshikui |
+----+------------+
2、创建操作
创建表时指定AUTO_INCREMENT自增值的初始值:
mysql> CREATE TABLE 表名 (ID INT() PRIMARY KEY AUTO_INCREMENT)AUTO_INCREMENT=;
通过ALTER TABLE 修改初始值(但要大于表中的AUTO_INCREMENT自增值,否则设置无效):
mysql>ATLER TABLE 表名 AUTO_INCREMENT=;
如果自增序列的最大值被删除了,则在插入新记录时,该值被重用。
就是说如果表中原本有AUTO_INCREMENT属性值连续为78、100的值,但100这个数据被删除了,下此再添加数据的时候自增值为101,100被重用了。
即使在你将整个表中的所有数据delete清空后,之前的自增序列最大值还是会被重用。
解决办法是使用下面命令:
ATLER TABLE 表名 AUTO_INCREMENT=; //重新设置自增初始值
设置AUTO_INCREMENT_INCREMENT以及AUTO_INCREMENT_offset用户变量值(重启MySQL之后,这些修改会恢复为初始值1):
mysql>SET auto_increment_increment=; //自增量每次增加的值改为10,
mysql>SET auto_increment_offset=; //第一次加载数值时的偏移值的个位值
mysql>SHOW VARIABLES LIKE 'AUTO_INC%'; //查看修改后变量的值 mysql>SHOW TABLE STATUS FROM NAME_DB; //显示数据库NAME_DB中所有表的信息 mysql>SHOW CREATE TABLE NAME_TBL; //显示表NAME_TBL创建时的信息 mysql>SHOW VARIABLES LIKE 'AUTO_INC%'; //显示MySQL的AUTO_INC开头的用户会话变量(SHOW GLOBAL VARIABLES)
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| auto_increment_increment | |
| auto_increment_offset | |
+--------------------------+-------+
rows in set (0.00 sec)
MySQL操作命令梳理(2)的更多相关文章
- mysql操作命令梳理(3)-pager
在mysql日常操作中,妙用pager设置显示方式,可以大大提高工作效率.比如select出来的结果集超过几个屏幕,那么前面的结果一晃而过无法看到,这时候使用pager可以设置调用os的more或者l ...
- mysql操作命令梳理(2)-alter(update、insert)
在mysql运维操作中会经常使用到alter这个修改表的命令,alter tables允许修改一个现有表的结构,比如增加或删除列.创造或消去索引.改变现有列的类型.或重新命名列或表本身,也能改变表的注 ...
- mysql操作命令梳理(1)-索引
1.创建索引索引的创建可以在CREATE TABLE语句中进行,也可以单独用CREATE INDEX或ALTER TABLE来给表增加索引.以下命令语句分别展示了如何创建主键索引(PRIMARY KE ...
- mysql操作命令梳理(4)-grant授权和revoke回收权限
在mysql维护工作中,做好权限管理是一个很重要的环节.下面对mysql权限操作进行梳理: mysql的权限命令是grant,权限撤销的命令时revoke:grant授权格式:grant 权限列表 o ...
- mysql操作命令梳理-grant授权和revoke回收权限
在mysql维护工作中,做好权限管理是一个很重要的环节.下面对mysql权限操作进行梳理: mysql的权限命令是grant,权限撤销的命令时revoke:grant授权格式:grant 权限列表 o ...
- mysql操作命令梳理(5)-执行sql语句查询即mysql状态说明
在日常mysql运维中,经常要查询当前mysql下正在执行的sql语句及其他在跑的mysql相关线程,这就用到mysql processlist这个命令了.mysql> show process ...
- mysql操作命令梳理(4)-中文乱码问题
在平时的mysql运维操作中,经常会碰到插入中文字段后出现乱码的情况,产生中文乱码的原因一般有:1)mysql的编码格式不对,是latin1编码.强烈推荐将mysql下的编码格式都改为utf8,因为它 ...
- MySQL操作命令梳理(1)
一.索引 1.创建索引 索引的创建可以在CREATE TABLE语句中进行,也可以单独用CREATE INDEX或ALTER TABLE来给表增加索引.以下命令语句分别展示了如何创建主键索引(PRIM ...
- Linux下Mysql 操作命令
Linux下Mysql 操作命令 一.连接MySQL 格式: mysql -h主机地址 -u用户名 -p用户密码 1.例1:连接到本机上的MYSQL. 首先在打开DOS窗口,然后进入目录 mysqlb ...
随机推荐
- seo外链发布之论坛外链
目前最常见的seo外链方式有5种,之前大发迹创业项目网写文章分享过,详情可以查看文章<[网站SEO优化]最常见的五种软文外链发布方式!>,这篇文章不说其他的几种发外链,就来讲讲通过论坛建设 ...
- WebSocket API 学习笔记
WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议. WebSocket 使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据.在 W ...
- scrapy实战8关于数据异步写入mysql:
环境:python3 爬取网址:腾讯社招(http://hr.tencent.com/position.php?keywords=&tid=0&start=0#a)总共2202条数据 ...
- ubuntu18.04上搭建KVM虚拟机环境超完整过程
看标题这是篇纯运维的文章.在中小型企业中,一般很少配置专业的运维人员,都是由开发人员兼着.同时,对有志于技术管理的开发人员来说,多了解一些运维及整个软件生命周期的知识,是很有帮助的,因为带团队不仅仅是 ...
- 用JavaScript做一個簡單的計算器
今天繼續學習JavaScript,視頻講的確實挺差勁的.還是只能跟著W3School自己慢慢摸索著弄了.自己百度了一下,參考了一個大佬寫的一個簡單的計算器代碼.代碼能跑通,但是做出來的樣子實在是感覺太 ...
- QRowTable表格控件(二)-红涨绿跌
目录 一.开心一刻 二.概述 三.效果展示 四.任务需求 五.指定列排序 六.排序 七.列对其方式 八.相关文章 原文链接:QRowTable表格控件(二)-红涨绿跌 一.开心一刻 一天,五娃和六娃去 ...
- SpringCloud-Alibaba-Sentinel(1)初探
Sentinel 是什么? Sentinel 具有以下特征: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围) ...
- [小米OJ] 4. 最长连续数列
思路: 时间限制为O(n),即不能使用先排序后寻找的方法. 这里利用哈希表查询插入复杂度都为O(1)的特性来解,利用一个哈希表来保存每一个数字以及其所在数列的长度. 遍历每一个数字n:查询表中是否存在 ...
- WGS84坐标与web墨卡托投影坐标转换
许久没有使用坐标转换,记忆有些模糊了,以后还是会用到,先将WGS84与web墨卡托转换复习一下: 1.84转web墨卡托 //核心公式 平面坐标x = 经度*20037508.34/108 平面坐标y ...
- Java EE.JSP.脚本
脚本是<%与%>之间Java语言编写的代码块. 1.输出表达式 <%=表达式%>输出表达式的计算结果. 2.注释 1)输出到客户端的注释:<!-comment-> ...