mysql基本操作
对于一个企业来说,数据的重要性是毋庸置疑的。作为一个运维人员,必须要掌握基本的数据库操作,为了方便以后查看,我把一些简单的数据库命令写出来。
查看数据库
MariaDB [(none)]> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | | test | +--------------------+
创建数据库
MariaDB [(none)]> create database xhk;
进入数据库并创建一个表
MariaDB [(none)]> use xhk; Database changed MariaDB [xhk]> create table stu (id int auto_increment primary key,name varchar(20) unique key);
查看表的结构,有2种方法
MariaDB [xhk]> DESC stu; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(20) | YES | UNI | NULL | | +-------+-------------+------+-----+---------+----------------+ MariaDB [xhk]> show create table stu; +-------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | Table | Create Table | +-------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | stu | CREATE TABLE `stu` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) DEFAULT NULL, PRIMARY KEY (`id`), UNIQUE KEY `name` (`name`) ) ENGINE=InnoDB DEFAULT CHARSET=latin1 | +-------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
在表中插入多条数据
MariaDB [xhk]> insert into stu(id,name) value(1,'xhk'),(2,'xxx');
查询表的内容
MariaDB [xhk]> select * from stu; +----+------+ | id | name | +----+------+ | 1 | xhk | | 2 | xxx | +----+------+
也可以按照需要查询
MariaDB [xhk]> select * from stu where id = 1; +----+------+ | id | name | +----+------+ | 1 | xhk | +----+------+
使用*号查询所有,但线上数据很大,使用*可能导致数据库压力增大,影响性能,建议使用特定的值来查询
MariaDB [xhk]> select name from stu; +------+ | name | +------+ | xhk | | xxx | +------+
修改表中的数据
MariaDB [xhk]> update xhk set name='qqq' where id=2;
删除表中的一行
MariaDB [xhk]> delete from stu where id=2 ;
增加表的字段
MariaDB [xhk]> alter table stu add age int;
删除表的字段
MariaDB [xhk]> alter table stu drop age;
修改字段的类型
MariaDB [xhk]> alter table stu modify name varchar(20);
修改字段的名字以及类型
MariaDB [xhk]> alter table stu change name names varchar(10);
修改表的名字
MariaDB [xhk]> rename table stu to student;
删除表中的全部数据
MariaDB [xhk]> delete from student;
创建用户和设置密码并且指定用户对所有库都有所有权,并且允许所有主机
MariaDB [xhk]> grant all on *.* to "xhk1"@"%" identified by "123456";
修改用户的密码
MariaDB [xhk]> update mysql.user set password=password('redhat') where user="xhk1";
查看用户的权限
MariaDB [xhk]> show grants for "xhk1"@"localhost"; +----------------------------------------------------------------------------------------------------------------------+ | Grants for xhk1@localhost | +----------------------------------------------------------------------------------------------------------------------+ | GRANT ALL PRIVILEGES ON *.* TO 'xhk1'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' | +----------------------------------------------------------------------------------------------------------------------+
创建用户只有对xhk库的student表有查询权限,并且只允许本地登录
MariaDB [xhk]> grant select,update,delete,insert on xhk.student to "xhk1"@"localhost" identified by "123456";
收回用户的某个权限
MariaDB [xhk]> revoke update,delete,insert on xhk.student to "xhk1"@"localhost";
删除用户
MariaDB [xhk]> delete from mysql.user where name="xhk1" and host="localhost";