Mysql 初始数据库

Mysql是基于C/S端的服务器软件

  Mysql服务端

  --server端开启

  --解析指令

  --对文件夹,文件,数据的增删改查

  

  Mysql客户端

  --连接S端

  --发送指令(sql语句)

一.安装mysql

  数据库服务器(一台电脑)

  数据库管理系统(Mysql软件)

  数据库(data/db 一个文件夹)

  表: (一个文件)

  记录:多个字段的信息组成一条记录,即文件中的一行内容

  1.解压MySQL的压缩包 到E:

  2.E:\mysql-5.7.21-winx64\bin 添加系统的环境变量

  3.初始化软件data目录

    生成data目录 存放数据库→文件→记录

    **初始化的时候,一定要等着自己退出      mysqld --initialize-insecure

二.开启mysql服务端

  4.mysql(必须授权)

三.开启客户端,连接服务端

  5.mysql -uroot -p

四.安装window服务

  mysqld --install  安装window服务

  mysqld --remove 移除window服务

  net start mysql : 开启服务端

  net stop mysql: 关闭服务端

五.忘记密码怎么办

  (1)先关闭掉之前的mysql服务器的进程

  (2)跳过授权表开启mysql的服务端  mysql --skip-grant-tables  (开启服务端的约束条件,跳过授权)

  (3)客户端连接mysql -uroot -p

  (4)更改密码:update mysql.user set authenation_string =password('') where User='root';

  (5)刷新权限 flush privis;

  查看进程号: tasklist |findstr mysql

  杀死进程: taskkill /F /PID 进程号

六.统一字符编码

  在Mysql软件的目录下新创建一个my.ini

[mysqld]
# 设置mysql的安装目录 **后面的路径一定是安装sql的目录(自己电脑的)**
basedir=C:\mysql-5.7.22-winx64\mysql-5.7.22-winx64
# 设置mysql数据库的数据的存放目录,必须是data
datadir=C:\mysql-5.7.22-winx64\mysql-5.7.22-winx64\data            sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
# mysql端口
port=3306
# 字符集
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

  再次重启mysql 服务端

  查看mysql软件配置:

  mysql -uroot -p

  \s;

七.创建mysql用户

  如何创建用户和密码

  creat user 'lqy'@'192.118.1.1' identified by '123';

  mysql -ulqy -h 192.168.13.29 -P 3306 -p123

  授权  grant 这个权限只有root有

  grant all privileges on *.* to 'xxx'@'%';

  revoke all privileges on *.* from 'xxx'@'%';

  

  show databases; 查看所有的数据库

  use db ; 使用数据库

  

  创建表(设计表)

  creat table t1(id int,name char(10)) defult charset='utf8';

  insert into t1(id,name) values(1,'liu'),(2,'wu');

  

  查询所有的数据     select * from t1;

  查询个别字段的数据  select id from t1;

八.sql的基本语法

  对数据库  create databa db1;

  对表  create table t1(id int,name char(10));

      show create table t1;

      show tables; 查看所有的表

      desc t1; 查看表的详细结构

  对数据

    insert into t1(id,name) values(1,'liu'),(2,'wu'); 插入

    insert into t1value(3,'cui');

    select id from t1;

    select id,name from t1;

    select * from t1;

    select * from db1.t1 where id = 2;

    关系型数据库:mysql db2 oricle sqlite  表中存储

    非关系型数据库:monogodb redis

        key: value 基于model 模型 obj.insert

九.存储引擎

  mysql 5.5版本之后默认为innodb 存储引擎,另外还有mysiam,memory,blackhole

  *memory,在重启mysql或者重启机器后,表内数据清空

  *blackhole,往表内插入任何数据,都相当于丢入黑洞,表内永远不存记录

 

  复制表结构和表数据  create table a1 select * from db2.t1;

  只复制表结构  create table a2 select * from db2.t1 where 1>2;

          create table a3 like db2.t1;

