初始MYSQL数据库(1)——创建、删除数据库和数据表的相关操作

news2024/11/14 15:23:43

找往期文章包括但不限于本期文章中不懂的知识点:

个人主页:我要学编程(ಥ_ಥ)-CSDN博客

所属专栏: MYSQL

目录

数据库的概念

数据库的相关操作

常用的数据类型 

数值型 

字符串类型

日期类型

数据表的相关操作

练习


数据库的概念

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。我们也可以将数据存储在文件中,但是在文件中读写数据速度相对较慢。因此,为了高性能的处理数据,便诞生了数据库。

数据库也分为两种:一种是关系型数据库,另一种是非关系型数据库。顾名思义:关系型数据库,肯定是数据与数据之间建立的一定的关联、关系。

关系型数据库的概念:是指采用了关系模型来组织数据的数据库。简单来说,关系模型指的就是二维表格模型,而一个关系型数据库就是由二维表及其之间的联系所组成的一个数据组织。

常见的关系型数据库有:MYSQL、Oracle、SQL Server。

既然有了数据库,那么肯定也要有操作数据库的东西或者说是工具——SQL语句。

数据库的相关操作

1、创建数据库

语法: 

CREATE DATABASE 数据库名;

在创建数据库时,我们也可以去指定其对应的字符集和排序规则,在上述代码后面直接加上:

CHARACTER SET 字符集编码 collate 排序规则;

-- 这个是SQL语句中的注释写法
-- 字符集编码在8.0版本中采用的是:utf8mb4
-- 排序规则在8.0版本中采用的是:utf8mb4_0900_ai_ci

 注意:如果有一个数据库之后,我们再去创建一个同名的数据库时,就会报错。因此,我们在创建数据库时,要加上一些校验:

有两种不同形式的校验:

(1)不管存不存在先删除它,再去创建它:(由于删除暂时未学,我们待会再学习)

(2)在创建之前,我们先去检验一下这个数据库是否存在:

CREATE DATABASE IF NOT EXISTS 数据库名;

注意:在SQL语法中建议是全部大写,但是小写也是没关系的,看个人的习惯吧。

既然有创建数据库,那么肯定也有删除数据库。

2、删除数据库 

语法:

DROP DATABASE 数据库名;

同样我们删除的数据库可能是不存在的,如果不存在的话,就会报错。因此也得加上校验。

DROP DATABASE IF EXISTS 数据库名;

其实在删除之前,我们完全可以进行一次查看操作。如果有,再删除也不迟。

SHOW DATABASES;

这里查看的是本级的所有数据库。 

因此,上面创建数据库的校验可以这样写:

-- 先是直接删除
DROP DATABASE IF EXISTS 数据库名;
-- 再去创建即可(这里不需要进行检验了,因为不可能存在要创建的数据库名)
CREATE DATABASE 数据库名;

 我们现在就可以在命令行中进行操作。

下面是打开数据库的操作,输入:mysql -uroot -p ,然后再输入密码即可

创建数据库——>查看数据库——删除数据库 

可能有小伙伴会好奇:为什么在SQL语句中大小写都可以,究其原因还是因为字符集编码和排序的的问题。utf8mb4 这个字符集是支持中文的,但是在5.0的版本中却是不支持的,因为其字符集为Latin1。排序规则中是支持大小写、口音不敏感。

常用的数据类型 

数值型 

数据类型大小说明对应Java中的类型
BIT [ (M) ]M为指定的位数,默认情况下是1因为BIT只能是0~8,因此M的范围也是有限的。M【1,64】常用Boolean来对应BIT,此时默认是1位,即只能存1和0
TINYINT1字节Byte
SMALLINT2字节Short
INT4字节Integer
BIGINT8字节Long
FLOAT(M, D)4字节单精度,M指定总长度,D指定小数位长度。会发生精度丢失Float
DOUBLE(M, D)8字节双精度,其余与FLOAT一样Double
DECIMAL(M, D)依赖于M和D的值双精度,M指定总长度,D表示小数点位数。不会发生精确数值BigDecimal
NUMERIC(M, D)依赖于M和D的值和DECIMAL一样BigDecimal

