(8条消息) Windows
目录
一、ZIP安装
二、启动、停止
三、登录、退出
四、新增、编辑、删除用户
五、配置、查看、撤销用户权限
六、新增、查看、选择、删除数据库
七、新增、编辑、查看、复制、删除数据库表
八、新增、编辑、删除数据
九、查询数据
十、数据统计、排序
十一、多表查询+取某个字段最大值
十二、查看、设置文件导出导入路径
十三、数据、数据库导出
十四、数据库、数据库表导入
十五、插入、修改、删除字段(更新于20190520)
十六、添加、删除主键(更新于20190520)
十七、Linux下查看初始密码,编辑初始密码策略、配置文件存放路径(更新于20190613)
一、ZIP安装
官网下载ZIP包
bin目录下添加配置文件my.ini
[mysql]# 设置mysql客户端默认字符集default-character-set=utf8[mysqld]# 设置3306端口port = 3306# 设置mysql的安装目录basedir=D:\\mysql-8.0.16-winx64# 设置 mysql数据库的数据的存放目录,MySQL 8+ 不需要以下配置,系统自己生成即可,否则有可能报错# datadir=C:\\web\\sqldata# 允许最大连接数max_connections=20# 服务端使用的字符集默认为8比特编码的latin1字符集character-set-server=utf8# 创建新表时将使用的默认存储引擎default-storage-engine=INNODB# 设置导出文件路径# secure-file-priv="E:/file"secure-file-priv=""
# 初始化数据库(bin目录下)mysqld --initialize --console# 安装mysqlmysqld install# 卸载mysqlmysqld remove
二、启动、停止
# 启动E:\> net start mysql# 停止E:\> net stop mysql
三、登录、退出
# 登录E:\> mysql -h(ip 地址) -u(用户名) -p(密码)# 登录本地数据库E:\> mysql -uroot -p# 退出mysql> exit
四、新增、编辑、删除用户
# 查看全部用户mysql> select user,host from mysql.user;# 新增用户mysql> CREATE USER '(用户名)'@'(ip地址)'-> IDENTIFIED BY '(密码)';# 修改用户名mysql> RENAME USER 'user1'@'localhost' TO 'user2'@'localhost';# 修改root用户初始密码alter user 'root'@'localhost' identified by '123456';# 修改用户密码mysql> set password for root@localhost = password('123456');# 删除用户mysql> DROP USER '(已存在的用户名)'@'(ip地址)';
五、配置、查看、撤销用户权限
# 配置超管权限(全部数据库,全部操作权限)mysql> GRANT ALL-> ON *.*-> TO '(已存在的用户名)'@'(ip地址)'-> WITH GRANT OPTION;# 具有访问bankaccount数据库的所有数据库级权限mysql> GRANT ALL-> ON bankaccount.*DTO '(已存在的用户名)'@'(ip地址)';# 具有访问expenses数据库的特定数据库级权限,例如查询,插入,更新,删除等mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP-> ON expenses.*-> TO '(已存在的用户名)'@'(ip地址)';# 具有特定的表级权限,可以从域中的任何主机访问数据库中 的 addresses表mysql> GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP-> ON customer.addresses-> TO '(已存在的用户名)'@'(ip地址)';# 查看用户权限mysql> SHOW GRANTS FOR 'admin'@'localhost';# 查看非特性属性mysql> SET print_identified_with_as_hex = ON;mysql> SHOW CREATE USER 'admin'@'localhost'\G# 撤销全部权限mysql> REVOKE RELOAD-> ON *.*-> FROM '(已存在的用户名)'@'(ip地址)';# 撤销数据库权限mysql> REVOKE CREATE,DROP-> ON expenses.*-> FROM '(已存在的用户名)'@'(ip地址)';# 撤销数据库表权限mysql> REVOKE INSERT,UPDATE,DELETE-> ON customer.addresses-> FROM '(已存在的用户名)'@'(ip地址)';
六、新增、查看、选择、删除数据库
# 新增数据库mysql> CREATE DATABASE (数据库名);# 查询全部数据库mysql> show databases;# 选择数据库mysql> use (数据库名);# 删除数据库mysql> DROP DATABASE (数据库名);
七、新增、编辑、查看、复制、删除数据库表
# 新增数据库表mysql> CREATE TABLE IF NOT EXISTS `test_data_1`(-> `id` INT UNSIGNED AUTO_INCREMENT, # 自动新增-> `title` VARCHAR(100) NOT NULL, # char类型,不可为空-> `author` VARCHAR(40) , # char类型,可以为空-> `number` INT(10), # int类型,可以为空-> `date` DATE,-> PRIMARY KEY ( `id` ) # 主键-> )ENGINE=InnoDB DEFAULT CHARSET=utf8;# 修改数据表名mysql> alter table table_name rename to table_name_new;#查看所有数据库表mysql> SELECT table_name-> FROM information_schema.tables-> WHERE table_schema='(数据库名)';# 复制数据库表mysql> CREATE TABLE (新数据库表名) LIKE (旧数据库表名);mysql> CREATE TABLE new_tbl AS SELECT * FROM orig_tbl;# 删除数据库表mysql> DROP TABLE test_data_1;
八、新增、编辑、删除数据
# 新增数据mysql> INSERT INTO test_data_1-> (title, author, date)-> VALUES-> ("学习", "小明", NOW());# 编辑数据mysql> UPDATE test_data_1 SET title='打篮球' WHERE id=3;# 删除数据mysql> DELETE FROM test_data_1 WHERE id=3;
九、查询数据
# 查询全部信息mysql> SELECT * FROM test_data_1;# 查询全部title信息mysql> SELECT title FROM test_data_1;# 当id为1的时候,查询全部信息mysql> SELECT * FROM test_data_1 WHERE id=1;# 查询前五行信息mysql> SELECT * FROM table LIMIT 5;# 查询以 abc 为开头的数据mysql> SELECT * FROM test_data_1 WHERE author like 'abc %’;# 查询以 abc 为结尾的数据mysql> SELECT * FROM test_data_1 WHERE author like '%abc ’;# 查询包含 abc 的数据mysql> SELECT * FROM test_data_1 WHERE author like '%abc %’;# 查询最大最小值mysql> select max(chinese_name) ,min(english_name) as english_name-> from p-> where id <11;# 查找name字段中以'st'为开头的所有数据mysql> SELECT name FROM person_tbl WHERE name REGEXP '^st';# 查找name字段中以'ok'为结尾的所有数据mysql> SELECT name FROM person_tbl WHERE name REGEXP 'ok$';# 查找name字段中包含'mar'字符串的所有数据mysql> SELECT name FROM person_tbl WHERE name REGEXP 'mar';# 查找name字段中以元音字符开头或以'ok'字符串结尾的所有数据mysql> SELECT name FROM person_tbl WHERE name REGEXP '^[aeiou]|ok$';
十、数据统计、排序
# 统计总数mysql> select count(id) from s where revenue <500000;mysql> select count(id) as total from s where revenue <500000;# 以id顺序mysql> SELECT * FROM test_data_1 ORDER BY id ASC;# 以id倒序mysql> SELECT * FROM test_data_1 ORDER BY id DESC;
十一、多表查询+取某个字段最大值
mysql> SELECT p.id,p.chinese_name,MAX(s.revenue) as revenue-> FROM p-> LEFT JOIN s ON (p.id=s.id)-> WHERE p.english_name = 'james'-> GROUP BY p.id-> ORDER BY MAX(revenue) desc;

