-- 1.数据库databases相关
-- 查看数据库
SHOW databases;
-- 查看当前使用的数据库
SELECT database();
-- 切换到指定数据库
USE mysql;
USE springbootdb;
-- 创建数据库springbootdb
CREATE DATABASE springbootdb;
-- 删除数据库
DROP DATABASE springbootdb;
-- 如果存在才删除,防止报错
DROP DATABASE IF EXISTS springbootdb;
-- 2.用户user相关
-- 查看当前登陆用户
SELECT user();
-- 查看所有用户
SELECT user,host,authentication_string FROM mysql.user;
-- 创建用户springboot
-- 可以指定主机名或者IP,也可以%允许所有客户端登录
CREATE USER 'springboot'@'localhost' IDENTIFIED BY 'ai12345';
CREATE USER 'springboot'@'192.168.0.1' IDENDIFIED BY 'ai12345';
CREATE USER 'springboot'@'%' IDENTIFIED BY 'ai12345';
-- 修改当前用户密码
SET PASSWORD = PASSWORD("newpassword");
-- 修改指定用户密码
SET PASSWORD FOR 'springboot'@'%' = PASSWORD("newpassword");
-- 删除用户
drop user 'springboot'@'%';
-- 3.权限privilege相关
-- 查看授予用户的权限
show grants for 'root';
show grants for 'springboot';
-- 授权给用户springboot,操作权限,数据库名.表名
GRANT SELECT, INSERT ON springbootdb.city TO 'springboot'@'%';
GRANT ALL ON . TO 'springboot'@'%';
GRANT ALL ON springbootdb.* TO 'springboot'@'%';
GRANT ALL ON springbootdb.city TO 'springboot'@'%';
-- 用上面命令授权的用户不能给其它用户授权
-- 如果想让该用户可以授权,用以下命令,同时可以修改其密码
GRANT ALL ON . to 'springboot'@'%' identified BY 'ai12345' WITH GRANT OPTION;
-- 撤销授权,撤销的权限要和授予时一致
REVOKE ALL ON springbootdb.* FROM 'springboot'@'%';
-- 刷新权限,使之生效
FLUSH privileges;
-- 4.数据库表table相关
-- 查看所有表
SHOW tables;
-- 查看指定的的表结构
DESCRIBE mysql.user;
DESCRIBE springbootdb.city;
-- 如果已经切换到数据库springbootdb,可以省略:
describe city;
-- 创建表city
CREATE TABLE city
(
id
int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '城市编号',
province_id
int(10) unsigned NOT NULL COMMENT '省份编号',
city_name
varchar(25) DEFAULT NULL COMMENT '城市名称',
description
varchar(25) DEFAULT NULL COMMENT '描述',
PRIMARY KEY (id
)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
-- 修改表
-- 添加列
ALTER TABLE city ADD COLUMN city_level INT AFTER city_name;
ALTER TABLE city ADD COLUMN logic_flag int not null default 1 comment '1:正常;0:(逻辑)删除。默认为1'
AFTER description;
-- 删除表
DROP TABLE city;
DROP TABLE IF EXISTS city
;
-- 5.表数据data操作相关
-- 插入数据到表city中,不指定字段名称,必须对应所有字段
INSERT city VALUES (1 ,1,'常州市','木木与呆呆的家在常州。');
-- 指定字段名称,值的填写可以更灵活
INSERT INTO city(id,province_id,city_name,description) VALUES (1 ,1,'常州市','木木与呆呆的家在常州。');
-- 修改表数据
UPDATE city SET city_name='南京市' WHERE id=1;
-- 删除表数据
DELETE FROM city;
-- 指定删除条件
DELETE FROM city WHERE id=1;
-- 直接清空表,会重建表执行效率更高,隐式提交
TRUNCATE city;
-- 查询事务是否为自动提交
SHOW VARIABLES like '%autocommit%'
-- 设置事务手动提交
set @@autocommit=0;
-- 查看表
SELECT * FROM city;
SELECT c.id, c.province_id, c.city_name FROM springbootdb.city AS c;
-- 指定查询条件
SELECT * FROM city WHERE id=1;
-- 6.其他
-- 开启创建函数功能
-- 如果开启了主从复制功能,不建议开启
SET GLOBAL log_bin_trust_function_creators = 1;
SELECT @@global.log_bin_trust_function_creators;
-- 查看服务器变量have_ssl,是否支持SSL
SHOW VARIABLES LIKE '%ssl%';
-- 如果为yes,表示服务端已经开启SSL
-- 查看服务ssl等状态
SHOW STATUS LIKE 'Ssl_cipher';
SHOW STATUS LIKE '%ssl%';
-- 查看MySQL连接
show processlist;
-- 查询并且修改数据库的编码格式
show variables like 'character%';
set character_set_database=utf8;
SET character_set_system=utf8;
-- 查看系统当前时间
SELECT NOW() FROM DUAL;
-- 常用参考模板
-- 1.删除和创建表结构
DROP TABLE IF EXISTS city;
CREATE TABLE city
(
id
int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '城市编号',
province_id
int(10) unsigned NOT NULL COMMENT '省份编号',
city_name
varchar(25) DEFAULT NULL COMMENT '城市名称',
description
varchar(25) DEFAULT NULL COMMENT '描述',
PRIMARY KEY (id
)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
-- 2.查看和删除表数据
SELECT * FROM city;
DELETE FROM city;
-- 3.插入、更新、删除表数据
INSERT city VALUES (1 ,1,'常州市','木木与呆呆的家在常州。');
INSERT INTO city(id,province_id,city_name,description) VALUES (1 ,1,'常州市','木木与呆呆的家在常州。');
-- 1.删除和创建表结构
DROP TABLE IF EXISTS tbl_port;
create table tbl_port
(
device_id varchar(100) not null comment '设备ID',
port_id varchar(100) not null comment '端口ID',
port_name varchar(100) not null comment '端口名称,网元设备上具体接口名称',
band varchar(100) comment '带宽,接口的带宽',
state varchar(100) not null comment '接口状态,接口的激活状态,up/down',
create_time datetime not null comment '创建时间',
update_time datetime comment '修改时间',
primary key (device_id, port_id)
);
-- 2.查看和删除表数据
SELECT * FROM tbl_port;
DELETE FROM tbl_port;
-- 3.插入、更新、删除表数据
INSERT INTO tbl_port(device_id, port_id, port_name, band, state, create_time)
VALUES("0x69E760","28","GigabitEthernet0/3/40",1000,"up",NOW());
INSERT tbl_port VALUES("0x69E760","28","GigabitEthernet0/3/40",1000,"up",NOW(),NULL);