注意:由于FLOAT和DOUBLE在表示精度方面有缺失,因此涉及到钱相关的计算时,都是用DECIMAL来代替,也就是说这个DECIMAL是用来表示金额的。 

字符串类型

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

注意:

1、我们常用的也就是VARCHAR和TEXT两种类型;

2、VARCHAR() 中的SIZE是指字符串的长度,也就是字符的个数,并不是字节的个数;

3、BLOB中存储的是文本的二进制,因此是一个byte[ ]数组。

日期类型

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

java.util.Date、

java.sql.Timestamp

这里的日期会精确到小时-分钟-秒。

数据表的相关操作

一个数据库服务是能够支持多个数据库的,而一个数据库中是有多个数据表的,而一个数据表中又是有多个数据记录(数据行)的,一个数据记录(数据行)是由若干个列组成的。

因此我们操作数据库,最终操作的还是数据表中的数据行。因此下面我们就来学习数据表的相关操作。创建数据表等都是要在一个具体的数据库中进行的,即先得使用具体的数据库。

1、使用数据库

USE 数据库; --注意这里分号可有可无,建议带上

当然如果我们不确定是否使用了这个数据库的话,还可以进行查看当前选择的数据库

SELECT DATABASE(); -- 这里就会查询到我们使用的数据库

2、创建、查看与删除数据表 

(1)创建数据表:

这里直接采用校验的写法:

DROP TABLE IF EXISTS 表名;
CREATE TABLE 表名 (
    column1 datatype, 
    column2 datatype,
    ...
);

这里的column是指表中的字段(属性)。例如,我们现在创建一个学生表,那么这个学生表中就有一下字段(属性):学号、姓名、年龄、性别......后面的datatype是指这些字段(属性)对应的数据类型。比如,学号对应的就是整型、姓名对应的字符串型、年龄同样对应整型、性别既可以是整型,也可以是字符串型。 

当然也可以使用comment增加字段说明,在数据类型的后面。

(2)查看数据表:

查看数据表主要是观察其表的结构:

DESC 表名;

下面是查看结果:

(3)删除数据表

DROP TABLE IF EXISTS 表名;

 学习了这些语法之后,我们就来进行实操。

练习

有一个商店的数据,记录客户及购物情况,有以下三个表组成: 

1、商品goods(商品编号goods_id,商品名goods_name,单价unitprice,商品类别category,供
应商provider)
2、客户customer(客户号customer_id,姓名name,住址address,邮箱email,性别sex,身份证
card_id)
3、购买purchase(购买订单号order_id,客户号customer_id,商品号goods_id,购买数量nums)

思路:首先,得单独创建一个存储商店数据的数据库,然后再去创建相应的数据表。

代码实现:

-- 创建一个商店数据库
DROP DATABASE IF EXISTS shop;
CREATE DATABASE shop;
-- 创建三个表
-- 因为这是新建的数据库,其中不会存在表,因此无需做检查
USE shop;

-- 商品表
CREATE TABLE goods (
    goods_id bigint comment '商品编号',
    goods_name varchar(50) comment '商品名',
    unitprice decimal(10, 2) comment '单价',
    category varchar(50) comment '商品类别',
    provider varchar(50) comment '供应商'
);

-- 客户表
CREATE TABLE customer (
    customer_id bigint comment '客户号',
    name varchar(50) comment '姓名',
    address varchar(50) commnet '住址',
    email varchar(25) comment '邮箱',
    sex bit(1) commnet '性别',
    card_id varchar(18) commment '身份证'
);

-- 购买表
CREATE TABLE purchase (
    order_id bigint comment '购买订单',
    customer_id bigint comment '客户号'
    goods_id bigint comment '商品号'
    nums int comment '购买数量'
);

注意:

1、通过上面的代码,我们会发现表中的字段只有在最后一个才的末尾才不要加上逗号,其余的都需要在末尾加上逗号;

2、对于编号这些数据,我们通常采用的都是 bigint 来记录;

3、对于性别这种只有少数选择项的(男、女),我们通常采用的是 bit 来记录。 

