Mysql入门

什么是关系型数据,什么是非关系型数据库?

关系型数据库是一种使用表、行和列来组织和存储数据的数据库系统。它们遵循结构化查询语言(SQL)标准,数据以表格形式存储,并支持事务处理和复杂查询。

非关系型数据库(NoSQL数据库)则是一种不使用传统表格关系型结构来存储数据的数据库系统。它们能够处理大量非结构化和半结构化数据,并具有分布式计算和数据存储能力。NoSQL数据库通常用于大规模Web应用程序、大数据处理和实时数据分析等场景。

常见的关系型数据库:

  1. MySQL:一个开源的关系数据库管理系统,广泛用于各种网站应用。

  2. PostgreSQL:一种功能强大的开源对象关系数据库管理系统,支持复杂的查询和事务处理。

  3. Oracle Database:一种功能强大的商业关系数据库管理系统,被广泛用于企业级应用。

  4. SQL Server:微软开发的商业关系数据库管理系统,用于Windows操作系统。

  5. SQLite:一个轻量级的嵌入式关系数据库引擎,适用于移动应用和小型项目。

  6. IBM Db2:IBM开发的商业关系数据库管理系统,用于企业级应用和数据仓库。

  7. MariaDB:一个由MySQL原创开发者创建的分支版本,兼容MySQL并加入了一些新功能。

  8. Amazon RDS:亚马逊云服务提供的关系数据库管理服务,支持多种数据库引擎如MySQL、PostgreSQL等

  常见的非关系型数据库包括MongoDB、Cassandra、Redis等。

Sql语言有那些分类

        什么是sql?

SQL是结构化查询语言(Structured Query Language)的缩写,是用于管理关系型数据库的标准化查询语言。SQL可以用来查询数据库中的数据、插入、更新和删除数据、创建和删除数据库对象(如表、视图、存储过程等)等操作。通过SQL,用户可以通过简单的语句访问和操作数据库,是数据库管理系统中不可或缺的重要组成部分

关系型数据库他们都遵循结构化查询语言(SQL)标准,使用SQL语言来操作数据库

        Sql语言有那些分类

  1. 数据定义语言(DDL):用于定义数据库对象如表、视图和索引等的语言。包括CREATE(创建)、ALTER(修改)、DROP(删除)等关键字。

  2. 数据操作语言(DML):用于对数据库中的数据进行操作的语言。包括SELECT(查询)、INSERT(插入)、UPDATE(更新)、DELETE(删除)等关键字。

  3. 数据控制语言(DCL):用于控制数据库的访问权限和数据完整性的语言。包括GRANT(授权)、REVOKE(撤销权限)等关键字。

  4. 数据查询语言(DQL):用于查询数据库中的数据的语言。主要是SELECT关键字。

除了以上分类外,还有一些其他类型的SQL语言,如事务控制语言(TCL)、嵌入式SQL、动态SQL等。这些语言都是为了更好地操作和管理数据库而设计的。

注意:所以后面我们都是使用Sql语言来操作Mysql数据库

什么是Mysql?

MySQL是一个开源的关系型数据库管理系统,最初由瑞典的MySQL AB公司开发。目前由Oracle公司开发和维护。MySQL是一种基于客户端-服务器模式工作的数据库管理系统,主要用于在Web应用程序中存储数据。MySQL支持多个操作系统,包括Windows、Linux、macOS等。

MySQL具有以下特点:

  1. 开源免费:MySQL是开源软件,用户可以免费使用和修改。
  2. 高性能:MySQL可以处理大量数据,并且具有高性能和高可靠性。
  3. 支持多种存储引擎:MySQL支持多种存储引擎,如InnoDB、MyISAM等,用户可以根据需求选择不同的存储引擎。
  4. 支持事务:MySQL支持事务处理,保证了数据处理的一致性和完整性。
  5. 支持SQL:MySQL使用标准的SQL语言,易于学习和使用。

总的来说,MySQL是一个功能强大、稳定可靠、易于使用的数据库管理系统,广泛应用于各种Web应用程序中。

安装和使用Mysql

   数据在数据库中的存储方式

    在windows中安装mysql

   下载mysql安装文件:MySQL安装程序下载

下载成功后就点击文件安装就好了,具体过程可以自己在网上搜一下教程

linux中安装Mysql

可以查看这篇文章,很详细

Linux安装Mysql(超详细,亲测)-CSDN博客

SQL基础概念

终端操作

登录

简写-- 登录本地MySQL服务, -u 指定⽤户名, -p: 使⽤密码登录

mysql -u root -p

完整写法 :

mysql -h ip地址 -P 端口号 -u 用户名 -p 密码

登录远程 :

mysql -h 10.211.55.5 -u root -p

切换数据库

USE database_name;

显示所有表 

show tables;

显示所有的数据库

show databases;

退出

quit 

数据库相关操作

创建数据库

CREATE DATABASE IF NOT EXISTS game    -- 指定数据库名为game DEFAULT CHARACTER SET utf8mb4                              -- 指定数据库字符集为utf8mb4

COLLATE utf8mb4_0900_ai_ci;                        -- 指定排序规则

  • uft8mb4 表示使⽤UTF-8编码,每个字符最多占4个Byte。
  • 0900 是UNICODE 校对算法版本。
  • ai(Accent Insensitive)表示⼝⾳不敏感,排序时不区分e,è,é,ê和ë,不 区分重⾳。
  • ci(Case Insensitive)表示不区分⼤⼩写,排序时不区分a和A。 

上⾯的语句等价于:

CREATE DATABASE game;

MySQL8.0以后默认字符集为utf8mb4,默认排序规则为utf8mb4_0900_ai_ci

删除数据库

DROP DATABASE game;

表相关的操作

创建表:

create table test  (

        id int,

        name varchar(20),

        age int

)        

CREATE TABLE player ( 
  id int DEFAULT NULL,                               
  name varchar(45) DEFAULT NULL, 
  level int DEFAULT NULL, 
  exp int DEFAULT NULL, 
  gold decimal(10,2) DEFAULT NULL 
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; 

修改表:

 

删除表

DROP TABLE test

修改密码及允许远程登录 

修改root⽤户密码

-- 【5.7.9以下版本】修改root⽤户密码为123456:

方式1:    UPDATE user SET password=PASSWORD("123456") WHERE user=root;

方式2:UPDATE user SET authentication_string=PASSWORD("123456") WHERE user=‘root’;

FLUSH PRIVILEGES; -- 刷新权限

-- 【5.7.9以上版本】修改root⽤户密码为123456:

ALTER user 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';

FLUSH PRIVILEGES; -- 刷新权限

修改root⽤户允许远程登录

UPDATE user SET host='%'  WHERE user='root' AND host='localhost'; 

FLUSH PRIVILEGES;  -- 刷新权限

配置⽂件my.cnf中的 bind-address 也需要改成 0.0.0.0

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

smilehjl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值