zoukankan      html  css  js  c++  java
  • Mysql基础笔记


    Mysql 是广泛使用的其中一种常见的关系型数据库

    安装与配置

    Mysql本体安装:

    1. 进入官网点击"Dowload"
    2. 根据需求下载对应版本,注意路径中避免出现中文。
      1. 免安装版Mysql安装步骤
      2. 安装版Mysql安装步骤

    Navcat安装:
    3. 安装Mysql的可视化工具Navicat,毕竟纯命令敲打虽然很牛,但还是挺麻烦的。


    SQL基础

    SQL语句分类

    DDL(Data Definition Languages):

    数据定义语言,这些语句定义了不同的数据段、数据库、表、列、索引、等数据库对象。

    数据库:

    1、创建数据库
     	create database 库名;
    2、展示所有的数据库
     	show databases;
    3、进入数据库
     	use 库名;
    4、展示数据表
     	show tables;
    5、删除数据库
     	drop database 库名;
    

    表:

    1、创建表
     	create table 表名 (字段名1 类型1 , ... , 字段名n 类型n );
    2、删除表
     	drop table 表名;
    3、修改表名
     	alter table 旧表名 rename 新表名;
    4、展示表结构
     	desc 表名;
    5、展示创表的语句
     	show create table 表名;
    

    字段:

    1、增加表字段
     	alter table 表名 add column 字段名 类型;
    2、删除表字段
     	alter table 表名 drop column 字段名;
    3、修改字段名
     	alter table 表名 change 字段原名 字段新名 新字段类型;
    4、修改字段类型
     	alter table 表名 modify 字段名 新类型;
    

    注意:在Mysql8.0之前,DDL是不支持事务回滚的,会将之前的输入过的不管是DML还是什么的都自动提交了。
    这是因为内存空间有限,DDL是修改数据字典,而且通常不会有长时间的DDL执行。数据库自动提交有助于控制数据字典的内存占用,把更多的空间留给DML。

    DML(Data Manipulation Languages):

    数据操控语句,用于添加、删除、更新和查询数据库记录,并检查数据完整性。

    插入( insert into ):

    -- 必须要插入所有的字段
     	insert into 表 values(值1,值2,值n);
    -- 选择字段插入
     	insert into 表 (字段1,字段n) values (值1,值n);
    

    删除( delete ):

    -- 根据条件删除(当然也可以不加 where 条件)
     	delete from 表名 where 条件;
    -- 清空表数据
     	truncate table 表名;
    

    修改( update ):

    -- 修改条件中的多个字段值
     	update 表名 set 字段1=值1,字段n=值n where 条件;
    

    查询( selete ):

    -- 表中查找所有指定字段数据
     	select 字段(*) from 表;
     	
    -- 去重查询
     	select distinct 字段 from 表;
     	
    -- 根据指定条件从表中查找字段数据
     	select 字段 from 表 where 条件;
     	
    -- 排序查询(默认升序asc)
     	select 字段 from 表 order by 字段 升降序;
     	
    -- 多字段排序查询
     	select 字段 from 表 order by 字段1 asc,字段2 desc;
     	
    -- 结果集限制显示多少条数据
     	select 字段 from 表 limit 数量;
     	
    -- 从哪里开始查多少条内容
     	select 字段 from 表 limit 偏移量,偏移后截取数;
     	
    -- 按字段分组查询
     	selete 字段 from 表 group by 字段;
     	
    -- 根据条件按字段分组查询(与 where 筛选不同,having是对于结果对象进行筛选)
     	selete 字段 form 表 group by 字段 having 条件;
    

    多表查询:

    -- 内连接(将两个表中存在的连结关系的字段又符合连结关系的记录的联结)
    
     select 表1.字段, 表n.字段 from 表1,表n where 等值连接条件;
    
     select 表1.字段, 表n.字段 from 表1 inner join 表n on 等值连接条件;
    
    
    -- 外连接(会选出其他不匹配的记录)
    -- 1、左连接
     	select * from 表1 left join 表n on 等值连接条件;
    -- 2、右连接
     	select * from 表1 right join 表n on 等值连接;
    -- 3、全外链接
     	select * from 表1 union join 表n on 等值连接条件;
     	
     
    -- 子查询(进行查询时需要嵌套查询另外一个select语句的结果)
        select* from 表1 where 表1.字段 in (select 表n.字段 from 表n);
        -- 用于子查询的关键字包括in、not in、=、!=、 exists、not exists等
    
    
    -- 记录联合(将结果合并到一起显示)
        SELECT * FROM 表1 UNION SELECT * FROM 表n
        SELECT * FROM 表1 UNION ALL SELECT * FROM 表n
    

    注意

    • UNION ALL 区别是把结果集合并在一起,而 UNION是将 UNION ALL后的结果进行一次 DISTINCT,去重记录后的结果
    DCL(Data Control languages):

    数据控制语句,用于控制不同数据段直接的许可和访问级别的语句,这些语句定义了数据库、表、字段、用户的访问权限和安全级别。

    -- 创建用户并赋予权限:
     	grant 权限 on 库.表(*) to '用户'@'主机' identified by '密码';
    -- 删除用户权限:
     	revoke 权限 on 库.表(*) from '用户'@'主机';
    
    -- 备份
     	mysqldump -u 用名 -p 密码 表名1 表名n > d:data.sql
    -- 恢复
     	mysqldump -u 用名 -p 密码 表名1 表名n < d:data.sql
    

    注意:在权限处写 all 说明全部权限,主机若为%,任何来源的主机均可用这个用户访问)


    字段类型分类

    1. 数值型
    数据类型 所占字节 值范围
    tinyint 1字节 -128~127
    smallint 2字节 -32768~32767
    mediumint 3字节 -8388608~8388607
    int 4字节 范围-2147483648~2147483647
    bigint 8字节 +-9.22*10的18次方
    数据类型 所占字节 值范围
    float(m, d) 4字节 单精度浮点型,m总个数,d小数位
    double(m, d) 8字节 双精度浮点型,m总个数,d小数位
    decimal(m, d) - decimal是存储为字符串的浮点数
    2. 字符型
    数据类型 所占字节 值范围
    CHAR 0-255字节 定长字符串
    VARCHAR 0-255字节 变长字符串
    TINYBLOB 0-255字节 不超过255个字符的二进制字符串
    TINYTEXT 0-255字节 短文本字符串
    BLOB 0-65535字节 二进制形式的长文本数据
    TEXT 0-65535字节 长文本数据
    MEDIUMBLOB 0-16 777
    MEDIUMTEXT 0-16 777
    LOGNGBLOB 0-4 294
    LONGTEXT 0-4 294
    VARBINARY(M) 允许长度0-M个字节的定长字节符串 值的长度+1个字节
    BINARY(M) M 允许长度0-M个字节的定长字节符串
    3. 日期型
    数据类型 所占字节 值范围
    date 3字节 日期,格式:2014-09-18
    time 3字节 时间,格式:08:42:30
    datetime 8字节 日期时间,格式:2014-09-18 08:42:30
    timestamp 4字节 自动存储记录修改的时间
    year 1字节 年份
    4. 复合型
    数据类型 所占字节 值范围
    ENUM 1-255个成员:1字节;256-65535个成员:2字节 存储预先定义好的字符串列表,插入和更新必须使用列表中的值,如果插入值不在列表中,则插入空串
    SET 1-8个成员:1字节;9-16个成员:2字节;17-24个成员:3字节;25-32个成员:4字节;33-64个成员:8字节 存储预先定义好的字符串列表,字段值可为集合中任意成员值。SET不按索引存储,而是以位图方式存储

    变量

    1. 会话变量

    定义形式:

    set @变量名 = 值;

    说明:

    1. 跟php类似,第一次给其赋值,就算定义了
    2. 它可以在编程环境和非编程环境中使用!
    3. 使用的任何场合也都带该”@”符号。
    2. 普通变量

    定义形式:

    declare 变量名 类型 【default 默认值】;

    设置值:

    set 变量名 = 值;

    说明:

    1. 它必须先声明(即定义),此时也可以赋值;
    2. 它只能在编程环境(即存储过程,函数,触发器这样的)中使用;
    3. 变量赋值形式

    语法一:(此语法中的变量必须先使用declare声明)

    set 变量名 = 表达式;

    语法二:

    set @变量名=表达式;

    语法三:

    select @变量名:=表达式;

    此语句会给该变量赋值,同时还会作为一个select语句输出’结果集’

    语法四:

    select 表达式 into @变量名;

    虽然看起来是select语句,但其实并不输出“结果集”,而是给变量赋值。

    常用运算符

    1. 算术运算符

    +、-、*、/、%

    注意:mysql没有 ++ 和 -- 运算符

    2. 关系运算符

    >、>=、<、<=、=(等于)、<>(不等于)!=(不等于)

    3. 逻辑运算符

    and(与)、or(或)、not(非)

    mysql常用函数

    1. 字符串函数
    函数 描述
    CONCAT(S1,S1,...Sn) 连接S1....为一个字符串
    INSERT(str,x,y,instr) 将字符串str从x位置开始,y个字符长的子串替换为字符串instr
    LOWER(str) 将字符串str中的所有字符变为小写
    UPPER(str) ...大写...
    LEFT(str,x) 返回字符串str最左边的x个字符
    RIGHT(str,x) ...右边...
    LPAD(str,n,pad) 用字符串pad对str最左边进行填充,知道长度为n个字符长度。
    RPAD(str,n,pad) ...右边...
    LTRIM(str) 去掉字符串str左侧的空格
    RTRIM(str) ...右侧...
    TRIM(str) 去掉字符串行尾和行头的空格
    REPEAT(str,x) 返回str重复x次的结果
    REPLACE(str,a,b) 用字符串b替换字符串str中所出现的字符串a
    STRCMP(s1,s2) 比较字符串s1和s2
    SUBSTRING(str,x,y) 返回从字符串str x位置起y个字符串长度的字串
    2. 数值函数
    函数 描述
    ABS(x) 返回x的绝对值
    CEIL(x) 返回大于x的最小整数值
    FLOOR(x) 返回小于X的最大整数值
    MOD(x,y) 返回x/y的模 #求余数
    RAND() 返回0~1的随机值
    ROUND(x,y) 返回参数x的四舍五入的有y位小数的值
    TRUNCATE(x,y) 返回数字x截断为y位小数的结果
    3.日期和时间函数
    函数 描述
    CURDATE() 返回当期日期
    CURTIME() 返回当前时间
    NOW() 返回当前的日期和时间
    UNIX_TIMESTAME(date) 返回日期date的UNIX时间戳
    FROM_UNIXTIME 返回UNIX时间戳的日期值
    WEEK(date) 返回日期date为一年中的第几周
    YEAR(date) 返回日期date的年份
    HOUR(time) 返回time的小时值
    MINUTE(time) 返回time的分钟值
    MONTHNAME(date) 返回date的月份
    DATE_FORMAT(date,fmt) 返回按字符串fmt格式化日期date值
    DATE_ADD(date,INTERVAL expr type) 返回一个日期或时间值加上一个时间间隔的时间值
    DATEDIFF(expr,expr2) 返回起始时间expr和结束时间expe2之间的天数
    4.流程函数
    函数 描述
    IF(value,t f) 如果value是真,返回t;否则返回f
    IFNULL(value1,value2) 如果value1不为空,返回value1,飞则返回value2
    CASE WHEN[value1] THEN[result1]...ELSE[default]END 如果value1是真,返回resul1,否为返回default
    CASE [expr] WHEN [value1] THEN[result1]... ELSE[default]END 如果expr等于value1,返回result1,否则发挥default
    5.其他常用函数
    函数 描述
    DATABASE() 返回当前数据库名
    VERSION() 返回当前数据库版本
    UESR() 返回当前登录用户名
    INET_ATON(IP) 返回IP地址的数字表示
    INET_NTOA(num) 返回数字代表的IP地址
    PASSSWORD(str) 返回字符串str的加密版本
    MD5() 返回字符串str的MD5值
    6. 其他循环编程
    • loop循环
    • while循环
    • repeat循环

    数据库功能

    视图

    视图可以看成数据库中一张虚拟表,方便用户只对某些表中的某些字段进行操作。

    视图的特点

    • 视图的数据并不是另外保存的,而是属于表里的,并能像表一样进行增删改查;
    • 视图不能被更改,表修改或删除后应该删除视图重建;
    • 视图数量没有限制,但命名不能和其他视图和表名重复,具有唯一性;
    • 视图可以被嵌套;
    • 视图不能索引,不能有相关联的触发器;

    视图的好处

    • 使操作简单:
      为复杂且使用频繁的操作定义一个视图,简化查询的步骤
    • 增加数据的安全性:
      用户只能查询和修改指定显示出来的数据,保证敏感信息不会被看到
    • 提高表的独立性:
      可以屏蔽原有表结构变化所带来的影响,即使是增删了列,对视图也不会造成影响

    视图的操作

    1. 创建视图:

    create view 视图名 as 查询语句

    1. 修改视图:

    create or replace view 视图名 as 查询语句

    1. 删除视图:

    drop view 视图名

    1. 使用视图:

    select * from 视图名

    存储过程

    存储过程是一组为了完成特定功能的SQL语句集,相当于封装的方法。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。

    存储过程的好处:
    • 存储过程创建后可以在程序中多次调用执行,不必重新编写该sql语句;
    • 存储过程能够实现较快的执行速度,因为存储过程只在创造时进行编译,不必重新编译该sql语句,也就是预编译;
    • 存储过程能减轻网络流量,客户机调用存储过程时,网络中传递的只是调用语句;
    • 存储过程可被作为一种安全机制来利用,进行权限限制,从而对数据访问的限制;
    存储过程的操作:
    1. 创建存储过程:
     	create procedure 存储过程名(参数列表) 
     	Begin
    	    存储过程内容
     	End
    

    形参列表:

    • IN —— 代表输入参数(如果没有注明, 参数默认的类型为 in)
    • OUT —— 输出参数,不管有没有传值里面都是null
    • INOUT —— 既可以做为输入参数,也可以做为输出参数
    • MySQL 存储过程名字后面的“()”是必须的,即使没有一个参数,也需要“()”
    1. 调用存储过程:

    call 存储过程名称(实参列表)

    1. 删除存储过程:

    drop procedure 存储过程名称

    触发器

    触发器是一个特殊的存储过程,它是由事件触发而执行的某个被动操作,例如insert、update、delete的时候,就会自动执行该代码块,从而让表具有联动关系或保持更新数据。

    触发器的要点

    • 在指定的数据库事件发生时自动执行;
    • 触发器必须定义在特定的表上;
    • 当触发器关联的表删除时,自动删除触发器;
    • 自动执行,不能直接调用;

    触发器的好处

    • 相对于外部程序、存储过程,触发器能更快更高效的维护数据

    触发器的操作

    1. 创建触发器:
    create trigger 触发器名 before/after 事件 on 表名 for each row 
    Begin
        (执行语句)
    End
    
    1. 删除触发器:

    drop trigger 触发器名;

    1. 查看触发器

    show triggers;


  • 相关阅读:
    第三篇——第二部分——第三文 配置SQL Server镜像——域环境
    DOS命令学习(从入门到精通)
    Cocos2d-x3.0 LoadingBar
    微信对接HIS——微信可查检验结果
    微信iOS SDK文档总结
    Azure编程笔记(4):配置Cloud Service的证书
    android的ViewPager和Animation的一些使用(一)
    小虾米的鳄鱼梦
    Hadoop源码分析21:namenode概要
    Hadoop源码分析20:datanode概要
  • 原文地址:https://www.cnblogs.com/zohnn/p/14044043.html
Copyright © 2011-2022 走看看