MySQL数据库入门基础知识 【1】推荐

news2024/12/28 20:22:07

数据库就是储存和管理数据的仓库,对数据进行增删改查操作,其本质是一个软件。

首先数据有两种,一种是关系型数据库,另一种是非关系型数据库。

关系型数据库是以表的形式来存储数据,表和表之间可以有很多复杂的关系,比如:MySQL、Oracle、SQL Server等;
非关系型数据库是以数据集的形式存储数据,大量数据集中存储在一起,比如:MongDB、Redis、Mencached等
MySQL就是一种开源的关系型数库,也是最受欢迎的数据库之一,今天对MySQL数据的基础知识做了整理,方便自己查看,也欢迎正在学习MySQL数据库的同学参考,谢谢。

目录

1.安装配置连接

2.数据库的增删改查基本操作

2.1 查询显示数据库

2.2  新增创建数据库

2.3 删除数据库

2.4修改数据库

3.SQL数据类型

3.1 整数类型

3.2 定点类型

3.3 字符串类型

3.4 日期时间类型

4.数据表的增删改查

4.1 查询数据表 

4.2 新增数据表

4.3 删除数据表

4.4 修改数据表

5.SQL约束

5.1 主键约束 primary key 数据唯一性 值不可为空 不可重复。

5.2 联合主键约束

5.3 自动递增 auto_increment

5.4 unique 唯一约束

5.5  非空约束 not null 

5.6  default 默认值

6.外键约束



1.安装配置连接

MySQL数据库的安装配置前面已经写过,需要了解的请参考:详细教程 MySQL 数据库 下载 安装 连接 环境配置 全面-CSDN博客

数据库安装包有需要的请去主页资源自行下载!!

2.数据库的增删改查基本操作

连接数据库

在第一步安装的时候我们已经会使用navicat (GUI工具)并成功连接数据库了。

2.1 查询显示数据库

查询显示数据库 show databases;

  1. 输入sql 语句
  2. 选中sql语句,点击查询
  3. 查看查询结果

2.2  新增创建数据库

-- 1.创建数据库 user  这种写法如果当前数据库存在这个表就会报错的
create database user;  


-- 2.如果数据库不存在则会创建;存在就什么也不做 但是不会报错(推荐)
create database if not exists user;

第一种写法当数据库存在user 时报错

第二种写法不会报错

2.3 删除数据库

-- 1.删除数据库 如果数据库不存在会报错
drop database user;

-- 2.如果数据库存在则删除 不存在什么也不会做 但不会报错 (推荐使用)
drop database if exists user;

报错图示

2.4修改数据库

这里我们把创建的user数据库 默认字符集和排序规则进行修改,然后用sql修改成默认值。

-- 这里utf8mb4:字符集 兼容 utf8,且比utf8 能表示更多的字符
-- utf8mb4_0900_ai_ci:字符集对应的排序规则 大小写不影响
alter  database user character set utf8mb4 collate  utf8mb4_0900_ai_ci;

2.5 使用数据库

-- 使用数据库 
select database();
use user;

3.SQL数据类型

sql主要数据类型 :数字、字符串、日期时间等类型。

3.1 整数类型

浮点类型

3.2 定点类型

3.3 字符串类型

3.4 日期时间类型

4.数据表的增删改查

4.1 查询数据表 
-- 查询数据表
select database();
--使用数据库
use demo; 

-- 查看当前数据库的所有表
show tables;
4.2 新增数据表
--创建数据表 不存在才创建 不会报错 (推荐)
create table if not exists  student (
id int unsigned,
name varchar(20),
age tinyint unsigned,
gender enum('男性','女性','保密'),
createAt timestamp 
)

查询表中的字段信息

4.3 删除数据表
-- 删除数据表  (推荐)
 drop table if exists student;

4.4 修改数据表

改表名

-- 修改数据表表名
alter table student rename to  students;

加字段

--添加字段
alter table student add updatedAt timestamp;

--查看数据表信息
desc student;

 

删除字段

--添加字段
alter table student drop  updatedAt;

--查看数据表信息
desc student;

修改字段名称和字段的数据类型

--修改字段的数据类型
alter table student modify createAt datetime;

--修改字段的名称和数据类型
alter table student change  createAt createAT TIMESTAMP;

5.SQL约束

对数据表进行约束。

5.1 主键约束 primary key 数据唯一性 值不可为空 不可重复。
//没有primary key约束的
create table if not exists use_1(
  id int unsigned,
  name varchar(20)
);

-- primary key 主键约束 数据的唯一性 值不可重复 不可为空
create table if not exists use_2(
  id int unsigned primary key,
  name varchar(20)
);