好啦!本期 初始MYSQL数据库(1)——创建、删除数据库和数据表的相关操作 的学习之旅就到此结束啦!我们下一期再一起学习吧!

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

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

相关文章

C++20中lambda表达式新增加支持的features

1.弃用通过[]隐式捕获this&#xff0c;应使用[,this]或[,*this]显示捕获&#xff1a; namespace { struct Foo {int x{ 1 };void print(){//auto change1 [] { // badauto change1 [, this] { // good, this: referencethis->x 11;};change1();std::cout << "…

【进程间通信】匿名管道

1.进程间通信的介绍 是什么 为什么 怎么做 匿名管道 原理 特征 管道的四种情况可以写代码自己看看 管道接口 编码实现 父进程进行读&#xff0c;子进程进行写 里面有snprintf的使用 #include<iostream> #include<unistd.h> #include<stdlib.h> #i…

力扣435-无重叠区间(Java详细题解)

题目链接&#xff1a;435. 无重叠区间 - 力扣&#xff08;LeetCode&#xff09; 前情提要&#xff1a; 因为本人最近都来刷贪心类的题目所以该题就默认用贪心方法来做。 贪心方法&#xff1a;局部最优推出全局最优。 如果一个题你觉得可以用局部最优推出全局最优&#xff0…

祝贺 | 武汉大学生命科学学院孙蒙祥教授课题组时隔三年再发Nature

公众号&#xff1a;生信漫谈&#xff0c;获取最新科研信息&#xff01; 祝贺 | 武汉大学生命科学学院孙蒙祥教授课题组时隔三年再发Naturehttps://mp.weixin.qq.com/s?__bizMzkwNjQyNTUwMw&mid2247487136&idx1&sn9d65a5f18c7b5131800446bcbba7fa06&chksmc0e9…

计算之魂:持续于正确的因果链(一)

文章目录 引言25 人赛跑比赛过程模拟演示 BB84 量子密钥分发&#xff08;量子通信&#xff09;协议模拟图形化演示 BB84 协议过程BB84 协议优势应用场景 结语 引言 如果你只有一杆 100 年前的毛瑟枪&#xff0c;能够打中目标只能靠天分&#xff0c;如果你有一杆最先进的狙击步…

每日定期分享诗歌

安装schedule库 首先&#xff0c;确保你已经安装了schedule库。如果没有安装&#xff0c;可以使用以下命令进行安装&#xff1a; pip install schedulepython每日定期分享诗歌 import json import requests import schedule import timedef get_poem():# 这里使用一个公开的…

Linux下快速判断当前终端使用的是bash or csh

在Linux下设置环境变量的时候&#xff0c;可能你也遇到过export: Command not found一类的错误。这是因为当前终端使用的不是bash&#xff0c;如何快速判断当前终端使用的是哪种类型的shell呢&#xff1f; echo $0判断shell类型 最简单的方法就是在终端输入echo $0&#xff0…

编写一个每次随机生成 10个 0(包括) 到 100 之间的随机正整数。

编写一个每次随机生成 10个 0&#xff08;包括&#xff09; 到 100 之间的随机正整数。 package cn.itcast.example;import java.util.Iterator; import java.util.Random; public class example {public static void main (String[] arge) {System.out.println("Math.ra…

【微机原理】v和∧区别

&#x1f31f; 嗨&#xff0c;我是命运之光&#xff01; &#x1f30d; 2024&#xff0c;每日百字&#xff0c;记录时光&#xff0c;感谢有你一路同行。 &#x1f680; 携手启航&#xff0c;探索未知&#xff0c;激发潜能&#xff0c;每一步都意义非凡。 在汇编语言和逻辑表达…

Android使用内容提供器(ContentProvider)实现跨程序数据共享

文章目录 Android使用内容提供器&#xff08;ContentProvider&#xff09;实现跨程序数据共享新建内容提供器DatabaseProvider修改DatabaseProvider中的代码AndroidManifest.xml文件中注册provider修改activity_main.xml中的代码修改MainActivity中的代码运行ProviderTest项目 …

mysql查询慢除了索引问题还会是因为什么?

