MYSQL数据库基础-01.数据库的基本操作

数据库的语法是大小写不敏感的,可以使用大写,也可以使用小写。

每条语句要以;结尾,可以多行输入。

名称不能是关键字,若想用关键字命名,要用反引号 `` 引起来。


目录

一.数据库的基本操作

1.创建数据库:

2.查看数据库:

3.选中数据库:

4.删除数据库:

二、对表的基本操作

1.常见的数据类型

数值类型:

字符串类型:

日期类型:

1.创建表:

2.查看所有表

3.查看表结构

三、对表内容的增删查改

1.新增

2.查找

全列查询:

指定列查询:

表达式查询:

带别名的查询:

去重

排序

条件查询

分页查询 limit

3.修改

4.删除


一.数据库的基本操作

1.创建数据库:

create datadase 数据库名;

注意:1.单词之间用 空格隔开,每条语句以分号结尾。 

           2.不能创建已经存在的数据库(同名数据库)。

当数据库量很大时,为防止创建的数据库名子不重名,可以这样创建:

create database if not exists 数据库名;

(当出行同名的数据库时,会创建数据库失败,但不会报错)

此时java109数据库已经存在,再次创建,仅有一个警告,不会报错,也不会再次创建。

创建数据库的时候,可以手动指定一下字符集:

character set 字符集名字/charset 字符集名字

create database 数据库名 charset 字符集名;

后来又有了utf8mb4,是完全的utf8.

什么是字符集:

在计算机中,一个汉字,占几个字节?

这个问题,不同的字符集,在不同的编码下,答案是不同的。

VS默认的字符集和系统自带的编码都是gbk,对应的一个汉字占两个字节。

utf8编码下,一个汉字占3个字节。

还有一种编码:unicode编码:是对字符进行编码,但无法对字符串进行编码,

2.查看数据库:

列出当前mysql服务器中有哪些数据库。

show databases;

3.选中数据库:

use  数据库名;

选中数据库后,就可以在这个数据库中创建表了,并对表进行操作(对数据库进行操作,最主要的就是对表进行操作了)。

4.删除数据库:

drop database 数据库名;

注意:删除数据库是一个非常危险的操作,特别是处理相关业务的时候,删除数据库,删除的不仅仅是这个数据库,数据库中的表及相关的数据都被删除了,且是不可再恢复的,因此一定要谨慎删库。

1.设置权限

2.提前把数据做好备份

3.当要进行类似的危险的,重要的操作时,可以找一个人,对上述操作一起进行,可以尽量防止误操作。

二、对表的基本操作

对表操作的前提是 先选中数据库。

1.常见的数据类型

数值类型:

整形:

浮点型:

float(M,D) :括号中的 M表示小数的长度,D表示小数点后保留几位。

decimal(M,D): 更加精确的保存浮点数。decimal(M,D)虽能更加精确的保存浮点数,但运算速度会变慢,还会浪费更多的空间,因此要在特定的场合使用。

数值类型可以指定为无符号:unsigned ,表示不取负数。

字符串类型:

varchar(size) :size表示最多存储字符的个数。

text ,mediumtext 都是用来存储文本数据的。

blob 用来存储二进制数据。

日期类型:

timespace 就是一个时间戳,用1970年0时0分0秒为一个基准时间,计算 现在时间与基准时间的秒/毫秒/微妙之差.

以后使用时间类型,一般用datatime,timespace的大小为4字节,表示的范围是到2038年,很快就到了,到时就没法再用了,

1.创建表:

一个表可以有很多行,每一行代表一条记录;也可以有很多列,每一列称为一个字段,代表的是一种具体的数据类型。

create table 表名(列名 类型,列明 类型,....);

类型:整形 int long

        浮点型 float decimal

        字符串 varchar

        日期 datatime

2.查看所有表

show tables;

3.查看表结构

desc 表名;

desc :describe描述

field:字段,列名

type:类型

NULL :表示是否允许为空,YES表示可以为空,

KEY:表示是否为关键字

default:表示默认值,没有指定是默认为NULL

Extra:表示其他的

4.删除表

drop table 表名;

删除表操作也是一个非常危险的操作,删除表不仅把表格删除,表中的数据也全被删除了。