十.数据类型

  1.数字:

    整型:tinyint  int  bigint

    小数:float: 在位数比较短的情况下不精准

       double: 在位数比较长的情况下不精准

       decimal:内部原理是以字符串形式去存,精准.(如果用小数,则推荐使用decimal)

  2.字符串

    char(10):简单粗暴,浪费空间,存取速度块

    varchar:精准,节省空间,存取速度慢

    sql优化:创建表时,定长的类型往前放(比如性别),变长的往后放(比如地址或描述信息)

    >255个字符,超了就把文件路径存放在数据库中.比如图片,视频等找到一个文件服务器,数据库只存在路径或url.

  3.时间类型  最常用:datetime

  4.枚举型与集合型

    enum 和 set

  --整型 默认是signed,有符号的 范围 -128~127

    sql中没有布尔类型,使用tinyint(1)来表示boolean值1,表示true;tinyint(0)表示false

  --int类型后面的存储是显示宽度而不是存储宽度,其他的数据烈性是村春宽度

    所以我们来设计表的时候,int类型的字段不用加显示宽度,默认是总长度的位数+1(定义int类型不需要加宽度,使用默认就可以)

  --datetime   now()  sql的内置函数,根据数据类型生成对应的时间格式

  --char  定长  存储速度快,浪费空间

    varchar 变长,存储速度慢,节省空间

  --enum枚举  表示多选一

  --set 集合 表示多选一或者多选多

 create table consumer(
             id int unsigned,
             name,varchar(20),
             sex enum('male','female','other'),
             level enum('vip','svip','vvip'),
             fav set('smoke','drink','tangtou'),
 );
  insert into consumer values(1,'刘清扬','male','vip','drink');        

  小结:

    数据类型:

        整型:tinyint  int   bigint

        浮点型: float   double decimal

        时间: year   date   time    datetime

        字符:char 定长>varchar变长>text文本

        枚举:enum

        集合:set

        布尔:boolean  tinyint(1) 表示true/0,表示false

        函数:now()根据字段的数据类型获取当前的时间格式

            char_length:获取字符长度

           length():获取字节长度

        sql中默认是有符号的,如果设置无符号unsigned,用0填充 zerofill

十一.约束***

    作用:保证数据的完整性和一致性

    表的设计

    1.not null 与 default

create table tb1(id int not null default 2,name char(20) not null);
insert into tb1 values(1,'liu');
insert into tb1(name) values('wu');
insert into tb1(id) values(3);

    2.unique

      单列唯一

create table dep(id int not null,name varchar(20) unique);
insert into dep(id,name) values(1,'liu');
insert into dep(id,name) values(2,'liu');

      多列唯一,表示每一列都唯一

create table dep2(id int unique,name varchar(20) unique);
insert into dep2(id,name) values(1,'liu');
#不能插入值
insert into dep2(id,name) values(1,'liu2');
insert into dep2(id,name) values(2,'liu');

      组合唯一(联合唯一) 只要有一列不同,就可以插入数据

create table dep3(
            id int,
            name varchar(20),
            unique(id,name)
  );
insert into dep3(id,name) values(1,'liu'); 
insert into dep3(id,name) values(1,'liu2');    
insert into dep3(id,name) values(2,'liu');    
#不能插入的格式
insert into dep3(id,name) values(1,'liu');       

    3.primary key(索引优化查询)

        sql版本中,一张表只允许有一个主键,通常都是id,cid,nid,sid

create table stu(
		id int primary key auto_increment,
		name varchar(10) unique
);
insert into stu(name) values ('alex');
				
化学反应: not null + unique
create table stu2(
		id int not null unique auto_increment,
		name varchar(10) unique
);

  primary key(索引优化)

  key 查询优化:前提,准备大量数据

    4.auto_increment  自增长

create table tb1(id int primary key auto_increment,name varchar(20) not null);
create table tb2(id int primary key auto_increment,name varchar(20) not null);
insert into tb1(name) values ('liu');
insert into tb2(id,name) values(4,'liu');

    5.清空表区分delete和truncate的区别:

      delete from t1:如果有自增id,新增的数据,仍然是以删除前的最后一样作为起始.

      truncate table t1:数据量大,删除速度比上一条快,且直接从0开始.

    6.完整性约束补充

      foreign key 外键 建立两张表之间的联系

      dep : 被关联表  主表

create table dep(
            id int primary key auto_increment,
            name vachar(20) not null,
            des varchar(30) not null
);
create table dep2(
            id int primary key auto_increment,
            name vachar(20) not null,
            des varchar(30) not null
);

      emp:关联表  从表

create table emp(
           eid int primary key auto_increment,
           name char(10) not null,
           age int not null,
           dep_id int not null,
           dep2_id int not null,
           constraint fk_dep foreign key(dep_id) references dep (id)
           on delete cascade # 同步删除
           on update cascade, #同步更新
           constraint fk_dep2 foreign key(dep2_id) references dep2 (id)
           on delete cascade # 同步删除
           on update cascade, #同步更新
);

    7.外键的变种.

      (1)先站在左表的角度 ,左表的多条记录对应右表的一条记录   成立

      (2)先站在右表的角度,右表的多条记录对应左表的一条记录   成立

      多对一 或者多对一,(1)和(2)条件 有一个成立

      多对多,(1)和(2)都成立,通过建立第三张表,来建立多对多的关系

      一对一,(1)和(2)都不成立,给一个表的fk的字段设置约束unique

      

      多对多:使用第三张表建立多对多的关系

