mysql基础

Posted wangzihong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql基础相关的知识,希望对你有一定的参考价值。

1.mysql安装
windows
-可执行文件
-压缩包
-放置任意目录
-初始化
1.1 管理员命令进入mysql bin目录
-初始化
mysqld --initialize
-启动服务端
D:mysqlmysql-5.6.41-winx64inmysqld
-启动客户端
D:mysqlmysql-5.6.41-winx64inmysql -u root -p 密码为空

C:Userslenovo>D:mysqlmysql-5.6.41-winx64inmysql -u root -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or g.
Your MySQL connection id is 1
Server version: 5.6.41 MySQL Community Server (GPL)

Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type ‘help;‘ or ‘h‘ for help. Type ‘c‘ to clear the current input statement.

mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
4 rows in set (0.00 sec)

mysql> create database db1;
Query OK, 1 row affected (0.01 sec)

mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| db1 |
| mysql |
| performance_schema |
| test |
+--------------------+
5 rows in set (0.00 sec)

2 添加环境变量
D:mysqlmysql-5.6.41-winx64in
关闭终端关闭进程
2.1 启动服务端
mysqld
2.2 启动客户端
mysql -u root -p

3 windows服务
以管理员身份运行cmd命令
D:mysqlmysql-5.6.41-winx64inmysqld --install
D:mysqlmysql-5.6.41-winx64inmysqld --remove
"D:mysqlmysql-5.6.41-winx64inmysqld" --install

以管理员身份运行cmd命令启动mysql服务
启动:net start mysql
停止:net stop mysql
以用户运行cmd命令进入客户端
mysql -u root -p
密码修改:set password=password(‘123‘)

4 关于连接
文件夹-数据库
文件-表
数据行-行
用户:root
查看用户信息:
show databases;
use mysql;
show tables;
select user from user;
创建用户:
create user ‘test‘@‘ip‘ identified by ‘123‘;
create user ‘test‘@‘192.168.%‘ identified by ‘123‘;
create user ‘test‘@‘%‘ identified by ‘test‘;
授权:
grant 权限 to wzh;
grant select,insert,update on db1.* to ‘test‘@‘%‘;
grant all privileges on db1.* to ‘test‘@‘%‘; --所有权限

sql语句
操作文件夹
create database db2 default charset=utf8;
show databases;
drop database db2;

操作文件
show tables;
create table t1(id int,name char(10)) default charset=utf8;
create table t1(id int,name char(10)) engine=innodb default charset=utf8; --加入引擎
#innodb支持回滚操作 支持事务操作
crate table t(
列名 类型 null,
列名 类型 not null,
列名 类型 not null default 1, --默认值
列名 类型 not null auto_increment primary key --自增 是自增必须是一个key 一个表只能一个自增列
)engine=innodb default charset=utf8

数据类型:
数值
tigyint
int
bigint
float
double 不太精准的小数
decimal 精准的 底层是按字符串存储
字符串
char(10) 速度快 定长的数据类型放前面
varchar(10) 节省空间 速度没有char快
-后面都需要加长度
-最高255字符
text 65535
longtext
上传文件:
存储在硬盘,数据库中存路径
时间类型
date
time
year
datetime
timestamp
枚举类型 enum
集合类型 set

操作文件中内容
select * from t1;
插入数据,插入中文时会乱码
insert into t1(id,name) values(1,‘A‘);
insert into t1(id,name) values(1,‘测试‘);

解决中文乱码问题:
在创建时设置字符集 default charset utf8

清空表内容:
delete from t1;
truncate table t1;
删除表:
drop table t1;

5 增删改查
insert
delete
update
select

6 外键
emp表 dept表
create table emp(
id int auto_increment primary key,
name varchar(50),
dept_id int,
constraint fk_emp_dept foreign key(dept_id) references dept(id)
)engine=innodb default charset=utf8;

create table dept(
id int auto_increment primary key,
dname varchar(50)
)engine=innodb default charset=utf8;


mysql> create table dept(
    -> id int auto_increment primary key,
    -> dname varchar(50)
    -> )engine=innodb default charset=utf8;
Query OK, 0 rows affected (0.23 sec)

mysql> create table emp(
    -> id int auto_increment primary key,
    -> name varchar(50),
    -> dept_id int,
    -> constraint fk_emp_dept foreign key(dept_id) references dept(id)
    -> )engine=innodb default charset=utf8;
Query OK, 0 rows affected (0.27 sec)

mysql> insert into dept(dname) values(sales);
Query OK, 1 row affected (2.05 sec)

mysql> insert into dept(dname) values(analysis);
Query OK, 1 row affected (0.41 sec)

mysql> select * from dept;
+----+----------+
| id | dname    |
+----+----------+
|  1 | sales    |
|  2 | analysis |
+----+----------+
2 rows in set (0.00 sec)

mysql> insert into emp(name,dept_id) values(A,1);
Query OK, 1 row affected (2.06 sec)

mysql> select * from emp;
+----+------+---------+
| id | name | dept_id |
+----+------+---------+
|  1 | A    |       1 |
+----+------+---------+
1 row in set (0.00 sec)

mysql> insert into emp(name,dept_id) values(A,3);
ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`db2`.`emp`, CONSTRAINT `fk_emp_dept` FOREIGN KEY (`dept_id`) REFERENCES `dept` (`id`))

查看表创建

show create table emp G;

自增设置

mysql> create table t2(id int auto_increment primary key,num int)engine=innodb default charset=utf8;
Query OK, 0 rows affected (2.30 sec)

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> insert into t2(num) values(1);
Query OK, 1 row affected (0.08 sec)

mysql> insert into t2(num) values(2);
Query OK, 1 row affected (0.07 sec)

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> insert into t2(num) values(3);
Query OK, 1 row affected (2.06 sec)

mysql> insert into t2(num) values(4);
Query OK, 1 row affected (0.06 sec)

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> delete from t2 where id=3;
Query OK, 1 row affected (0.70 sec)

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR:
No query specified

mysql> insert into t2(num) values(5);
Query OK, 1 row affected (0.12 sec)

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql> alter table t2 AUTO_INCREMENT=10;
Query OK, 0 rows affected (2.06 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

mysql> insert into t2(num) values(6);
Query OK, 1 row affected (2.05 sec)

mysql> show create table t2 G;
*************************** 1. row ***************************
       Table: t2
Create Table: CREATE TABLE `t2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

自增步长  基于会话级别步长

--查看会话步长
mysql> show session variables like auto_inc%;
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 1     |
| auto_increment_offset    | 1     |
+--------------------------+-------+
--设置会话步长
mysql> set session auto_increment_increment=2;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from emp;
+----+------+---------+
| id | name | dept_id |
+----+------+---------+
|  1 | A    |       1 |
+----+------+---------+
1 row in set (0.00 sec)

mysql> insert into emp(name,dept_id) values(B,1);
Query OK, 1 row affected (2.09 sec)

mysql> select * from emp;
+----+------+---------+
| id | name | dept_id |
+----+------+---------+
|  1 | A    |       1 |
|  3 | B    |       1 |
+----+------+---------+
2 rows in set (0.00 sec)

mysql> show session variables like auto_inc%;
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_increment_increment | 2     |
| auto_increment_offset    | 1     |
+--------------------------+-------+

全局步长设置

set global auto_increment_increment=20;

会话和全局步长

--会话
show session variables like auto_inc%; --查看
set session auto_increment_increment=2;  --步长
set session auto_increment_offset=10;  --起始值

--全局
show global variables like auto_inc%;
set global auto_increment_increment=2;
set global auto_increment_offset=10;

===========================分割============================

1.唯一约束

  create table t1(

  id int,

  num int,

  d_id int,

  unique uq1(num)

  unique uq2(num,d_id)  --联合唯一

)

ps:唯一约束不能重复(可以为空)

    加速查找

2 外键的变种

  外键+唯一 ===> 一对一 

                create table userinfo1(
                    id int auto_increment primary key,
                    name char(10),
                    gender char(10),
                    email varchar(64)
                )engine=innodb default charset=utf8;
 
                create table admin(
                    id int not null auto_increment primary key,
                    username varchar(64) not null,
                    password VARCHAR(64) not null,
                    user_id int not null,
                    unique uq_u1 (user_id),
                    CONSTRAINT fk_admin_u1 FOREIGN key (user_id) REFERENCES userinfo1(id)
                )engine=innodb default charset=utf8;

  多对多 -- 多张表 双向一对多 在第三张表中有多个外键,根据需求可以将这多个外键联合唯一 

create table userinfo2(
                    id int auto_increment primary key,
                    name char(10),
                    gender char(10),
                    email varchar(64)
                )engine=innodb default charset=utf8;
 
                create table host(
                    id int auto_increment primary key,
                    hostname char(64)
                )engine=innodb default charset=utf8;
 
 
                create table user2host(
                    id int auto_increment primary key,
                    userid int not null,
                    hostid int not null,
                    unique uq_user_host (userid,hostid),
                    CONSTRAINT fk_u2h_user FOREIGN key (userid) REFERENCES userinfo2(id),
                    CONSTRAINT fk_u2h_host FOREIGN key (hostid) REFERENCES host(id)
                )engine=innodb default charset=utf8;

sql语句数据行操作

--
create table tb12(
                id int auto_increment primary key,
                name varchar(32),
                age int
            )engine=innodb default charset=utf8;
insert into tb12(name,age) values(A,22);  --插入单条
insert into tb12(name,age) values(A,22),(B,33);  --插入多条

create table tb13(
                id int auto_increment primary key,
                name varchar(32),
                age int
            )engine=innodb default charset=utf8;
insert into tb13(name,age) select name,age from tb12;  -- 从另一张表插入新的表 

--
delete from tb12 where id = 1;  --  可以用 < 、>、 !=、 not 、not in 

--
update tb12 set name=C,age=33 where id = 1 and name = A;

--
select id,name,age from tb12 where id = 1;
select name,age from tb12 where age like 3%;  -- 通配符
select name,age from tb12 where age like 3_;
select name,age from tb12 limit 1,2;  -- 分页
select name,age from tb12 limit 3 offset 1;  -- 从第1行读(不含1),读取3行
select * from tb12 order by id desc -- 排序 asc升序
select * from tb12 order by id desc limit 10;  -- 取后10条数据
select age,count(id) from tb12 group by age;  -- 分组
select age,count(id) from tb12 group by age having count(id) > 1;  -- 分组后的数据进行筛选
    --连表操作
select t12.name,t13.age from t12 left join t13 on t12.id = t13.id -- 左外连接 左表为基表匹配右表,匹配不上的空值补充
--right join 右表全部显示
--inner join 匹配上的数据
--outer full join 显示全部

 转储sql文件

-- 在当前目录下产生db1.sql文件 数据表结构+数据
mysqldump -u root db1 > db1.sql -p

-- 加参数 -d 数据库表结构
mysqldump -u root -d db1 > db1.sql -p

-- 导入现有数据库 < 
mysqldump -u root -d db1 < db1.sql -p

 






























































































































































以上是关于mysql基础的主要内容,如果未能解决你的问题,请参考以下文章

linux中怎么查看mysql数据库版本

从mysql的片段中加载ListView

[Go] 通过 17 个简短代码片段,切底弄懂 channel 基础

连接MySQL出现错误:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)(代码片段

使用 json rereiver php mysql 在片段中填充列表视图

关于mysql驱动版本报错解决,Cause: com.mysql.jdbc.exceptions.jdbc4Unknown system variable ‘query_cache_size(代码片段