十二、查看、设置文件导出导入路径
# 查询文件导出导入路径mysql> show variables like '%secure_file_priv%';# 设置导出文件路径(在my.ini配置文件的mysqld下添加)secure-file-priv="" # 无路径限制,不推荐secure-file-priv="E:/file"
十三、数据、数据库导出
# 导出数据表(仅数据,不包含数据表结构)mysql> SELECT * into outfile 'E:/file/test1.csv' FROM test_data_1;mysql> SELECT id,title,name into outfile 'E:/file/test1.csv'-> FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'-> LINES TERMINATED BY '\n'-> FROM test_data_1;# 导出数据和数据库表结构E:\mysql-8.0.16\bin> mysqldump -uroot -p123456 test_basess haha > E:/file/db.sql
十四、数据库、数据库表导入
# 仅导入数据库表mysql> source e:/file/test_base.sql;# 导入数据库表的同时创建新的数据库,需要在表数据的前面添加这段代码---- Current Database: `test_haha`--DROP SCHEMA IF EXISTS test_haha;CREATE SCHEMA test_haha;USE test_haha;

十五、插入、修改、删除字段(更新于20190520)
# 默认插入在最后一列mysql> ALTER TABLE test_data ADD number INT(4) ;# 插入在指定列后面mysql> ALTER TABLE test_data ADD number INT(4) AFTER id;# 插入在第一列mysql> ALTER TABLE test_data ADD number INT(4) FIRST;# 修改字段名称mysql> ALTER TABLE test_data CHANGE test test1 CHAR(32) NOT NULL DEFAULT CHARSET=utf8;# 把name字段移动到id后面mysql> ALTER TABLE name MODIFY card CHAR(10) AFTER id;# 把id字段移动到第一位mysql> ALTER TABLE id MODIFY test CHAR(32) NOT NULL DEFAULT '123' FIRST;# 删除字段idmysql> ALTER TABLE test_data DROP id;
十六、添加、删除主键(更新于20190520)
# 添加主键mysql> ALTER TABLE test_data ADD PRIMARY KEY(id);# 添加复合主键mysql> ALTER TABLE test_data ADD PRIMARY KEY(id,name);# 删除主键mysql> ALTER TABLE test_data DROP PRIMARY KEY;# 自增主键需要先删除自增长属性mysql> ALTER TABLE test_data MODIFY id INT UNSIGNED;
十七、Linux下查看初始密码,编辑初始密码策略、配置文件存放路径(更新于20190613)
# 查看初始密码[root@localhost ~]# grep 'temporary password' /var/log/mysqld.log# 查看mysql初始的密码策略mysql> SHOW VARIABLES LIKE 'validate_password%’;# 降低密码的验证强度等级mysql> set global validate_password_policy=LOW;
mysql 密码策略相关字段参数解释:
| 字段 | 解释 |
|---|---|
| validate_password_length | 固定密码的总长度 |
| validate_password_dictionary_file | 指定密码验证的文件路径 |
| validate_password_mixed_case_count | 整个密码中至少要包含大/小写字母的总个数 |
| validate_password_number_count | 整个密码中至少要包含阿拉伯数字的个数 |
| validate_password_policy | 指定密码的强度验证等级,默认为 MEDIUM |
| validate_password_special_char_count | 整个密码中至少要包含特殊字符的个数 |
validate_password_policy 的取值参考:
| 取值 | 解释 |
|---|---|
| 0/LOW | 只验证长度 |
| 1/MEDIUM | 验证长度、数字、大小写、特殊字符 |
| 2/STRONG | 验证长度、数字、大小写、特殊字符、字典文件 |
配置文件存放路径:
| 文件类型 | 存放路径 |
|---|---|
| 配置文件 | /etc/my.cnf |
| 日志文件 | /var/log/mysqld.log |
| 服务启动脚本 | /usr/lib/systemd/system/mysqld.service |
| socket文件 | /var/run/mysqld/mysqld.pid |
赞 (0)

