如何使用mysql命令行基本命令大全
MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。我们就要善于使用mysql命令行,从数据库的建立到表数据的删除,小编都给大家整理出来了,请看下文。
如何使用mysql命令行?
1、登陆mysql
打cmd命令终端,如果已经添加了mysql的环境变量,可以直接使用命令
01mysql -uroot
直接回车,之后按提示输入密码,
如果未添加mysql的环境变量,可以切换到mysql的安装目录下的bin目录,再使用
01mysq -uroot
你也可以手动为mysql添加环境变量。这里就不介绍怎么添加环境变量的方法了
密码输入正确之后,就会出现“Welcome to the MySQL monitor. Commands end with ; or \g. ......”字样,
命令行出现“mysql》”字符前缀。现在你就可以使用命令对mysql进行操作了。曾经有没有过这样的经历,原来看见别人在命令行里面咔咔的猛敲时,就一通的崇拜,觉得这人很牛,现在你也可以让别一通崇拜了。
mysql的所有命令都以“;”或者\g为结束符
2、新建数据库
在新建数据库之后,我们先设置一下字符集
01mysql>SET NAMES utf8;
然后再创建数据库
01mysql>CREATE DATABASE lesson
3、显示所有数据库
01mysql>SHOW DATABASES;
4、使用数据库
01mysql>USE 数据库名;
5、新建表
01mysql>CREATE TABLE study(
02id int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '学生id号',
03username varchar(30) NOT NULL DEFAULT '' COMMENT '学生名字',
04class tinyint(3) unsigned NOT NULL,
05sex enum('男','女','保密') CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '保密' COMMENT '性别',
06addtime int(10) NOT NULL DEFAULT '0',
07PRIMARY KEY (id)
08)ENGINE=InnoDB COMMENT = '学生表';
6、显示所有表
01mysql>SHOW TABLES;
7、修改表的名称
01mysql>RENAME TABLE study TO study_new;
或者
01mysql>ALTER TABLE study_new RENAME TO study;
8、显示字段信息
01SHOW COLUMNS FROM study
或者
01DESCRIBE study
9、插入数据
01mysql> insert into study (username,class,sex)VALUES('小王',1,'男'),('小四',2,'女');
10、查询数据(使concat函数拼接数据)
01mysql> SELECT username,CONCAT(class,'班'),sex FROM study;
11、删除数据
01mysql>DELETE FROM study WHERE id=1;
12、删除数据表
01DROP TABLE study;
13、删除数据库
01mysql> DROP DATABASE lesson;
补充:MySQL 数据库常用命令
create database name; 创建数据库
use databasename; 进入数据库
drop database name 直接删除数据库,不提醒
show tables; 显示表
describe tablename; 查看表的结构
select 中加上distinct去除重复字段
mysqladmin drop databasename 删除数据库前,有提示。
显示当前mysql版本和当前日期
select version(),current_date;
数据库维护方法
在MySQL使用的过程中,在系统运行一段时间后,可能会产生碎片,造成空间的浪费,所以有必要定期的对MySQL进行碎片整理。
当删除id=2的记录时候,发生的现象
这个时候发现磁盘的空间并没有减少。这种现象就叫做碎片化(有一部分的磁盘空间在数据删除以后(空),还是无法被操作系统所使用。)
常见的优化:
# alter table xxx engine myisam;
# optimize table t1;
注意: 在实际开发的过程中,上面两个语句尽量少使用,因为在使用的过程中,MySQL的表的结构会整体全部重新整理,需要消耗很多的资源,建议在凌晨两三点钟的时候执行。(在linux下有定时器脚本可以执行,crontab)
MySQL相关文章: