1.MySQL开始基础

1. MySQL

javaee : 企业级java开发 web

前端(页面:渲染 展示 数据)

后台(连接点 : 连接数据库jdbc,链接前端(控制视图跳转,给前端传递数据))

数据库(存数据 : txt ,Word ,Excel )

只会写代码,学号数据库,基本混饭吃

操作系统,数据结构与算法!!!学会这些就很nice了

离散数学,数字电路,体系结构,编译原理----就很牛逼了已经+实战经验==高级程序员

1.1 为什么学习数据库

1.岗位需求

2.大数据时代`人人都会 得数据着得天下

3.被迫需求,存数据

4.数据可是所有软件的体系最核心的存在 DBA

1.2什么是数据库

数据库 (DB, DteBase)

概念 : 数据仓库,软件,安装在操作系统上面(Linux) SQL是一个操作系统语句,可以存储大量语句500w

作用:存数据,管理数据(类似于Excel)

1.3 数据库分类 DBSM(数据库管理系统)

**关系数据库:(SQL)

+ MySQL Oracle aqlserver 

​ 通过表和表之间,航和列直接的关系进行数据的存储,学员信息表

非关系型数据库:

​ Redis mongdb

== DBMS数据库管理系统 ==

  • 数据库的管理软件,科学有效的管理数据
  • MySQL 数据库管理

1.4MySQL

MySQL是一个关系型数据库管理系统

前世:瑞典MySQL AB公司

今生:属于Oracle旗下产品

MySQL是最好用的关系新数据库管理系统

中小型网站

安装MySQL

官网 : https://www.mysql.com/

安装MySQL

这里建议大家使用压缩版,安装快,方便.不复杂.

软件下载
mysql5.7 64位下载地址:
https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.19-winx64.zip
电脑是64位的就下载使用64位版本的!

安装步骤

1、下载后得到zip压缩包.
2、解压到自己想要安装到的目录,本人解压到的是D:\Environment\mysql-5.7.19
3、添加环境变量:我的电脑->属性->高级->环境变量
选择PATH,在其后面添加: 你的mysql 安装文件下面的bin文件夹
4、编辑 my.ini 文件 ,注意替换路径位置
[mysqld] basedir=D:\Program Files\mysql-5.7\ datadir=D:\Program Files\mysql-5.7\data\ port=3306 skip-grant-tables
5、启动管理员模式下的CMD,并将路径切换至mysql下的bin目录,然后输入mysqld –install (安装mysql)
6、再输入 mysqld --initialize-insecure --user=mysql 初始化数据文件
7、然后再次启动mysql 然后用命令 mysql –u root –p 进入mysql管理界面(密码可为空)
8、进入界面后更改root密码
update mysql.user set authentication_string=password(‘123456’) where user='root’and Host = ‘localhost’;
9、刷新权限
flush privileges;
10、修改 my.ini文件删除最后一句skip-grant-tables
11、重启mysql即可正常使用
net stop mysql net start mysql
12、连接上测试出现以下结果就安装好了

一步步去做 , 理论上是没有任何问题的 .
如果您以前装过,现在需要重装,一定要将环境清理干净 .
好了,到这里大家都装好了,因为刚接触,所以我们先不学习命令.
这里给大家推荐一个工具 : SQLyog .
即便有了可视化工具,可是基本的DOS命名大家还是要记住!

SQLyog

SQLyog下载

链接: https://pan.baidu.com/s/1D_iRna8V90omfHsKHyeBtg 提取码: bqht 复制这段内容后打开百度网盘手机App,操作更方便哦

可手动操作,管理MySQL数据库的软件工具
特点 : 简洁 , 易用 , 图形化

使用SQLyog管理工具自己完成以下操作 :

连接本地MySQL数据库

新建MySchool数据库

1.7 连接数据库

命令行连接

cd /dD:\MySQL\mysql-5.7.19\bin  --连接数据库

mysql -uroot -p --进入数据库

update mysql.user set authentication_string =password('123456')where user='root' and Host = 'localhost';

flush privileges; ----刷新权限
-- ---------------------------------------------------------

-- 所有语句都是用;号结尾

show databases;-- 查看数据库
mysql> use school  -- 切换数据库 use 数据库名
Database changed
 
 -- 
show tables; -- 查看数据库中所有的表

describe student; -- 显示数据库中所有的表的信息

create database westos; -- 创建一个数据库

exit;  --退出连接

/*注释*/
-- 
# 123

2 .操作数据库

操作数据库—>操作数据库中的表–>操作数据库中的表的数据

2.1操作数据库

  1. 创建数据库

    CREATE DATABASE 数据库名;
    CREATE DATABASE IF NOT EXISTS 数据库名 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;-- 先会判断是否存在这个数据库名,后面是编码集为utf8,数据库排序规则是utf8_general_ci
    
    
  2. 删除数据库

    DROP DATABASE [IF EXISTS] 数据库名;
    
  3. 使用数据库

    USE `数据库名`
    
  4. 查看数据库

    SHOW DATABASES -- 查看所有的数据库
    

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-44263p5O-1616596431643)(C:\Users\86155\AppData\Roaming\Typora\typora-user-images\1615816830046.png)]

思路:

  • 对比:SQLyog可视化历史记录查看sql

  • 固定的语法或者关键字必须记住

2.2数据库的数据类型

数值

  • tinyint 十分小的内存 一个字节

  • smallint 较小的数据 两个字节

  • int 标准的整数 四个字节 常用

  • mediumint 中等大小数据 三个字节

  • bigint 较大的数据 八个字节

  • float 单精度浮点 四个字节

  • double 双进度浮点 八个字节

  • decimal 字符串浮点数 金融计算的时候一般使用

字符串

  • char 字符串固定大小 0-255
  • varchar 可变字符串 0-65535 (16位2进制的数字)
  • tinytext 微型文本 2^8-1
  • text 文本串 2^16-1

时间日期

java.util.Date

  • date YYYY-MM-DD ,日期格式
  • time HH:mm: ss 时间格式
  • datetime YYYY-MM-DD HH: mm: ss
  • timestamp 时间戳 1970.1.1----现在的毫秒数
  • year 年份表示

null

  • 没有值
  • 不要使用null运算,结果一定为null

2.3数据库的字段属性(重点)

Unsigned:

  • 无符号的整数
  • 声明了该列不能声明为负数

zerofill

  • 0填充
  • 不足的位数使用0填充 int(3) ,5 — 005

自增

  • 统常理解为自增,自动在上一条记录基础上+1
  • 统常来设计唯一的逐渐`index,必须是整数类型
  • 可以自定义设计主键自增的起始值和步长

