当前位置: 首页 > article >正文

数分-MySQL基础01

数分-MySQL基础01基础概念MySQL数据库对象MySQL的架构MySQL客户端和服务器端连接方式命令行连接方式图形化客户端连接SQL语言分类通用语法所有数据库DDL语句数据库DDL数据表DDL表字段DDL数据类型字段约束基础概念数据库Database, DB按照一定数据结构组织、存储、管理数据的集合。数据库管理系统DBMS1定义管理数据库的软件系统负责数据的增删改查、安全、备份、恢复等。2MySQL开源免费、轻量级、高性能就是一个典型的关系型数据库管理系统。3核心功能数据定义创建库、表、字段数据操作增删改查数据控制用户权限、事务数据备份与恢复关系型数据库RDBMS基于关系模型的数据库用行列二维表格的形式存储数据。核心特点→ 数据以表为单位存储→ 表与表之间通过关系关联→ 使用SQL结构化查询语言操作数据。MySQL数据库对象表Table数据库中最基本的数据存储单位由行和列组成的二维表格。列Column/字段Field表中的标题表示数据的一个属性。属性→ 数据类型int、varchar、datetime 等→ 长度→ 是否允许为空null/not null→ 默认值default→ 约束主键、外键、唯一键等例如用户表中的id、username、password、create_time。行Row/记录Record表中的水平方向表示一条完整的数据。例如用户表中(1, ‘Ming’, ‘123456’, ‘2026-05-12 20:00:00’)就是一条记录。主键Primary Key表中唯一标识一条记录的列或列组合。特性→ 唯一性主键值不能重复→ 非空性主键值不能为null→ 一个表只能有一个主键。作用快速定位一条记录建立表之间的关联。外键Foreign Key引用另一个表主键的列用于建立表与表之间的关系。索引Index为了提高数据查询速度而建立的一种数据结构。MySQL的架构MySQL 采用客户端-服务器C/S架构分为客户端和服务器两部分客户端Client向服务器发送 SQL 请求接收并显示结果。常见客户端命令行客户端mysql.exe图形化客户端DataGrip、Navicat、DBeaver编程语言客户端Python、Java、PHP 等。服务器端Server接收客户端请求处理 SQL 语句返回结果。存储引擎Storage EngineMySQL 中负责数据存储和提取的底层软件模块。MySQL 的独特优势支持插件式存储引擎可以根据不同需求选择不同的引擎。最常用的存储引擎存储引擎特点适用场景InnoDB支持事务、行级锁、外键、崩溃恢复默认引擎绝大多数业务场景MyISAM不支持事务表级锁速度快只读数据、临时表、日志表Memory数据存在内存中速度极快断电丢失缓存、临时计算MySQL客户端和服务器端连接方式命令行连接方式命令格式远程服务器连接mysql -h 主机地址 -P 端口号 -u 用户名 -p [密码] [数据库名]参数说明默认值主机地址HostMySQL 服务器的 IP 地址或域名localhost本地端口PortMySQL 服务监听的端口3306用户名Username数据库账号root默认管理员密码Password对应账号的密码安装时设置数据库名Database要连接的具体数据库可选不指定则连接到服务器连接成功标志出现mysql退出连接mysql exit/quit本地默认连接mysql -u 用户名 -p[密码] [数据库名]注意密码推荐不在命令行明文输入回车后再输入例如# 密码不在命令行明文输入回车后再输入mysql-uroot-p# 连接本地的 sakila 数据库mysql-uroot-psakila# 连接 IP 为 192.168.1.100端口为 3306 的远程服务器mysql-h192.168.1.100-P3306-uanalyst-p图形化客户端连接MySQL与PyCharm连接社区版PyCharm-右侧未有Database选项PythonMySQL均已安装下载插件Database Navigator并应用点击DB Navigator - Database Browser点击“” - MySQL在弹出的窗口中依次完成下图中的1-5个步骤弹出连接成功的窗口即完成连接。SQL语言分类SQLStructured Query Language结构化查询语言是操作关系型数据库的标准通用语言。数据定义语言DDLData Definition Language用于定义数据库对象包括数据库、数据表、字段/列等。数据操作语言DMLData Manipulation Language用于操作数据库中的表记录包括新增、修改、删除。数据查询语言DQLData Query Language用于查询数据库中的表记录。数据控制语言DCLData Control Language用于管理数据库用户的权限和安全包括创建用户、授权、撤销权限等。通用语法所有数据库SQL 不区分大小写。关键字SELECT / select 完全一样。习惯关键字大写表名字段小写方便阅读。一条语句可以单行或多行书写但语句结尾必须加分号“;”代表一条 SQL 结束单行注释-- 注释内容注释内容与符号中间必须有空格# 注释内容多行注释/* 多行注释 */空格、换行不影响执行可随意换行排版增强语句的可读性字符串必须用单引号’不用双引号字段别名、表别名直接空格隔开。DDL语句作用用来定义、修改、删除数据库/表/索引等数据库结构不操作表里的数据。核心关键字create创建drop删除alter修改show查看truncate清空表结构数据。数据库DDL创建数据库# 创建数据库createdatabase数据库名称;# 数据库不存在时创建数据库createdatabaseifnotexists数据库名称;# 指定编码创建createdatabase数据库名称charsetutf8;createdatabaseifnotexists数据库名称defaultcharactersetutf8mb4;查看、使用数据库# 查看目前所有数据库showdatabases;# 切换使用指定的数据库use数据库名称;# 查看当前正在使用的数据库selectdatabase();# 查看指定数据库创建信息例如码表showcreatedatabase数据库名称;删除数据库# 不存在则不删除避免报错dropdatabaseifexists数据库名称注意删除后数据库内所有数据表与数据全部永久丢失无法回复。修改数据库字符集alterdatabase数据库名称defaultcharactersetutf8mb4;数据表DDL创建数据表-- []中的内容可选createtable[ifnotexists]表名(字段名1数据类型[约束条件],字段名2数据类型[约束条件]);常用字段约束primary key主键唯一性非空auto_increment自增长not null非空unique唯一default设置默认值示例createtableifnotexistsstudent(-- 字段名1为sid, 数据类型为int, 约束条件为主键、自增长, 添加备注学生编号用户看sidintprimarykeyauto_incrementcomment学生编号,-- 字段名2为sname, 数据类型为varchar,最大长度为100, 约束条件非空snamevarchar(100)notnullcomment学生姓名,ageintdefault18comment学生年龄,genderchar(2)comment性别,emailvarchar(50)uniquecomment邮箱)engineinnodbdefaultcharsetutf8mb4comment学生信息表;查看表相关信息-- 查看当前库中的所有数据表showtables;-- 快速查看指定数据表的具体结构包括字段、类型、约束desc表名;-- 查看完整建表语句showcreatetable表名;修改表名、删除数据表-- 修改指定数据表名称altertable表名renameto新表名;renametable表名to新表名;-- 删除指定的数据表droptable[ifexists]表名;注意删除后表结构和表里所有数据全部清空。表字段DDL添加表字段# 格式altertable表名add字段名 数据类型[约束条件];# 示例altertablestudentaddphonechar(11)notnullunique;修改字段——修改字段 数据类型 / 约束# 格式altertable表名modify字段名 新数据类型[新约束条件];# 示例altertablestudentmodifysnamevarchar(30)notnull;——修改字段 名 数据类型/约束# 格式altertable表名 change 旧字段名 新字段名 数据类型[新约束条件];# 示例altertablestudent change age stu_ageint;注意修改字段未写入新约束条件时原有全部约束会直接丢失清空例如原有的 not null 非空约束消失变回默认 null 状态。3. 删除字段# 格式altertable表名drop字段名;# 示例altertablestudentdropaddress;数据类型数值类型存数字类型占用空间使用场景tinyint1字节年龄、状态、少量数字int4字节编号、id、数量、常用整数bigint8字节订单号、长数字float4字节普通小数不精准double8字节双精度小数不精准decimal(m,d)自定义金额、价格、财务数据精准小数注意存钱、金额一律用 decimal不用 float/doubledecimal(10,2) 表示共存10位数小数占2位。字符串类型存文字类型特点用法char(n)固定长度手机号、身份证、性别长度固定varchar(n)可变长度姓名、地址、简介text长文本文章内容、长篇备注区别char 写多少占多少空间查询快varchar 用多少占多少节省空间。日期时间类型类型格式用法dateyyyy-mm-dd只存日期timehh:mm:ss只存时间datetime日期 时间登录时间、创建时间等字段约束在数据类型限制的基础上额外增加的要求。primary key 主键约束——唯一标识一条数据非空且唯一一张表只能有一个主键。auto_increment 自增约束——数值自动往上累加不用手动赋值只能用于整型主键。unique 唯一约束——字段值不能重复但可以为空手机号、邮箱、身份证常用。default 默认值约束——不填数据时自动使用默认值。foreign key 外键约束——让两张表建立关联保证数据完整性只能在 innodb 引擎使用从表字段引用主表主键。即对关系字段进行约束当为关系字段赋值时会到关联的表中查询此值是否存在若存在则填写成功不存在则填写失败抛出异常。空值约束——null允许为空默认状态——not null禁止为空必须赋值。comment 字段 / 表注释——字段后comment 说明给字段添加备注表末尾comment 表用途给整张表加备注。只做阅读提示不限制数据。

