|
目录
1、初识MySQL
1.1、为什么学习数据库
1.2、什么是数据库
1.3、数据库分类
1.4、MySQL简介
1.5、MySQL5.7安装(免安装版配置详细教程)
一、软件下载
二、操作步骤
1.6、连接数据库
2、操作数据库
2.1、操作数据库
2.2、数据库的列类型
1、初识MySQL
JavaEE: 企业级java开发 Web
前端(页面:展示,数据!)
后台(连接点:连接数据库JDBC ,连接前端(控制,控制视图跳转,和给前端传递数据))
数据库(存数据,Txt,Excel,word)
只会写代码,学好数据库,基本混饭吃;
操作系统,数据结构与算法!当一个不错的程序员
离散数学,数字电路,体系结构,编译原理。+实战经验,高级程序员~优秀的程序员
1.1、为什么学习数据库
1、岗位需求
2、现在的世界,大数据时代、得数据库者得天下。
3、被迫需求:存数据
4、数据库是所有软件体系中最核心的存在 DBA
1.2、什么是数据库
数据库(DB,DataBase)
概念:数据仓库 , 软件,安装在操作系统(window,linux,mac…)之上!SQL,可以存储大量的数据500万!
作用:存储数据、管理数据
1.3、数据库分类
关系型数据库:
- MySQL,Oracle,SqlServer,DE2,SQLlite
- 通过表和表之间,行和列之间的关系进行数据的存储,学员信息,考勤表,…
非关系型数据库: (NoSQL) Not Only
- Redis , MongDB
- 非关系型数据库,对象存储,通过对象自身的属性来决定
DBMS(数据库管理系统)
- 数据库的管理软件,科学有效的管理我们的数据。维护和获取数据。
- MySQL,数据管理系统!
1.4、MySQL简介
MySQL是一个关系型数据库管理系统
前世:瑞典MySQL AB 公司
今生:属于?Oracle?旗下产品
MySQL是最好的?RDBMS?(Relational Database Management System,关系数据库管理系统) 应用软件之一。
开源的数据库软件。
体积小、速度快、总体拥有成本低,招人成本比较低,所有人都必须会~
中小型网站、或者大型网站,集群!
官网
5.7稳
安装建议:
1、尽量不要使用exe、注册表
2.尽可能使用压缩包安装~
1.5、MySQL5.7安装(免安装版配置详细教程)
一、软件下载
MySql下载
二、操作步骤
1.下载后得到zip压缩包
2.解压到自己想要安装的目录,本人解压到的是:D:\WL1\Environment\mysql-5.7.17
3.添加环境变量
- 我的电脑—>属性–>高级—>环境变量
- 选择PATH,在其后面添加:你的mysql安装文件下面的bin文件夹
- 在D:\WL1\Environment\mysql-5.7.17下新建my.inl文件
- 编辑my.inl文件,注意替换路径位置
[mysqld]
basedir=D:\WL1\Environment\mysql-5.7.17
datadir=D:\WL1\Environment\mysql-5.7.17\data\
port=3306
skip-grant-tables
5.启动管理员模式下的CMD,并将路径切换至mysql下的bin目录,然后输入mysqld -install(安装mysql)
cd /d D:\WL1\Environment\mysql-5.7.17\bin
mysqld -install
6.再输入mysqld --initialize-insecure --user=mysql初始化数据文件
mysqld --initialize-insecure --user=mysql
7.然后再次启动mysql然后用命令mysql -uroot-p进入mysql管理界面(密码可为空)(-p后面不要有空格)
net start mysql
mysql -u -root -p
8.进入界面后更改root密码(sql语句后面一定要加分号!)
update mysql.user set authentication_string=password('123456') where user='root' and Host='localhost';
(最后输入 flush privileges;刷新权限)
flush privileges;
9.修改my.inl文件注掉最后一句skip-grant-tables(前面加#)?
10.重启mysql即可正常使用
net stop mysql
net start mysql
11.连接上测试出现以下结果就安装好了

1.6、连接数据库
命令行连接!
mysql -u root -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;--退出连接
-- 单行注释(SQL)
/*(sql的多行注释)
hello
asds
database
*/
数据库
DDL 定义
DML 操作
DQL 查询
DCL 控制
2、操作数据库
操作数据库>操作数据库中的表>操作数据库表中的数据
?mysql是不区分大小写的
2.1、操作数据库
- 创建数据库
CREATE DATABASE [IF NOT EXISTS]可选 SSM;
2.删除数据库
DROP DATABASE [IF EXISTS] SSM;
3.使用数据库?
-- tab 键上面,如果你的表名或者字段名是一个特殊字符,就需要带
use school;
SELECT `user` FROM student;
4、查看数据库
SHOW DATABASE --查看所有的数据库
2.2、数据库的列类型
数值
- tinyint 十分小的数据 1个字节
- smallint 较小的数据 2个字节
- mediumint 中等大小的数据 3个字节
- int 标准的整数 4个字节?常用的
- bigint 较大的数据 8个字节
- float 浮点数 4个字节
- double 浮点数 8个字节 (精度问题!)
- decimal 字符串形式的浮点数 金融计算的时候,一般是使用decimal
字符串
时间日期?
java.util.Date
null?
2.3、数据库的字段属性(重点)
?
Unsigned:
?
zerofill
- 0填充的
- 不足的位数,使用0来填充, int(3),5 — 005
自增
- 通常理解为自增,自动在上一条记录的基础上+1(默认)
- 通常用来设置唯一的主键~ index下标 ,必须是整数类型
- 可以自定义设置主键的起始值和步长
?
非空?NULL not null
- 假设设置为not null ,如果不给它赋值,就会报错!
- NULL,如果不填写值,默认就是null!
默认:
- 设置默认的值!
- sex,默认为男 如果不指定该列的值,则会有默认的值!
?
扩展:
/*每一个表,都必须存在一下的数据 未来做项目用的 ,表示一个记录存在的意义*/
id 主键
·version· 乐观锁
is_delete 伪删除
gmt_create 创建时间
gmt_update 修改时间
-- 目标 : 创建一个school数据库
-- 创建学生表(列,字段)
-- 学号int(4) 姓名(30)默认匿名,登录密码varchar(20)默认123456 性别varchar(2)默认女,出生日期(datatime)默认空,家庭住址默认空,email默认空
-- 创建表之前 , 一定要先选择数据库
-- 注意点:使用英文(),表的名称 和 字段尽量使用 `` 括起来
-- AUTO_INCREMENT 自增
-- 字符串使用 单引号括起来
-- 所有的语句后面加 , (英文的) 最后一个不用加
-- PRIMAY KEY 主键,一般一个表只有一个唯一的主键
CREATE TABLE IF NOT EXISTS student (
`id` INT(4) NOT NULL 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(20) DEFAULT NULL COMMENT '家庭住址',
`email` VARCHAR(20) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
)ENGINE=INNODB DEFAULT charset=utf8
格式?
CREATE TABLE [IF NOT EXISTS] `表名`(
`字段名` 列类型 [属性] [索引] [注释],
`字段名` 列类型 [属性] [索引] [注释],
……
`字段名` 列类型 [属性] [索引] [注释]
)[表类型] [字符集] [注释]
常用命令
SHOW CREATE DATABASE school -- 查看创建数据库的语句
SHOW CREATE TABLE student -- 查看student数据表的定义语句
DESC student -- 查看表的具体结构
?
?
?
?
?
?
?
?
?
?
-
- char 字符串固定大小的 0~255
- varchar 可变字符串 0~65535?常用的 String
- tinytext 微型文本 2^8-1
- text 文本串 2^16-1?保存大文本
- date YYYY-MM-DD, 日期
- time HH:mm:ss 时间格式
- datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式
- **timestramp 时间戳, 1970.1.1到现在的毫秒数!**也较为常用
- year 年份表示
- 没有值,未知
- 注意 ,不要使用NULL进行运算,结果为NULL
|