三、对表内容的增删查改

1.新增

insert into 表名 values (值,值,...);

这里插入的值的类型,个数 要和创建表时的结构 相匹配。

插入指定列:

inset into 表名 (列名,列名...) values (值,值...);

对某些指定的列进行插入.

一次插入多条记录:

insert into 表名 values (值,值...),(值,值...)...;

2.查找

全列查询:

select * from 表名;

在真正使用的时候,select *查询操作是很危险的操作,mysql查询都是在硬盘上进行的,当要查询的表中有大量数据时,可能会是硬盘损坏,是数据丢失,这造成的后果是非常严重的,因此一定要谨慎使用.

指定列查询:

select (列名,列名,...) from 表名;

表达式查询:

select 表达式 from 表名;

表达式指的是针对每列进行加减乘除类似的运算,把当前表的每一行对应的列进行运算.

这里的运算仅是针对从数据库中查询出的数据,进行计算,是一份临时的数据,不会修改数据库中原本保存的数据。

带别名的查询:

select  列名 as 别名 from 表名;

as 别名: as可以针对列名/表名/库名,as是可以省略的,但不建议省略.

去重

distinct

用于修饰某一列/多列,当值相同时,仅保存一条记录.

select distince 列名,列名... from 表名;

排序

针对列进行排序,把每一行的数据进行排序。

order by 列名  asc/desc

asc为升序排列(升序为默认排序规则,可以不写),desc为降序排序.

select 列名 from 表名 order by 列名 asc/desc;

当没有使用order by 时,对数据库查询出的结果是无序的,随机的.

按指定列进行查询,若查询结果未对排序列进行查询,也是可以的,不影响查询结果.

对多列进行排序:

select 列名 from 表名 order by 列名 asc/desc,列名asc/desc...;

 以指定列顺序为优先级,对指定列按指定排序顺序先进行排序,再按照下一个列的指定列排序.

条件查询

where

指定具体的条件,对条件进行查询.

select 列名 from 表名 where 条件;

遍历表的每一条记录,把每一条数据带入条件,条件成立,就显示在结果表中;不成立就不会显示.

比较运算符:

逻辑运算符:

注意:where条件可以使用表达式,但不能使用别名.

创建学生成绩表exam_result,保存chinese,math,english三门成绩.

查询总成绩大于200的同学:

查询语文成绩为90的同学:

注意:mysql中的=表示判断的意思,和java中的含义不一样.

and / or

查询语文成绩大于80分,且英语成绩大于80分的同学:

查询语文成绩大于80分,或英语成绩大于80分的同学:

注意:and的优先级大于or,使用时,可以通过()来设置执行顺序.

between and:通常用来查询区间段的数据,闭区间.

查询语文成绩在 [80, 90] 分的同学及语文成绩

in:通常用来查询离散的数据

查询数学成绩是 58 或者 59 或者 98 或者 99 分的同学及数学成绩

模糊查询:% 匹配任意多个(包括 0 个)字符,_匹配任意一个字符

查询姓张的同学成绩:

未知NULL:

查询语文成绩未知的人:

分页查询 limit

select 列名 from 表名 limit n (offset m);

从m行开始,最多筛选n条记录.(offset m 不写,默认从第0行记录开始)

使用select * 查询表是比较危险的,可以使用分页查询,限制查询数据的个数

从第3行开始,筛选3条记录:

从第4行开始,筛选3行记录:

只剩下两行记录,就显示两行.

3.修改

update  表名 set 列名=值,列名=值,... where 条件;

对制定条件下的某行的值进行修改,若为设置条件,则会对所有行都修改.

 将张张同学的数学成绩变更为 80 分,语文成绩变更为 60 分

将总成绩倒数前三的 3 位同学的数学成绩加上 30 分

 这里有一个报错:out of range value for column math:数学这个字段超出范围.

成绩的类型为double(3,1),加上30后,成绩大于100,超出范围.修改为将数学成绩减30:

注意:mysql中没有+=  -=  *=  /= 类似语法

将所有同学的语文成绩更新为原来的 1/2 

4.删除

delete from 表名 where 条件;

删除满足条件的行,若条件没写,则会将表中的数据都删除.

