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 在集合中匹配,匹配到了为真
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容