MYSQL

MYSQL,第1张

MYSQL

目录

1、初识MySQL

1.1、为什么学习数据

1.2、什么是数据

1.3、数据库分类

1.4、MySQL简介

1.5、MySQL5.7安装(免安装版配置详细教程)

一、软件下载

二、 *** 作步骤

1.6、连接数据库

2、 *** 作数据库

2.1、 *** 作数据库

2.2、数据库的列类型

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

2.4、数据表类型

2.5、修改删除表


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:WL1Environmentmysql-5.7.17

3.添加环境变量

  1. 我的电脑—>属性–>高级—>环境变量
  2. 选择PATH,在其后面添加:你的mysql安装文件下面的bin文件夹
  3. 在D:WL1Environmentmysql-5.7.17下新建my.inl文件
  4. 编辑my.inl文件,注意替换路径位置
[mysqld]
basedir=D:WL1Environmentmysql-5.7.17
datadir=D:WL1Environmentmysql-5.7.17data
port=3306
skip-grant-tables

5.启动管理员模式下的CMD,并将路径切换至mysql下的bin目录,然后输入mysqld -install(安装mysql)

cd /d D:WL1Environmentmysql-5.7.17bin
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)
 

数据库

DDL 定义

DML *** 作

DQL 查询

DCL 控制

2、 *** 作数据库

*** 作数据库> *** 作数据库中的表> *** 作数据库表中的数据

 mysql是不区分大小写的

2.1、 *** 作数据库
  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

字符串

  • char 字符串固定大小的 0~255
  • varchar 可变字符串 0~65535 常用的 String
  • 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 最常用的时间格式
  • **timestramp 时间戳, 1970.1.1到现在的毫秒数!**也较为常用
  • year 年份表示

null 

  • 没有值,未知
  • 注意 ,不要使用NULL进行运算,结果为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  -- 查看表的具体结构
2.4、数据表类型
-- 关于数据库的引擎

 

常规使用 *** 作:

  • MYISAM 节约空间,速度较快
  • INNODB 安全性高,事务的处理,多表多用户 *** 作

在物理空间存在的位置

所有的数据库文件都存在data目录下,一个文件夹就对应一个数据库

本质还是文件的存储!

MySQL引擎在物理文件上的区别

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

  • 包括表文件 , 数据文件 , 以及数据库的选项文件

  • 位置 : Mysql安装目录data下存放数据表 . 目录名对应数据库名 , 该目录下文件名对应数据表.

注意 :

  • InnoDB类型数据表只有一个 *.frm文件 , 以及上一级目录的ibdata1文件
  • MyISAM类型数据表对应三个文件 :
    • * . frm – 表结构定义文件
    • * . MYD – 数据文件 ( data )
    • * . MYI – 索引文件 ( index )

 

设置数据库表的字符集编码

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

  • 创建时通过命令来设置 , 如 : CREATE TABLE 表名()CHARSET = utf8;

  • 如无设定 , 则根据MySQL数据库配置文件 my.ini 中的参数设定

charset-set-server=utf8
#不建议这么使用 
2.5、修改删除表
修改

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

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

修改字段 :

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

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

-- 修改表名 ALTER TABLE 旧表名 RENAME AS 新表名
ALTER TABLE teacher RENAME AS teacher1
-- 增加表的字段 ALTER TABLE `表名` ADD `字段名` 列属性 
ALTER TABLE `teacher1` ADD `age` INT(11) NOT NULL DEFAULT '12' COMMENT '年龄'

-- 修改表的字段  (重命名,修改约束)
-- ALTER TABLE 表名 MODIFY 字段名 列类型[属性]
ALTER TABLE `teacher1` MODIFY `age` VARCHAr(100)  -- 修改约束
-- ALTER TABLE 表名 CHANGE 旧字段名 新字段名 列属性[属性]
ALTER TABLE `teacher1` CHANGE `age` `age1`  INT(11)  -- 字段重命名


-- 删除表的字段 ALTER TABLE 表名 DROP 字段名
ALTER TABLE `teacher1` DROP `age1`

删除

 

语法: DROP TABLE [IF EXISTS] 表名

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

1. 可用反引号(`)为标识符(库名、表名、字段名、索引、别名)包裹,以避免与关键字重名!中文 也可以作为标识符! 

2. 每个库目录存在一个保存当前数据库的选项文件db.opt。 

3. 注释: 单行注释 # 注释内容 多行注释 单行注释 -- 注释内容 (标准SQL注释风格,要求双破折号后加一空格符(空格、TAB、 换行等)) 

4. 模式通配符: _ 任意单个字符 % 任意多个字符,甚至包括零字符 单引号需要进行转义 ' 

5. CMD命令行内的语句结束符可以为 ";", "G", "g",仅影响显示结果。其他地方还是用分号结 束。delimiter 可修改当前对话的语句结束符。 

6. SQL对大小写不敏感 (关键字)

7. 清除已有语句:c
 

 

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5637543.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存