问题 作为一个程序员SQL查询慢的问题在工作和面试中都是会经常遇到的问题, 一般情况下我们都会联想到索引问题, 那么除了索引问题还有什么其他的场景会导致SQL查询慢呢? MySQL执行查询逻辑 例如我们使用可视化工具执行这样一条SQL: select * from user_info where age 10;…

Java:寻找最长连续序列

Java实现寻找最长连续序列 引言问题描述设计思路实现代码 代码解释单元测试 总结 引言 在面对大规模数据集时&#xff0c;经常需要识别出其中的连续子序列&#xff0c;这一任务在诸多领域如股票市场分析、天气预报等方面尤为关键&#xff0c;因为连续性的数据往往承载了重要的…

MacBook真的不能打游戏吗?Mac打游戏会损坏电脑吗?苹果电脑怎么玩游戏

MacBook从来都是高端的代名词&#xff0c;超强的性能搭配顶尖的系统&#xff0c;不光处理大型文件时举重若轻&#xff0c;长期使用也不会有明显卡顿。但很多人在需要MacBook一流的生产力同时&#xff0c;也希望能在空闲时体验游戏的乐趣。在大多人的印象里&#xff0c;Mac电脑对…

剑指offerJZ24 反转链表

描述&#xff1a; 给定一个单链表的头结点pHead(该头节点是有值的&#xff0c;比如在下图&#xff0c;它的val是1)&#xff0c;长度为n&#xff0c;反转该链表后&#xff0c;返回新链表的表头。 数据范围&#xff1a; 0≤n≤10000≤n≤1000 要求&#xff1a;空间复杂度 O(1)&…

大模型本地化部署1-Ollama安装(Windows)

大模型本地化部署1-Ollama安装&#xff08;Windows&#xff09; 1、下载Ollama安装包2、安装Ollama3、设置模型存放目录4、查看Ollama支持的模型5、模型安装6、查看已安装的模型列表7、运行一个模型8、设置Ollama允许外放访问 1、下载Ollama安装包 Ollama官网地址 https://oll…

【数据结构】二叉树基础(带你详细了解二叉树)

&#x1f30f;个人博客主页&#xff1a;心.c ​ 前言&#xff1a;最近学习了二叉树&#xff0c;和大家分享一下我的理解和感悟&#xff0c;希望对大家有所帮助&#xff0c;话不多说&#xff0c;开整&#xff01;&#xff01;&#xff01; &#x1f525;&#x1f525;&#x1f5…

示波器测量交流市电的注意事项

先说结论&#xff1a; 测量交流电或者市电的时候&#xff0c;注意示波器的电源千万不要用那种带GND的三角插头&#xff0c;可以用双脚插头但要小心漏电&#xff0c;示波器外壳金属部分可能带电&#xff1a; 当示波器的探头探针接L&#xff0c;黑色架子接N&#xff0c;这个时候…

YOLOv8改进 | 模块缝合 | C2f融合卷积重参数化OREPA【CVPR2022】

秋招面试专栏推荐 &#xff1a;深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 &#x1f4a1;&#x1f4a1;&#x1f4a1;本专栏所有程序均经过测试&#xff0c;可成功执行&#x1f4a1;&#x1f4a1;&#x1f4a1; 专栏目录 &#xff1a;《YOLOv8改进有效…

python自动化操作PDF,拆分pdf合并pdf,提取pdf内容

第三方库介绍 Python 操作 PDF 会用到两个库&#xff0c;分别是&#xff1a;PyPDF2 和 pdfplumber。 PyPDF2 可以更好的读取、写入、分割、合并PDF文件&#xff1b; pdfplumber 可以更好的读取 PDF 文件中内容和提取 PDF 中的表格&#xff0c;主要应用于机器生…

Redis基础知识学习笔记(二)

文章目录 一.Redis安装1.Windows 下安装1>资源管理器目录进入2>目录进入命令:3.配置环境变量 2.Linux 下安装1> 安装redis2> 启动redis3> 查看 redis 是否启动 二.Redis配置1. 查看配置2. 编辑配置3. 参数说明 三.Redis数据类型1. String&#xff08;字符串&…