将表中的数据删空 delete from ,和删除表drop table 这两个操作,表中的数据都将不存在,但第一个操作,表还存在,只是表中的数据不存在了;第二个数据会将表和表中的数据都给删除.

注意:

修改(update),和删除(delete)都是对数据库进行的操作,都是永久性的,这两个操作也是危险操作,操作时,要谨慎使用.

数据库的很多操作都是危险操作,可以进行备份,应对误操作:

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Decode Global专注金融创新,构建便捷的交易平台

随着金融市场持续进阶,越来越多的年轻正在涌入金融交易的体系中,针对当下年轻人崇尚精简,优中取优的特点,Decode Global紧跟金融市场发展的步伐,不断创新体验,致力于打造一个精简快捷,安全便捷的…

系统思考—转型

我们大多数问题的来源是:人们的思考方式与大自然的运作方式之间的差异。——葛雷果利贝特森(人类学家、生物学家及系统思考先驱) 在企业转型的过程中,许多企业创始人常常面临一个困境——过去的成功经验和旧有的思维方式&#xf…

Flutter:carousel_slider 横向轮播图、垂直轮播公告栏实现

安装依赖 carousel_slider: ^5.0.01、垂直滚动公告栏 import package:carousel_slider/carousel_options.dart;// 垂直滚动公告栏Widget _buildNotice() {return <Widget>[<Widget>[TDImage(assetUrl: "assets/img/home11.png",width: 60.w,height: 60.w…

【二叉树的深搜】计算布尔二叉树的值 求根节点到叶节点数字之和

文章目录 2331. 计算布尔二叉树的值解题思路&#xff1a;后序遍历129. 求根节点到叶节点数字之和解题思路&#xff1a;深度优先搜索 前序遍历 2331. 计算布尔二叉树的值 2331. 计算布尔二叉树的值 给你一棵 完整二叉树 的根&#xff0c;这棵树有以下特征&#xff1a; 叶子节…

【高阶数据结构】布隆过滤器(BloomFilter)

1. 概念 1.1 背景引入 背景&#xff1a;在计算机软件中&#xff0c;一个常见的需求就是 在一个集合中查找一个元素是否存在 &#xff0c;比如&#xff1a;1. Word 等打字软件需要判断用户键入的单词是否在字典中存在 2. 浏览器等网络爬虫程序需要保存一个列表来记录已经遍历过…

偏序关系.

一、偏序&#xff08;半序&#xff09;关系 偏序关系 自反反对称传递性 二、全序&#xff08;线序、链&#xff09;关系 三、偏序集中的重要元素 1. 极大元与极小元 极大元找所在集合的一个或几个最高点&#xff1b; 极小元找所在集合的一个或几个最低点。 2. 最大元与最小…

国产编辑器EverEdit - 列编辑模式

1 列模式 1.1 应用背景 在编辑CSV格式&#xff0c;或者比较规整的配置文件时&#xff0c;可能会用到一列的内容都要进行修改的情况&#xff0c;在不支持列模式的编辑器中&#xff0c;可能需要用户逐行去编辑&#xff0c;比如有下面一段扯淡文本&#xff1a; ADD NRNFREQ:LOCA…

论文笔记(六十三)Understanding Diffusion Models: A Unified Perspective(一)

Understanding Diffusion Models: A Unified Perspective&#xff08;一&#xff09; 文章概括引言&#xff1a;生成模型背景&#xff1a;ELBO、VAE 和分层 VAE证据下界&#xff08;Evidence Lower Bound&#xff09;变分自编码器 &#xff08;Variational Autoencoders&#x…

【重庆市乡镇界】面图层shp格式arcgis数据乡镇名称和编码wgs84坐标无偏移内容测评

标题中的“最新重庆市乡镇界面图层shp格式arcgis数据乡镇名称和编码wgs84坐标无偏移最新”指的是一个地理信息系统&#xff08;GIS&#xff09;的数据集&#xff0c;特别设计用于ArcGIS软件。这个数据集包含了重庆市所有乡镇的边界信息&#xff0c;以Shapefile&#xff08;.shp…

【0x04】HCI_Connection_Request事件详解