create table book(
            id int primary key auto_increment,
            name varchar(20)
);
create table author(
            id int primary key auto_increment,
            name varchar(20)
);
create table auto_book(
            id int primary key auto_increment,
            book_id int not null,
            author_id int not mull,
            constraint fk_book foreign key(book_id) references book(id)
            on delete cascade
            on update cascade,
            constraint fk_author foreign key(author_id) references author(id)
            on delete cascade
            on update cascade
);
insert into book(name) values('九阳神功'),('九阴真经'),('九阴白骨爪'), ('独孤九剑'),('降龙十巴掌'),('葵花宝典');  
insert into autho_book(author_id,book_id) values
(1,1),
(1,2),
(1,3),
(1,4),
(1,5),
(1,6),
(2,1),
(2,6),
(3,4),
(3,5),
(3,6),
(4,1);     

    8.核心:数据驱动视图

      json -- server

  设计模式:    MVC  ===>MTV

      Model --View --Controller

十二.sql的查询

    1.单表查询

      (1),表单查询的语法 

      SELECT 字段1,字段2... FROM 表名
    WHERE 条件
    GROUP BY field
    HAVING 筛选
    ORDER BY field
    LIMIT 限制条数

      (2)关键字的执行优先级*

    from→where→group by→having→select→distinct→order by→limit

      1.找到表:from

      2.拿着where指定的约束条件,去文件/表中取出一条条记录

      >,<,>=,<=,!=

      between xxx and ooo

      and or not

      3.将取出的一条条记录进行分组group by,如果没有group by.则整体作为一组

      sql_mode = ONLY_FULL_GROUP_BY

      分组之后只能获取分组的字段,如果哦想获取组内的信息,需通过聚合函数

      聚合函数:count(1) 计算总个数 

           avg()  sum()  max()  min()

      4.将分组的结果进行having过滤

      二次筛选,having后面的字段只能是分组(group by)之后的字段

      5.执行select

      6.去重

      7.将结果按条件排序:order by

      asc升序   /    desc降序

      8.限制结果的显示条数

      limit 0,5    第一个参数起始位置,第二个参数显示的个数   

    2.多表查询

      外连接操作:select * from t1,t2 where t1_t2id = t2.id  

      内连接: 符合条件查询,只连接匹配的行

          select * from t1 inner join t2 on t1_t2id = t2.id

      左连接:优先显示左表记录

          select * from t1 left join t2 on t1_t2id = t2.id

      右连接:优先显示右表记录

          select * from t1 right join t2 on t1_t2id = t2.id

      全部连接

          select * from t1 left join t2 on t1_t2id = t2.id

              union

          select * from t1 right join t2 on t1_t2id = t2.id

    3.符合条件查询

       以内连接的方式查询employee和department表,并且employee表中的age字段值必须大于25,即找出年龄大于25岁的员工以及员工所在的部门

       select department.name,employee.name from employee inner join department on employee.dep_id = department.id where age > 25

    4.子查询

        子查询是将一个查询语句嵌套在另一个查询语句中;一个查询语句(内层)查询的结果作为另一个查询语句(外层)的条件

 

十三.pymysql的使用

  pip3 install mysql 安装mysql包

import pymysql
conn = pymysql.connect(
            host:'127.0.0.1',
            port:3306,
            database:'db1',
            user:'root',
            password:'',
            charset:'utf8'
);
cur = conn.cursor()
sql = 'select * from userinfo'
res = cur.execute(sql,()||[]||{})
cur.close()
conn.close()

  1.pymysql 增 删 改 一定要加commit()

  2.pymysql 查询

    fetchone()

    fetchmany(size)

    fetchall

十四.索引

  作用:约束+加速查询

    普通索引:create index ix_name on 表名(字段)

        作用:加速查询

    唯一索引:create unique index un_index_name on 表名(字段)

        作用:约束和加速查询

    主键索引: 加速查找和唯一约束(不含null)

     #覆盖索引:在索引文件中直接获取数据

          select name from data where name = 'liu10000';

    #索引合并:把多个单列索引一起使用

          select * from data where name = 'liu520' and id 520;

    #联合索引:联合普通索引

         联合唯一索引

         联合主键索引

    #最左前缀

      如果使用组合索引加上,name和email组合索引之后,查询

      (1)name和email ---使用索引

      (2)name             ---使用索引

      (3)email              ---不适用索引(字段太长)

      对于索引

          1.创建索引

              注意事项(优化):

                  (1)避免使用select*

                  (2)count(1)或count(列) 代替count(*)

                  (3)创建表时尽量使用char代替varchar

                  (4)表的字段顺序固定长度的字段优先

                  (5)组合索引代替代替多个单列索引(经常使用多个条件查询时)

                  (6)尽量使用短索引

                  (7)使用连接(join)来代替子查询

                  (8)连表时注意条件类型需一致

                  (9)索引散列(重复少)不适用于建索引,列如:性别不合适

          2.命中索引

          3.正确使用索引

           

 

 

 

 

 

 

 

    

posted @ 2018-08-09 21:30  不喜欢酸甜的刘青阳  阅读(263)  评论(0编辑  收藏  举报