数据库1.v

Day26 MySQL

  1. 软件安装
    遇到安装问题 度娘。
    1 检查是否安装(安装就卸载,未安装就安装,保证版本一致)
    2 Navicat安装
    3 测试
  2. MySQL
    数据库:解决了不同操作系统之间,数据格式的兼容性问题。同一个数据库的数据文件,即使是从Windows迁移到了Linux上,也可以正常处理的
    1.3关系型和非关系型的区别
    关系型数据库查询来数据,得到对象,而非关系型数据库,保存键值对 查询处理数据,得到数组

1.4数据库分类

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不同的表中。使用sql语言
数据库对象
表,视图,函数,存储过程,索引等

表中具有几个概念:列、行、主键。 列叫做字段(Column),行叫做表中的记录,每一个字段都有:字段名称/字段数据类型/字段约束/字段长度
视图
我们可以理解为一张虚表(它在物理磁盘上并不真实存在)。视图是基于select语句查询生成的结果集。当一条select语句比较复杂而且调用的频率也比较高时,我们不想再写一遍语句,这时候可以把这条select语句创建为一个视图。每次使用视图的时候,就可以把它当成一张表来用。
函数
通常是一个功能的实现,我们大部分使用的是系统函数(MYSQL提供的),我们也可以自定义函数。它的调用套路通过使用select 函数名(参数1,参数2…);来调用。它只有一个返回值。
存储过程
也是一个功能的实现。我们所说的数据库编程,SQL语句编程,就主要是指自定义一个存储过程。调用存储过程是使用exec 存储过程名 参数1等来调用。它是可以返回多个值,也可以没有返回值。
索引
我们之前接触过,它就像一本书的目录一样,是为了加快我们查询速度而建立的。

4.SQL的分类
数据查询语言(DQL-Data Query Language)
代表关键字:select
数据操纵语言(DML-Data Manipulation Language)
代表关键字:insert,delete,update
数据定义语言(DDL-Data Definition Language)
代表关键字:create ,drop,alter,
事务控制语言(TCL-Transactional Control Language)
代表关键字:commit ,rollback;
数据控制语言(DCL-Data Control Language)
代表关键字:grant,revoke.
5.1 TCL–用户创建和授权

1、创建用户:CREATE USER ‘username’@‘host’ IDENTIFIED BY ‘password’;
需要切换到mysql数据库下,操作user表
username:用户名;host:指定在哪个主机上可以登录,本机可用localhost,%通配所有远程主机;password:用户登录密码;
2、授权:GRANT ALL PRIVILEGES ON . TO ‘username’@’%’ IDENTIFIED BY ‘password’ ;
刷新权限:FLUSH PRIVILEGES;
格式:grant 权限 on 数据库名.表名 to 用户@登录主机 identified by “用户密码”;*.*代表所有数据库和所有表;
Select 查询
Insert 插入数据
Update 更新数据
Delete 删除数据
Drop 删除表
Create 创建表
5.2 DDL–数据库创建
数据库创建和删除
在当前数据库服务器上创建一个新库
create database day01;
在当前数据库服务器上删除一个库
drop database day01;

查看当前链接的MySQL版本

select version();

查看所有的数据库

show databases;

输出指定内容 as 是设置内容的列名,as也可以省略

select ‘xxxxx’ as 列名;

创建数据库

create database day_01;

切换数据库

use day_01;

查看该数据库下所有表,一般会和 use 一起使用,

show tables;

删除数据库

drop database day_01;

5.3 DDL–表创建和删除
在数据库day01下创建表student_info
use day01;
create table student_info (
id int,
name varchar(20),
salary decimal(18,2)
)ENGINE = innodb default charset = utf8;

查看建表语句

show create table t_student;

再次创建 如果表已经有了,就会报错

需求 如果有了这个表,就不创建,不报错

加上 if not exists 可以防止语句出错,如果这个表存在就不创建

create table if not exists t_student(
id int,
name varchar(20)
);

存储引擎 :
MyISAM
InnoDB

– 在数据库day01下删除表student_info
use day01;
drop table student_info;
6.DML操作
DML : Data Manipulate Language(数据操作语言) ,主要用于向数据库插入,修改,删除数据使用
涉及的关键字有 : insert delete update
Insert (用于向表中添加数据):
格式 :
insert into 表名 (列名1,列名2) values (值1,值2);
示例 :
insert into teacher (name, id, salary) values (‘老刘’,1,56.23);
Delete(用于删除表中的数据):
格式 :
delete from 表名 where 列名 = 值;
示例 :
delete from teacher where name=‘老王’;可以把符合where条件的记录全部删除。一定要加where条件,否则会删除全表的数据。
delete from teacher where id is null也可以起到上面的作用,判断为null 不能使用 = ,is null 为空 is not null 不为空。
Update(用于更新表中的数据):
格式 :
update 表名 set 列名1=值 , 列名2=值 where 列名 = 值;
示例 :
update teacher set salary=9999.45, name=‘dave’ where id = 1;
会将符合where条件的所有记录对应的字段都更新为新值
Select(用于查询表中的数据,属于DQL):
格式 :
select 列限定 from 表限定 where 行限定
示例 :
select * from teacher where id= 1;
查询teacher表中id为1 所有信息
select * from teacher;
查询teacher表中的所有信息
select name from teacher where id= 1;
查询teacher表中 id为1 的name值

注意:无论是delete还是update,只要你确定不是全表操作,就一定要使用where条件!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值