非NULL not null

  • x新建表格的时候如果给 “非空”(not null)打钩,如果不给他赋值就会报错
  • null 如果不填写就是默认null

默认

  • 设置默认的值!
  • sex 默认为男 如果不指定就是默认值代替

数据字段属性

UnSigned

  • 无符号的
  • 声明该数据列不允许负数 .

ZEROFILL

  • 0填充的
  • 不足位数的用0来填充 , 如int(3),5则为005

Auto_InCrement

  • 自动增长的 , 每添加一条数据 , 自动在上一个记录数上加 1(默认)

  • 通常用于设置主键 , 且为整数类型

  • 可定义起始值和步长

    • 当前表设置步长(AUTO_INCREMENT=100) : 只影响当前表
    • SET @@auto_increment_increment=5 ; 影响所有使用自增的表(全局)

NULL 和 NOT NULL

  • 默认为NULL , 即没有插入该列的数值
  • 如果设置为NOT NULL , 则该列必须有值

DEFAULT

  • 默认的
  • 用于设置默认值
  • 例如,性别字段,默认为"男" , 否则为 “女” ; 若无指定该列的值 , 则默认值为"男"的值

`-- 目标 : 创建一个school数据库-- 创建学生表(列,字段)-- 学号int 登录密码varchar(20) 姓名,性别varchar(2),出生日期(datatime),家庭住址,email-- 创建表之前 , 一定要先选择数据库


CREATE TABLE IF NOT EXISTS `student` (
	`id` int(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
	`name` varchar(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
	`pwd` varchar(20) NOT NULL DEFAULT '123456' COMMENT '密码',
	`sex` varchar(2) NOT NULL DEFAULT '男' COMMENT '性别',
	`birthday` datetime DEFAULT NULL COMMENT '生日',
	`address` varchar(100) DEFAULT NULL COMMENT '地址',
	`email` varchar(50) DEFAULT NULL COMMENT '邮箱',
	PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8
-- 查看数据库的定义SHOW CREATE DATABASE school;-- 查看数据表的定义SHOW CREATE TABLE student;-- 显示表结构DESC student;  -- 设置严格检查模式(不能容错了)SET sql_mode='STRICT_TRANS_TABLES';

数据表的类型

设置数据表的类型

CREATE TABLE 表名(   -- 省略一些代码   -- Mysql注释   -- 1. # 单行注释   -- 2. /*...*/ 多行注释)ENGINE = MyISAM (or InnoDB)-- 查看mysql所支持的引擎类型 (表类型)SHOW ENGINES;

MySQL的数据表的类型 : MyISAM , InnoDB , HEAP , BOB , CSV等…

常见的 MyISAM 与 InnoDB 类型:

图片

经验 ( 适用场合 ) :

  • 适用 MyISAM : 节约空间及相应速度
  • 适用 InnoDB : 安全性 , 事务处理及多用户操作数据表

数据表的存储位置

  • MySQL数据表以文件方式存放在磁盘中

    • 包括表文件 , 数据文件 , 以及数据库的选项文件
    • 位置 : Mysql安装目录\data\下存放数据表 . 目录名对应数据库名 , 该目录下文件名对应数据表 .
  • 注意 :

    • * . frm – 表结构定义文件

    • * . MYD – 数据文件 ( data )

    • * . MYI – 索引文件 ( index )

    • InnoDB类型数据表只有一个 *.frm文件 , 以及上一级目录的ibdata1文件

    • MyISAM类型数据表对应三个文件 :

      图片

设置数据表字符集

我们可为数据库,数据表,数据列设定不同的字符集,设定方法 :

  • 创建时通过命令来设置 , 如 : CREATE TABLE 表名()CHARSET = utf8;
  • 如无设定 , 则根据MySQL数据库配置文件 my.ini 中的参数设定

修改数据库

修改表 ( ALTER TABLE )

修改表名 :ALTER TABLE 旧表名 RENAME AS 新表名

添加字段 : ALTER TABLE 表名 ADD字段名 列属性[属性]

修改字段 :

  • ALTER TABLE 表名 MODIFY 字段名 列类型[属性]
  • ALTER TABLE 表名 CHANGE 旧字段名 新字段名 列属性[属性]

删除字段 : ALTER TABLE 表名 DROP 字段名

删除数据表

语法:DROP TABLE [IF EXISTS] 表名

  • IF EXISTS为可选 , 判断是否存在该数据表
  • 如删除不存在的数据表会抛出错误

其他

1. 可用反引号(`)为标识符(库名、表名、字段名、索引、别名)包裹,以避免与关键字重名!中文也可以作为标识符!
2. 每个库目录存在一个保存当前数据库的选项文件db.opt

3. 注释:  单行注释 # 注释内容  多行注释 /* 注释内容 */  单行注释 -- 注释内容       (标准SQL注释风格,要求双破折号后加一空格符(空格、TAB、换行等))   
4. 模式通配符:  _   任意单个字符  %   任意多个字符,甚至包括零字符  单引号需要进行转义 \'   5. CMD命令行内的语句结束符可以为 ";", "\G", "\g",仅影响显示结果。其他地方还是用分号结束。delimiter 可修改当前对话的语句结束符。
6. SQL对大小写不敏感 (关键字)7. 清除已有语句:\c
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值