MySQL开篇:简单的库操作,表操作,数据类型

news2024/11/28 0:32:00

在这里插入图片描述博客主页: 心荣~
系列专栏:【MySQL】
一句短话: 难在坚持,贵在坚持,成在坚持!

文章目录

  • 一. 什么是MySQL
  • 二. 基础库操作
    • 1. 创建数据库
    • 2. 查看所有数据库
    • 3. 选中数据库
    • 4. 删除数据库
  • 三. 设置数据库的编码字符集
  • 四. MySQL数据类型
    • 1. 数值类型
    • 2. 字符串类型
    • 3. 日期数据类型
  • 五. 基础表操作
    • 1. 创建表
    • 2. 查看库中有哪些表
    • 3. 查看表结构
    • 4. 删除表

一. 什么是MySQL

MySQL是一种数据库,数据库其实是"基于数据结构"实现出来的软件, 可以对数据进行有组织的存储和管理;

MySQL是一种关系型数据库, 对于数据的存储, 在格式上有严格的要求(以类似于execl表格的方式来存储); 而SQL是编程语言, SQL可以在MySQL等数据库软件上运行;

MySQL是一个客户端, 服务器结构的软件, 我们安装好MySQL, 其实已经把客户端和服务器都安装好了; 我们所使用的MySQL的命令行输入页面就相当于一个客户端,客户端是用来完成和用户交互的, 而服务器是存储数据的本体; 数据存储在服务器主机的硬盘上.

img

img

  • 主动发送数据的这一方为客户端(client).

  • 被动接收数据的这一方为服务器(server).

  • 客户端给服务器发送的数据叫做请求(request).

  • 服务器给客户端返回的数据叫做响应(response).

  • 客户端和服务器之间是通过网络来进行通信的.

  • 一个服务器可以同时给多个客户端提供服务.

MySQL中的代码不区分大小写, 也就是是说关键字大写和小写都可以.

二. 基础库操作

1. 创建数据库

语法:

create database 数据库名;

注意:

数据库名不能是sql中的关键字, 如果非要使用, 需要将关键字用反引号引起来关键字.

示例:

img

  • 为了防止所建的数据库已经存在导致报错, 可以加上if not exists来解决.

img

加上if not exists在建库时如果库存在也不会报错, 避免了sql语句批量执行时由于这一句报错而中断了后面的执行.

  • 在建库时还可以指定字符集.

img

MySQL的utf8编码不是真正的utf8,没有包含某些复杂的中文字符; 在MySQL中真正的utf8是utf8mb4 .

2. 查看所有数据库

语法:

show databases;

示例:

img

3. 选中数据库

在对一个数据库中的数据进行crud等操作前需要先选中指定的一个数据库.

语法:

user 数据库名;

示例:

img

4. 删除数据库

语法:

drop database 数据库名;

示例:

img

三. 设置数据库的编码字符集

MySQL默认的编码字符集是gbk和latin1,这两种字符集是不支持中文的, 需要我们去将这两种字符集修改为utf8或者utf8mb4.

在数据库客户端中我们可以通过show variables like "%char%";来查询当前MySQL默认编码格式。

mysql> show variables like "%char%";
+--------------------------+---------------------------------------------------------+
| Variable_name            | Value                                                   |
+--------------------------+---------------------------------------------------------+
| character_set_client     | gbk                                                     |
| character_set_connection | gbk                                                     |
| character_set_database   | latin1                                                  |
| character_set_filesystem | binary                                                  |
| character_set_results    | gbk                                                     |
| character_set_server     | latin1                                                  |
| character_set_system     | utf8                                                    |
| character_sets_dir       | C:\Program Files\MySQL\MySQL Server 5.7\share\charsets\ |
+--------------------------+---------------------------------------------------------+
8 rows in set, 1 warning (0.01 sec)

如果执行结果是上面这个样子就需要去配置文件中去修改字符集了.

可以通过Everything等工具快速找到MySQL的配置文件my.ini.

img

打开该文件, 找到如下图所示的两个字段修改为utf8或utf8mb4, 修改前要注意备份, 防止修改错搞坏数据库.

  • 设置mysql客户端默认字符集

img

  • 设置mysql服务端默认字符集

img

修改完保存, 重启数据库服务器即可;

img

修改完后的效果:

img

四. MySQL数据类型

sql中定义变量时,变量名在前,类型在后.

1. 数值类型