--主键也可以这样设置
create table if not exists use_3(
  id int unsigned,
  name varchar(20),
   primary key(id)
);

5.2 联合主键约束
-- 联合主键 就是两个字段一起约束数据的唯一性  这里id 和name 两个字段
create table if not exists use_4(
  id int unsigned,
  name varchar(20),
   primary key(id,name)
);

当联合主键约束中的其中一个字段重复不会提示,两个字段完全重复会约束。

5.3 自动递增 auto_increment

设置自动递增的字段,当我们新增数据时,该字段会自动填充数据。

-- 自动递增 auto_increment
create table if not exists use_6(
  id int unsigned primary key auto_increment,
  name varchar(20)
);
5.4 unique 唯一约束
-- unique 唯一约束
-- 保证某个字段的值永远不重复 但允许有多个null值存在
-- 一张表可以只能有一个主键,但是可以有多个unique 

create table if not exists use_7(
  id int unsigned primary key auto_increment,
  name varchar(20) unique 
);

5.5  非空约束 not null 
--非空约束 not null 
create table if not exists use_8(
  id int unsigned primary key auto_increment,
  name varchar(20) not null  
);
5.6  default 默认值
-- default 默认值
create table if not exists use_9(
  id int unsigned primary key auto_increment,
  name varchar(20) not null,
  gender enum('男性','女性','保密') default('保密'),
  cerateAt timestamp default crrent_timestamp,
  updateAt timestamp default crrent_timestamp on update current_timestamp
);

6.外键约束


外键约束以及其他关于MySQL知识 请参考:MySQL数据库入门基础知识 【2】

MySQL数据库安装配置连接教程

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

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

相关文章

flink 1.17 测试

1、配置 2、测试: ./bin/flink run-application -t yarn-application -Dyarn.application.namewordcount -c org.apache.flink.streaming.examples.wordcount.WordCount ./examples/streaming/WordCount.jar --input hdfs://jy/tmp/input --output hdfs://jy/tmp/o…

linux安装人大金仓数据库

下载人大金仓数据库 人大金仓-成为世界卓越的数据库产品与服务提供商 (kingbase.com.cn) 下载授权文件 1创建用户 创建用户并设置密码为kingbase useradd kingbasepasswd kingbase 创建目录 sudo mkdir -p /opt/Kingbase/ES/V9 # 设置操作权限 sudo chmod orwx /opt/Kingba…

Spring@Autowired注解

Autowired顾名思义,就是自动装配,其作用是为了消除代码Java代码里面的getter/setter与bean属性中的property。当然,getter看个人需求,如果私有属性需要对外提供的话,应当予以保留。 因此,引入Autowired注解…

智慧水务项目(一)django(drf)+angular 18 通过pycharm建立项目

一、环境准备 windows 10 pycharm python3.11 二、pycharm 创建django项目 三、建立requirements.txt 在根目录创建requirements.txt,也就是与manage.py同一目录下,先放下面几个依赖 Django djangorestframeworkpip install -r .\requirements.txt 更新下pip python…

仓颉语言 -- 网络编程

使用新版本 (2024-07-19 16:10发布的) 1、网络编程概述 网络通信是两个设备通过计算机网络进行数据交换的过程。通过编写软件达成网络通信的行为即为网络编程。 仓颉为开发者提供了基础的网络编程功能,在仓颉标准库中,用户可使用…

python3GUI--new音乐播放器!By:PyQt5(附下载地址)

文章目录 一.前言二.展示1.启动2.MV推荐3.专辑详情页4.歌手详情页5.搜索结果页6.歌曲播放页7.我喜欢歌曲页8.我喜欢专辑页 三.思路&启发1.布局2.细节3.组件复用4.项目结构5.优化速度1.Nuitka1.显著提高性能:2.减小程序体积&am…

SPSSAU | 德尔菲专家法原理及案例实操分析

