1、下载mysqld
在网页中依次点击:DOWNLOADS--->MySQL Community(GPL)Downloads---->MySQL Community Server
这里以下载mysql-5.6.46-winx64.zip为例
下载成功后解压--->改名为mysql56
2、添加系统环境变量
把mysql56下bin文件的目录路径添加到系统的环境变量中
3、把mysql制作成系统服务
注意:在制作之前要把mysqld关掉(在命令提示符中输入taskkill /F /PID xxxx ,xxx可以通过输入tasklist |findstr mysqld查看)
制作:在命令提示符中输入mysqld --install回车后就制作成功,可以通过在win+R中输入services.msc中查看制作成功(MySQL)
此时可以通过双击MySQL启动
可以在cmd中输入:net start mysql / net stop mysql 进行开启/关闭mysql
4、启动
启动服务端:
mysqld
启动客户端:
mysql -uroot -p -h127.0.0.1 -p 3306
如果在本机登陆mysqld客户端可以简写:
mysql -uroot -p
5、修改密码
在系统命令提示符(以管理员身份运行)中输入mysqladmin -uroot -p password "123”,然后回车在回车就会把密码设置成123,如果再把密码改为456:
mysqladmin -uroot -p123 password "456" 回车就会修改成功
6、破解管理员密码
(1)先跳过密码登入:
#1 关闭mysql
#2 在cmd中执行:mysqld --skip-grant-tables
(2)打开新的cmd输入 mysql -uroot -p登入
(3)修改密码:update mysql.user set password=password("123") where user="root" and host="localhost";
刷新:flush privileges
(4)在命令行中用taskkill /F /PID xxxx杀死mysqld服务,然后正常启动mysqld
7、统一字符编码
问题:以管理员的身份运行cmd--->mysql -uroot -p456--->\s:此时会发现表格数据中有多种编码(latinl、gbk),需要统一改为utf8
解决方法:在mysql56目录下新建文档,改名为my.ini,然后用Notepad++打开,进行如下配置:
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
user="root"
password="2180736"
default-character-set=utf8
然后关闭再重启mysql,编码就会统一为utf8
8、创建用户以及授权
连接:
默认:用户root
创建:
create user 'alex'@'192.168.1.1' identified by '123123';
create user 'alex'@'192.168.1.%' identified by '123123';
create user 'alex' @'%' identified by '123123';
授权:
用法:
show grants for '用户'@'IP地址' -- 查看权限
grant 权限 on 数据库.表 to '用户'@'IP地址' -- 授权
revoke 权限 on 数据库.表 from '用户'@'IP地址' -- 取消权限
例如:
grant select,insert,update on db1.t1 to 'alex'@'%'; 用户在任何机器上都能对 db1数据库下面的t1做查看、插入、更新操作
grant all privileges on db1.t1 to 'alex'@'%'; 给用户授权所有功能(用户授权给别人的功能除外)
9、基本的SQL语句
1、文件夹(库) 增 create database db1 charset utf8; 改 alter database db1 charset gbk; 查 查看所有库的库名 show databases; 单独查看某一个库的信息 show create database db1; 删 drop database db1;2、文件(表) 首先切换文件夹: use db1; select database(); #查看当前所在的文件夹 增
create table t1(id int,name char);
create table t1(id int,name char)engine=innodb default charset=utf8;
create table t3(id int auto_increment primary key,name char(10))engine=innodb default charset=utf8; *****
create table t1(
列名 类型 null,
列名 类型 not null,
列名 类型 not null auto_increment primary key,
id int,
name char(10)
)engine=innodb default charset=utf8;
# innodb 支持事务,原子性操作
# myisam myisam
auto_increment 表示:自增 (一个表里面只能有一个自增列)
primary key: 表示 约束(不能重复且不能为空); 加速查找 (一般与auto_increment 连用)
not null: 是否为空
数据类型:
1、数字:
tinyint:-128127 0255
int:-21474836482147483647 04294967295
bigint:-9223372036854775808 ~ 9223372036854775807 0 ~ 18446744073709551615
FLOAT
0.00000100000123000123001230123 (数据不精准)
DOUBLE
0.00000000000000000000100000123000123001230123
0.00000100000123000000000000000 (数据不精准)
decimal
注意:对于精度数值计算时需要用此类型,
decimal能够储存精确值的原因在于其内部按照字符串储存
2、字符串:
char(m) 速度快()
char数据类型用于表示固定长度的字符串,可以包含最多达255个字符。其中m代表字符串的长度,即使数据小于m长度,也会占用m长度
varchar(10) 节省空间
varchars数据类型用于变长的字符串,可以包含最多达255个字符。其中m代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可 以被保存在该数据类型中。
PS: 创建数据表定长列往前放,,,,char、varchar最多存255个字符
3、text:
上传文件:
文件存硬盘
db存路径
4、时间类型:
DATETIME: YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)
5、enum:枚举类型
CREATE TABLE shirts (
name VARCHAR(40),
size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
);
INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');
6、set:集合类型
CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
create table t1(
id int signed not null auto_increment primary key,
num decimal(10,5),
name char(10)
)engine=innodb default charset=utf8;
改 alter table t1 modify name char(16); 查 查看当前库下所有的表名 show table 查看t1表的详细信息 show create table t1; 查看表结构 desc t1;
清空
1、delete from t1;(自增情况下清空再插入数据,序号从上面递增)
2、truncate table t1;(运行速度比上面的快 ,再插入数据序号从1开始)
删 drop table t1;3、文件的一行内容(记录) 增 insert into db1.t1(id,name) values (1,'egon'), (2,'alex'), (3,'lxx'); 改 update db1.t1 set name='sb' where id > 1; 查 select id,name from db1.t1; 删 delete from t1;(全部删除) delete from db1.t1 where name = "SB" ; (有条件的删除)详见:https://www.cnblogs.com/wupeiqi/articles/5713323.html