相关文章:

数分-MySQL基础01

数分-MySQL基础01基础概念MySQL数据库对象MySQL的架构MySQL客户端和服务器端连接方式命令行连接方式图形化客户端连接SQL语言分类通用语法(所有数据库)DDL语句数据库DDL数据表DDL表字段DDL数据类型字段约束基础概念 数据库(Database, DB&…...

Spring AI Alibaba 1.x 系列【55】Interrupts 中断机制:静态中断源码分析

文章目录 1. interruptBefore 模式1.1 中断判断逻辑1.2 构建中断元数据1.3 返回中断响应1.4 初始化【中断执行】上下文1.5 合并状态(BUG)1.6 执行结束 2. interruptsAfter 模式2.1 设置 INTERRUPT_AFTER 标记2.2 动态计算下一个节点 3. 中断时机对比 1. …...

【Linux驱动开发】第11天:设备树(Device Tree)超详细全解:从诞生背景到工作原理

一、设备树的诞生背景:传统驱动的致命痛点 在设备树出现之前(Linux 3.0之前),Linux内核采用硬编码的方式描述所有硬件信息。这意味着: 每一个开发板的寄存器地址、中断号、GPIO号,都直接写死在驱动代码里换…...

【Linux驱动开发】第10天:设备树零基础入门——DTS/DTB/DTC全解+编译流程

目录 为什么需要设备树?传统驱动的终极痛点DTS/DTB/DTC 大白话定义核心区别三者关系完整编译流程图最简单的DTS示例语法解析设备树编译与反编译实操命令内核如何加载和使用设备树核心总结面试必背考点 1. 为什么需要设备树?传统驱动的终极痛点 在设备树…...

TowerPersonalProperty.cs

TowerPersonalProperty 是塔的标准化攻击组件,攻击节奏(CD管理)子弹发射(从对象池获取并配置)视觉表现(旋转、动画、音效、特效)经济交互(升级/出售价格计算与金币变更)它…...

[工具] 数学题库生成器(小学,初中,高中全包括) 面向中小学数学教学的自动出题工具,覆盖从小学一年级到高中三年级共 7 个学段、33 种题型

数学题库生成器(小学,初中,高中全包括) 基本覆盖各个年级的重点题型生成,并导出为word,可以显示解题步骤。# 数学题库生成器 MathMaster 数学题库生成器(MathMaster)是一款面向中小学…...

硬件工程师,每天5分钟(5)——为什么 DDR5 最怕地不好?回流路径,才是高速设计真正的灵魂

讲透: 回流路径 为什么 Split Plane 最危险 为什么加地孔有时候能救命 为什么 GPS 会被 DDR 干扰 为什么 EMC 挂的根因常是地 🚗《硬件工程师,每天5分钟》第5篇 🔥《为什么 DDR5 最怕地不好?回流路径,才是高…...

11.三层网络VXLAN

先把之前基于flat模式创建的虚机,全部删除 控制节点配置:1.修改配置文件/etc/neutron/neutron.conf 将[DEFAULT]区域 core_plugin ml2 service_plugins 修改为 core_plugin ml2 service_plugins router allow_overlapping_ips True2.修改/etc/neutro…...

数采网关的应用与特点

摘要在工业自动化、智能制造和物联网(IoT)快速发展的背景下,数据采集网关(数采网关)作为连接现场设备与上层管理系统的关键枢纽,发挥着至关重要的作用。它能够实现工业设备数据的实时采集、协议转换、边缘计…...

第2章:文档加载与智能分块——RAG的第一步

本章你将收获:支持PDF(含表格)、Word、Markdown、网页、CSV等10+格式的完整加载代码;五种分块策略的深度对比(固定大小、递归字符、语义、文档结构、按标题);元数据保留与增强的工程方法;处理100页混合格式技术手册的完整实战;以及分块参数调优的最佳实践。 📌 本章…...

西门子PLC对接须知:从通信到编程的实战指南

在工业自动化领域,西门子S7系列PLC凭借强大的功能和广泛的兼容性,成为众多企业的首选。无论是设备集成、数据采集还是系统升级,掌握PLC对接的核心要点,是保障项目高效落地的关键。本文将从通信连接、编程架构、数据处理三个维度&a…...

ComfyUI全面掌握-知识点详解——ComfyUI 开发与扩展基础(开发指南+环境搭建)

本文为「ComfyUI 全面掌握」系列第 23 篇,是高阶进阶章节的第一篇知识点详解博客。作为开发系列的起点,本文将带你系统了解 ComfyUI 社区贡献流程,并手把手搭建完整的自定义节点开发环境,为后续的节点开发与发布奠定坚实的技术基础…...

STM32矩阵按键详解——4×4行列扫描与非阻塞消抖(硬件总结六)

前言 独立按键虽然简单,但当产品需要十几个按键时,每个按键独占一个GPIO的接法就变得很不经济。矩阵按键通过“行列”的交叉结构,仅用NM个GPIO即可驱动NM个按键。以最常见的44矩阵为例,16个按键仅需8个GPIO,引脚利用率…...

鸿蒙中的自由流转

鸿蒙自由流转是 ‌HarmonyOS(鸿蒙系统)‌ 实现多设备协同的核心能力之一,旨在打破设备边界,让应用和服务在不同终端间无缝流转,提升用户体验。‌什么是鸿蒙自由流转?‌鸿蒙自由流转是指用户在多个搭载 Harm…...

RUST编程学习.2语法

目录 前言 一、思维导图 二、Rust语法专属 1.迭代器 2.生命周期 总结 前言 在进行编译器下载后,就可以写代码进行编译调试了,在这之前就是要学习rust语法,在学习的过程中我整理了一版思维导图,最直观的感觉就是rust的语法很…...

【SSD】闪存1

闪存的特点 闪存是非易失存储器,掉电了数据也不会丢失,但是闪存不能够覆写,必须按块擦除,按页写入。 闪存的基本单元 闪存的基本单元是Cell,一种类Nmos的双层浮栅MOS管 MOS管 首先理解什么是MOS管:(金…...

性价比高的国产PLM软件公司

在制造业领域,不少企业都面临着研发效率低下、协同困难等问题。比如某电子制造企业,研发部门与生产部门之间信息沟通不畅,图纸版本管理混乱,导致产品研发周期延长,生产成本增加,新品上市时间比预期晚了近30…...

分布式团队的代码协作规范:从分支策略到提交信息格式

在分布式团队模式下,代码协作的地域分散、时区差异和沟通成本,给版本控制和质量保障带来了严峻挑战。作为软件测试从业者,我们不仅是代码质量的“守门员”,更需要深入理解并推动执行规范的代码协作流程,从分支管理到提…...

几十万买的数字孪生低代码平台集体落灰?被隐瞒的落地真相,终于说透了

在政企数字化采购圈子里,一直有个特别讽刺、且年年重复上演的现象。很多企业、政府单位,手握专项数字化预算,毫不犹豫花几十万重金购入数字孪生、3D可视化低代码平台。采购前被厂商的宣传话术打动:零代码拖拽、人人上手、无需专业…...

在家办公效率低?试试这个“空间切换”技巧

一、软件测试从业者居家办公的效率困境对于软件测试从业者而言,居家办公看似摆脱了办公室的嘈杂与束缚,实则面临着诸多独特的效率挑战。测试工作本身就需要高度的专注与严谨,从需求分析、用例设计到缺陷跟踪,每一个环节都容不得半…...

SMARTFORM不同模板一起打印

一、背景由于客户提出发货单要加上条形码打印,条形码单独一个模板,加在后面打印,输出PDF并发送邮件。二、效果展示不同模板一起打印效果如下,建立smartforms的表单时,也使用了两个不同的模板三、smartforms建立表单&am…...

远程技术面试的潜规则:摄像头角度可能影响你的录用

一、摄像头角度:被忽视的专业细节在软件测试的工作中,我们习惯用严谨的态度去排查代码里的每一个bug,用精准的测试用例去验证产品的每一项功能。但在远程技术面试这个特殊的“测试场景”里,很多人却忽略了一个看似无关紧要&#x…...

Spec-Kit + Superpowers 实战:Go语言博客论坛系统的规范驱动开发

从“凭感觉写代码”到“按规范做工程”,一套完整的AI驱动开发方法论落地 一、引言:AI编程的“效率陷阱” 2024年Google DORA报告揭示了一个令人困惑的数据:AI编码助手采用率每提升25%,软件交付稳定性反而下降7.2%。问题出在哪?研究表明,当上下文从1K Token扩展到32K Tok…...

微波遥感杂谈五(微波辐射计)

前言微波辐射计是通过被动的接收各个高度传来的温度辐射的微波信号来判断温度、 湿度曲线,能定量测量目标(如地物和大气各成分)的低电平微波辐射的高灵敏度接收装置。目前机载微波辐射计实测温度分辨率达0.02K,星载微波辐射计温度分辨率达 0.2&#xff5…...

适配多层级组织管理,科学运用 360 度反馈打造公平高效绩效文化

360度绩效反馈评估是一种从上级、下属、同事、客户等多个维度收集反馈的综合绩效评估方法,通过多源数据消除单一评价者的主观偏差,帮助企业获得更全面、客观的员工能力画像。相比传统的上级单向评价,360度反馈能将评估准确度提升40%以上&…...

鸿蒙备考题库页面构建:错题本、小组榜单与备考提示模块详解

鸿蒙备考题库页面构建:错题本、小组榜单与备考提示模块详解 前言 在 HarmonyOS 6.0 应用开发中,教育类应用的错题管理、学习排行榜和系统提示是提升用户粘性的关键功能模块。本文将以“备考题库”应用中的“错题本”高频错题列表、“小组榜单”学习排名和…...

中文编程语言的开创性语法,言律:一门以汉语为思维内核的原生中文编程语言

在对母语作为思维原生载体的深层结构、语言相对论与神经认知机制的探讨基础上,我们不再满足于“把英文关键字翻译成中文”的表层汉化,而是要开创一种真正根植于汉语思维逻辑的编程语法体系—— 🌿「言律」(Yn Lǜ)&…...

leetcode思路-236 二叉树的最近公共祖先

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的…...

把SAC model的数据导出到BW的ADSO中

目录 1. SAC 侧的准备 1.1 OData连接要做好 1.2 SAC里的model设置要配置好允许导出到Odata 2. BW侧要做的准备(先跟着SAP的note走) 3. SAC 模型数据导出 一般都是把planning model的数据导出到一个ADSO中,然后再用Composite Provider里…...

Word文档保护技巧:防止内容被轻易复制

Word文档如何防止复制呢?其实,Word根本没有真正意义上的禁止复制,因为用户按一下手机截图,或者拍张照片,内容照样能拿走。但是,我们可以提高复制门槛,也就是让其他用户通过“CtrlC”无法直接复制…...