德尔菲专家法Delphi是一种结构化的预测和决策方法,主要用于收集和综合专家意见,进而做出相应决策的研究方法。比如在我们建立指标体系时,首先选择20个备选指标,然后寻找10位专家进行评价(评价该20个指标是否具有可行&a…

聊聊ChatGLM6B的微调脚本及与Huggingface的关联

前言 本文首先分析微调脚本trainer.sh的内容,再剖析ChatGLM是如何与Huggingface平台对接,实现transformers库的API直接调用ChatGLM模型,最后定位到了ChatGLM模型的源码文件。 脚本分析 微调脚本: PRE_SEQ_LEN128 LR2e-2CUDA_V…

GeneAvatar: 3D 数字人编辑方案

定位: GeneAvatar是一种通用方法,用于编辑不同体积表示(如NeRFBlendShape、INSTA、Next3D)中的3D数字人,仅需一张2D图像即可实现友好的编辑操作。 核心功能: 支持使用2D编辑方法(如拖拽式GAN、文本驱动编辑等&#x…

[Bugku] web-CTF-GET

GET 1.开启环境 2.根据内容得知在网址url后输入?whatflag

字符设备驱动基础—sys文件系统,udev介绍,驱动模块在内核空间注册设备

文章目录 sys文件系统介绍设计思想应用和功能 udev介绍主要功能工作原理使用 udevadm 工具 设备文件创建流程驱动程序的注册device_create函数详解示例代码效果图 sys文件系统介绍 sysfs 是 Linux 内核中的一种虚拟文件系统,它为用户空间和内核之间提供了一种统一的…

C语言小练习(贰)

上机 计算n以内所有正奇数的和 ? n值通过键盘输入 #include <stdio.h>int main() {int sum 0;int i 1;int n;printf("请输入一个范围\n");scanf("%d",&n);do{if(i % 2 ! 0)//判断奇数{sum i;}i;}while(i < n);//限定条件printf("范围…

Python连接数据库:JDBC不是唯一选择!

你是否曾困惑于如何在Python中连接数据库?也许你听说过JDBC,但不确定它是否适用于Python?别担心,本文将为你揭开Python数据库连接的神秘面纱! 目录 JDBC vs Python数据库连接Python连接数据库的正确姿势Python的数据库连接方案为什么Python不直接使用ODBC或JDBC&#xff1f;…

正点原子imx6ull-mini-Linux驱动之阻塞IO和非阻塞IO实验(12)

阻塞和非阻塞 IO 是 Linux 驱动开发里面很常见的两种设备访问模式&#xff0c;在编写驱动的时候 一定要考虑到阻塞和非阻塞。本章我们就来学习一下阻塞和非阻塞 IO&#xff0c;以及如何在驱动程序中 处理阻塞与非阻塞&#xff0c;如何在驱动程序使用等待队列和 poll 机制。 1&…

2024-08-01升级问题记录:升级ArcGIS for Android

升级以离线方式引用的arcgis for Android &#xff0c;从10.2.7到 10.2.9 1、下载完整的aar库 地址&#xff1a;JFroghttps://esri.jfrog.io/ui/native/arcgis/com/esri/arcgis/android/arcgis-android/10.2.9/ 2、替换旧的库&#xff0c;由于10.2.7是以jar方式引用&#xf…

Win10系统,使用钉钉会议共享屏幕的时候,别人看到的都是全黑或全白屏幕

环境&#xff1a; Win10系统 钉钉7.6.0 问题描述&#xff1a; Win10系统&#xff0c;使用钉钉会议共享屏幕的时候&#xff0c;别人看到的都是全黑或全白屏幕 解决方案&#xff1a; 在Win10系统上使用钉钉会议共享屏幕出现全黑或全白的问题&#xff0c;这可能与系统升级兼容…

盘点那些实用的开发技术!!

敏感信息加密操作&#xff0c;让开发的系统更加的安全可靠&#xff01;&#xff01;Jasypt&#xff08;Java Simplified Encryption&#xff09;是一个开源的Java库&#xff0c;用于简化加密操作。https://mp.weixin.qq.com/s/sPBV8Ej46YJsElImodRjAQ每个Web开发都应了解的&…

一个前后端分离架构的低代码开发平台,支持微服务架构,支持开发SAAS项目(附源码)

前言 在当前的企业软件开发领域&#xff0c;开发者常常面临着代码重复性高、开发效率低、项目周期长等挑战。现有的软件解-决方案往往难以满足快速变化的市场需求&#xff0c;特别是在SAAS项目、企业信息管理系统&#xff08;MIS&#xff09;、内部办公系统&#xff08;OA&…

淘天笔试0508-选择题

kmp中&#xff0c;匹配失败时&#xff0c;主串不动。模式串回退&#xff1a;最长前后缀的前缀位置。 bcabbccabbacaa abbac 比较3次&#xff0c;a匹配成功 一直到匹配abb&#xff0c;比较了5次. c和a不匹配&#xff0c;比较6次。 abb最长前后缀长度为0&#xff0c;模式串回退到…

昇思25天学习打卡营第18天|MindSporeK近邻算法实现红酒聚类学习- MindSpore进行KNN实验

基于MobileNetv2的垃圾分类 本文档主要介绍垃圾分类代码开发的方法。通过读取本地图像数据作为输入&#xff0c;对图像中的垃圾物体进行检测&#xff0c;并且将检测结果图片保存到文件中。 1、实验目的 了解熟悉垃圾分类应用代码的编写&#xff08;Python语言&#xff09;&a…