数据类型内存大小(字节)说明对应java数据类型对应c数据类型
BIT(M)M指定位数,默认为1单个二进制位值,或者为0或者为1,主要用于开/关标志(M范围从1到64, 存储数值范围从0到2个M-1)Booleantrue/false
TINYINT11字节整数值,支持0~255的整数Batychar
SMALLINT22字节整数值,支持−32768~32767的整数Shortshort
INT44字节整数值,支持−2147483648~2147483647的数Integerint
BIGINT8整数值,支持-9223372036854775808~9223372036854775807的数Longlong
FLOAT(M, D)4单精度浮点值,M指定长度,D指定小数位数。会发生精度丢失Floatfloat
DOUBLE(M,D)8双精度浮点值, M指定长度,D指定小数位数。会发生精度丢失Doubledouble
DECIMAL(M,D)M/D+2定点或精度可变的浮点值,M指定长度,D表示小数点位数; 精确数值BigDecimal
NUMERIC(M, D)M/D最大 值+2和DECIMAL一样BigDecimal

数值类型可以指定为无符号(unsigned),表示不取负数.

2. 字符串类型

数据类型大小说明对应java数据类型
VARCHAR (SIZE)0-65,535字节可变长度字符串String
TEXT0-65,535字节长文本数据String
MEDIUMTEXT0-16 777 215字节中等长度文本数据String
BLOB0-65,535字节二进制形式的长文本数据byte[]

sql中的字符串值可以用单引号也可以用双引号.

3. 日期数据类型

数据类型大小说明对应java数据类型
DATETIME8 字 节范围从1000到9999年,不会进行时区的 检索及转换。java.util.Date、 java.sql.Timestamp
TIMESTAMP4 字 节范围从1970到2038年,自动检索当前时 区并进行转换。java.util.Date、 java.sql.Timestamp

存储格式 : 'yyyy-mm-dd hh:mm:ss'

五. 基础表操作

注意 : 需要操作数据库中的表时,要先选中该数据库

1. 创建表

语法:

create table 表名(定义列1, 定义列2, .......);-> 变量名 数据类型

示例:

设计一张图书表,包含以下字段:图书名称,图书作者、图书价格、图书分类

img

2. 查看库中有哪些表

语法:

show tables;

示例:

img

3. 查看表结构

语法:

desc 表名;

示例:

img

4. 删除表

语法:

drop table 表名;

示例:

img

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/3829.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

_Linux 动态库

文章目录0. 前言1. 生成动态库1.1 我们把静态库和动态库打包1.2 当动静库同时存在的时候默认生成的是动态库1.3 -static2. 动态库的使用2.1 运行动态库的方法3. 库文件名称和引入库的名称0. 前言 链接:静态库文章 上一章我们讲解了静态库的生成和两种使用&#xff…

Netty架构设计

目录 Selector模型 SelectableChannel Channel注册到Selector SelectionKey 遍历SelectionKey 事件驱动 责任链模式 Selector模型 Java NIO是基于Selector模型来实现非阻塞IO,Netty底层基于Java NIO实现的,因此也使用了Selector模型。 Selector提…

Go语言五大主流web框架

以下 star数截止2022年11月份 1.Gin(64.1K) 项目简介:Gin 是一个用 Go (Golang) 编写的 HTTP Web 框架。 它具有类似 Martini 的 API,但性能比 Martini 快 40 倍。 仓库地址:https://github.com/gin-gonic/ginhttps…

TensorRt安装和命令行测试

1、选择TensorRt版本 安装tensorrt前,需要先了解自己的显卡算力、架构等,点击 算力列表链接 对号入座。 这里仅展示RTX和Titan系列,其他系列可在当前网页选择。 1.1、cuda版本 首先需要安装cuda,其版本并不是最新就好&#xf…

基于SSM跨境电商网站的设计与实现/海外购物平台的设计

通过对跨境电商网站的编写,使得自己对于javaweb技术和数据库理论有了更深的认识。课题设计javaweb,能够学习网页编程知识。此课题设计的知识有HTML,CSS和MVC模式等。还跟javaScript的知识有关。在不断的学习过程中提高自己的编程能力。本跨境…

TCP/IP网络参考模型

目录 TCP/IP四/五层模型 应用层常见协议——传输数据PDU 传输层协议——传输数据段 端口号 TCP面向连接服务 UDP无面向连接服务 网络层协议——传输数据包 IP协议 数据链路层——传输数据帧 Ethernet帧格式 IEEE802.3帧格式 TCP/IP四/五层模型 标准定义的TCP/IP模型…

使用idea自动开发springMVC程序及表单标签

1.新建项目 选择Spring—>SpringMVC——>Download 点击next,起好项目名称project name,我这里项目名是MVCTag,选择好项目的路径project location,然后点击确定就会自动加载SpringMVC所需要的全部jar包 项目新建完成&…

【Spring5】基于注解的Bean管理简直是Spring中的Spring