目录 一、事件概述 二、事件格式及参数 2.1. HCI_Connection_Request 事件格式 2.2. BD_ADDR 2.3. Class_Of_Device 2.4. Link_Type 三、主机响应 3.1. ACL链接类型 3.2. SCO或eSCO链接类型 四、应用场景 4.1. 设备配对场景 4.2. 蓝牙文件传输场景 4.3. 蓝牙物联网…

9. 神经网络(一.神经元模型)

首先&#xff0c;先看一个简化的生物神经元结构&#xff1a; 生物神经元有多种类型&#xff0c;内部也有复杂的结构&#xff0c;但是可以把单个神经元简化为3部分组成&#xff1a; 树突&#xff1a;一个神经元往往有多个树突&#xff0c;用于接收传入的信息。轴突&#xff1a;…

CTTSHOW-WEB入门-爆破25-28

web25 题目&#xff1a;解题思路及步骤&#xff1a;分析代码&#xff1a; error_reporting(0); include("flag.php");//包含文件flag.php if(isset($_GET[r])){$r $_GET[r];//获取参数rmt_srand(hexdec(substr(md5($flag), 0,8)));$rand intval($r)-intval(mt_ra…

win32汇编环境,对多行编辑框添加或删除文本

;运行效果 ;win32汇编环境,对多行编辑框添加或删除文本 ;主要要先设置文本的开始点与结束点&#xff0c;然后把一段文本顶替上去。没有添加文本或删除文本的概念&#xff0c;只有顶替。如果开始点与结束点都是前面文本的长度值&#xff0c;则成了从后面添加文本的效果。如果结束…

AutoGen入门——快速实现多角色、多用户、多智能体对话系统

1.前言 如https://github.com/microsoft/autogen所述&#xff0c;autogen是一多智能体的框架&#xff0c;属于微软旗下的产品。 依靠AutoGen我们可以快速构建出一个多智能体应用&#xff0c;以满足我们各种业务场景。 本文将以几个示例场景&#xff0c;使用AutoGen快速构建出…

项目中使用的是 FastJSON(com.alibaba:fastjson)JSON库

从你的 pom.xml 文件中可以看到&#xff0c;项目明确依赖了以下 JSON 库&#xff1a; FastJSON&#xff1a; <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.47</version> </depende…

EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成

EAMM: 通过基于音频的情感感知运动模型实现的一次性情感对话人脸合成 1所有的材料都可以在EAMM: One-Shot Emotional Talking Face via Audio-Based Emotion-Aware Motion Model网站上找到。 摘要 尽管音频驱动的对话人脸生成技术已取得显著进展&#xff0c;但现有方法要么忽…

cuda从零开始手搓PB神经网络

cuda实现PB神经网络 基于上一篇的矩阵点乘&#xff0c;实现了矩阵的加减乘除、函数调用等。并且复用之前元编程里面写的梯度下降、Adam、NAdam优化方法。实现PB神经网络如下&#xff1a; #ifndef __BP_NETWORK_HPP__ #define __BP_NETWORK_HPP__ #include "matrix.hpp&quo…

【Java数据结构】排序

【Java数据结构】排序 一、排序1.1 排序的概念1.2 排序的稳定性1.3 内部排序和外部排序1.3.1 内部排序1.3.2 外部排序 二、插入排序2.1 直接插入排序2.2 希尔排序 三、选择排序3.1 选择排序3.2 堆排序 四、交换排序4.1 冒泡排序4.2 快速排序Hoare法&#xff1a;挖坑法&#xff…

内存 管理

1、如何在LCD上面实现SD卡文件浏览&#xff1f; 需要读取所有文件名到内存&#xff0c;方法是定义一个数组才存储所有文件名。&#xff08;最大文件名的长度和文件个数&#xff09; 2、内存管理是什么&#xff1f; 指软件运行时对MCU内存资源的分配和使用的技术。要实现两个函…

1月21日星期二今日早报简报微语报早读

1月21日星期二&#xff0c;农历腊月廿二&#xff0c;早报#微语早读。 1、多地官宣&#xff1a;2025年可有序、限时或在限定区域燃放烟花爆竹&#xff1b; 2、TikTok恢复在美服务&#xff1b;特朗普提出继续运营TikTok方案&#xff0c;外交部&#xff1a;若涉及收购中国企业应…