03-Mysql-part01[学习笔记]

1 - 数据库的常见概念

  • 数据:Data

  • 数据库:DataBase(DB) 在硬盘上以文件的形式存在

  • 数据管理员:DataBase Administrator(DBA)

  • 数据库管理系统:DataBase Management System(DBMS)

    常见的有:MySQL Oracle DB2 Sybase SqlServer

                              DBMS负责执行sql语句 通过执行sql语句来操作DB中的数据
    
  • 数据库系统:DataBase System(DBS)

  • MySQL:数据库

2 - SQL语言

1.DQL(数据查询语言):查询语句 凡是select语句都是DQL

2.DML(数据操作语言):insert delete update 对表当中的语句进行增删改

3.DDL(数据定义语言):creat drop alter 对表结构进行增删改

4.TCL(事务控制语言):commit 提交事务 rollback回滚事务 (T代表Transation)

5.DCL(数据控制语言) :grant 授权 revoke 撤销权限等

数据库存在的意义就是为了做持久化存储

3 - 数据库基本操作

3.1 - 连接数据库

语法:mysql -h 主机名/IP地址 -u 用户名 -p 密码 [数据库名]

-- 连接MySQL但是不指定使用的数据库
mysql -u root -p
-- 连接MySQL的同时指定要使用的数据库
mysql -u root -p 数据库名
-- 连接MySQL的时候指定主机名
mysql -h localhost -u root -p
-- 连接MySQL的时候指定IP地址
mysql -h 127.0.0.1 -u root -p
-- 一步完成数据库的连接
mysql -uroot -ptoor

3.2 - mysql基本操作

  • 通常情况下命令都需要以分号结束
  • 可以将一条命令在任意一个可以插入空格的位置拆分成多行,当遇到分号的时候结束当前的这条命令
  • 可以通过 \c 来取消一条命令的执行
  • 帮助信息查看:\hhelp?
  • 查看当前数据库服务器的状态 \s
  • 将查询的结果纵向显示 \G
  • 退出MySQL的方法:exitquit\q
  • ctrl+C强行终止

3.3 - 常用mysql命令

1.查看有哪些数据库

show databases (这个不是SQL语句 属于MySQL命令)换成Oracle就不能用了

注意每一个语句后面都要有分号!!!!!!

2.创建属于自己的数据库

create database 数据库名(这个不是SQL语句 属于MySQL命令)

3.使用自己创建的数据库

use ddgenius(这个不是SQL语句 属于MySQL命令)

4.查看当前数据库中有哪些表

show tables;

5.初始化数据

mysql > source + 文件路径(C:\Users\My\Desktop\资料汇总\F.java\java开发\MySQL数据库\bjpowernode.sql)

可以直接把文件拖过来(太大的命令记事本可能打不开)

6.删除数据库:drop database bjpowernode

4 - 数据表基本操作

4.1 - 介绍

  • 数据表就是数据库中最基本的对象(Java 里就是用类对象来表示一个数据表的结构)单元

  • 每一条数据记录:行

  • 每个字段记录:列

  • 设计表之前需要根据数据的对应实体和属性找到对应的关系(联系) - E-R图

    • 实体:你想针对什么具体的事物来创建一个数据表
    • 属性:该事物具备的属性,在数据表里面用字段来表示

    EX:学生是实体,学号,姓名,性别,年龄,成绩...等等都是学生这个实体具备的属性(字段)

  • 数据类型:数据表中的属性具备适当的数据类型,尽量避免数据的冗余(时优空优)

4.2 - 四大数据类型

1 - 数字

类型名 空间(字节) 描述
tinyint 1 非常小的整数类型
smallint 2 比较小的整数类型
mediumint 3 中等大小的整数类型
int 4 标准的整数类型
bigint 8 大整数类型
float 4 ~ 8 单精度浮点型
double 8 双精度浮点型
decimal 自定义 以字符串形式显示浮点数

整型后面的括号:表示的是显示的位数,并不是存储的位数,比如 int(3),表示的是以3个长度来显示一个整数,如果这个数据的实际位数大于了这个括号中的值,则会截取括号中指定的位数进行显示,超出部分不会显示在结果中

浮点型后面的小括号:float(6,2)表示的是以六位的数字显示一个数值,其中小数点后保留两位,显示位数当中小数点不算作一位,比如:1234.56 就符合以上的条件(浮点数中会四舍五入),存储也按照小括号里面的约束

2 - 字符串类型

类型名 空间(字节) 描述
char[(M)] M 不可变长字符串
varchar[(M)] length + 1 可变长字符串
tinyblob / tinytext length + 1 小二进制和文本串
blob / text length + 2 小二进制和文本串
mediumblob / mediumtext length + 3 中二进制和文本串
longblob / longtext length + 4 大二进制和文本串
enum 1 / 2 枚举
set 1 / 2 / 3 / 4 / 8 集合

char和varchar怎么选择?

    在实际的开发中,当某个字段中的数据长度不发生改变的时候,是定长的,例如:性别、生日等都是采用char。

    当一个字段的数据长度不确定,例如:简介、姓名等都是采用varchar。(自动化分配空间,底层有if语句)

3 - 时间和日期

基本不用:时间戳代替

类型名 空间(字节) 描述
date 3 YYYY-MM-DD
time 3 hh:mm:ss
datetime 8 YYYY-MM-DD hh:mm:ss
timestamp 4 YYYYMMDDhhmmss
year 1 YYYY

4 - NULL值

  • NULL 不意味着没有值也不意味着未知值
  • 在 MySQL 中可以检测到某一条数据的某一个字段值是否为 NULL
  • 不能对 NULL 进行算术运算,对 NULL 进行算术运算得到的结果还是 NULL
  • 在 MySQL 当中 0 和 NULL 都可以作为 false 的另外一种表现形式,其他的值都是 true

4.3 - 创建数据表

create table 表名(

        字段名1 数据类型,

        字段名2 数据类型,

        字段名3 数据类型,

        ....

    );
create table t_student(
            no bigint,
            name varchar(255),
            sex char(1),
            classno varchar(255),
            birth char(10)
        );

varchar是可变长!!必须给长度

可以使用default添加默认值

sex char(1) default 1,//默认值1

表的复制

create table 表名 as select语句;

    将查询结果当做表创建出来。

4.4 - 删除数据表

drop table 数据表名
drop table if exists t_student; // 当这个表存在的话删除。

4.5 - 运算符

  • AND 或 && 逻辑与
  • OR 或者 || 逻辑或
  • NOT 或者 ! 逻辑非
  • XOR 或者 ^ 逻辑异或
  • = 判断是否相等,相等为真
  • <=> 是否相等,相等为真,可用于NULL(不推荐)
  • != 或 <> 不等于为真,(<>不推荐)
  • < > <= >= 基本的关系运算符
  • is null 空为真
  • is not null 非空为真
  • between and 从哪儿到哪儿之间
  • not between and 不在从哪儿到哪儿之间
  • like 匹配字符串,匹配到结果为真(长得像什么一样)
  • not like 匹配字符串,没有匹配到为真(张的不想什么一样)
  • in 在集合中匹配,匹配到了为真
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容