文章目录1 什么是注解2 基于注解方式实现对象的创建3 组件扫描配置的细节4 基于注解实现属性的注入4.1 几种注解概述4.2 Autowire注解演示4.3 Qualifier注解演示4.4 Value注解演示5 纯注解的开发模式写在最后1 什么是注解 注解是代码中特殊的标记,格式如下&#xf…

Latex论文排版

O、部分参考: https://blog.csdn.net/qq_41982200/article/details/123051883?spm1001.2014.3001.5506 https://blog.csdn.net/qq_27353621/article/details/127170340 一、基础知识 1、空一行 → 分一段 空很多行也只是分一段 2、加粗、斜体 3、新章节 4…

JAVA学习笔记(二)

JAVA学习笔记 包1.1基本使用 2.2包的命名 2.3常用的包 2.4使用细节 访问修饰符面向对象 3.1面向对象三大特征 封装、继承、多态 3.2封装介绍 3.3封装的理解和好处 3.4封装的实现步骤 3.5构造器和setXXX结合 3.6继承(细节) 3.7super基本用法 3.8super给…

Kotlin基础学习笔记之第六章——kotlin的类型系统

一、本章简介 与java相比,kotlin中引入了一些新特性,他们是提升代码可读性的基本要素,比如:对可空的类型和只读集合的支持。与此同时,kotlin去掉了一些java类型系统中不必要的或者有问题的特性,比如把数组作…

docker安装mysql同步数据到linux与docker容器卷

可以去dockerhub搜索mysql寻找命令 docker run -p 3310:3306 --name mysql57 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/datadir:/var/lib/mysql -e MYSQL_ROOT_PASSWORD123456 -d mysql:5.7 -e配置启动容器mysql 需要配置密码 -v 是绑定容器卷到linux 上 …

阿里二面,前端开发在web3.0中该如何应用,答完面试官对我笑了笑

近期听说周星驰也开始招募web3.0的人才了,可见其火爆程度真是不一般啊,不得不说的是,这又是一场新的革命,必将带来腥风血雨。 对于前端开发来说,很多人可能刚刚准备学习,刚刚入门,刚刚在企业中找…

目标检测(4)—— 经典算法和常用指标

一、深度学习的经典算法 two-stage(两阶段):RCNNone-stage(一阶段):YOLO,SSD(这个好像很牛) one-stage: 将图片输入到CNN里,经过特征提取&#…

rabbitMQ:绑定Exchange发送和接收消息(topic)

topic交换机和fanout交换机类似,也是广播机制,但是topic需要绑定RoutingKey,绑定RoutingKey时可以使用通配符(*,#)代替。 *:只能一个单词 #:0个或多个单词 编写topic消息发送类 1.编写Recei…

区块链的认识

目录 频繁的交易如何记录这些交易信息呢? 那我们的链又是如何连接起来的? 谁做记账先生呢? 共识机制 如何处理有些人距离账目的公共太远的问题? 安全性: 去中心化: 总结: 频繁的交易如何记录…

云原生k8s的盘古开天辟地

背景 容器(docker)流行开来,容器调度机制风起云涌,各路神仙用systemctl调度, 也有号称容器宗师的出品docker swarm, 各大门派也有各自的旗帜主张。天下混沌,血雨腥风,龙藏深泉,而谷歌的k8s就是这个主角。 …

较低成本的ISO7637-2 5A 5B抛负载保护方案

科普下什么是抛负载,抛负载测试方案以及后端电路参数的选择。 在众多汽车电子电磁兼容测试中,最具破坏性的就是ISO7637-2的5A 5B测试了,当然也有的测试项目放在ISO16750标准中,但测试波形大体相同。上海雷卯有专门的文章描述这2个…

基于JavaWeb的手机商城系统设计与实现

目录 摘要 I Abstract II 第1章 绪论 1 1.1 课题背景 1 1.2 目的和意义 1 1.3 系统设计思想 3 1.4 本文的结构 3 第2章 可行性分析 4 2.1 业务流程图 4 2.2 经济可行性 6 2.3 技术可行性 6 2.4 运行可行性 6 2.5 本章小结 7 第3章 需求分析 8 3.1 关于电商的前世今生和目前发展…

C++基础知识梳理<2>(引用、内联函数、auto关键字) [入门级】

目录 一、引用 1. 引用概念 2. 引用特性 2.1 引用在定义时必须初始化 2.2 一个变量可以有多个引用 2.3 引用一旦引用一个实体,再不能引用其他实体 3. 常引用 3.1 取别名的规则 3.2 权限放大error 3.3 权限不变 3.4 权限缩小 4. 引用原理与拓展 4.1…