【重学 MySQL】十二、SQL 语言的规则与规范

news2025/1/8 5:35:12

【重学 MySQL】十二、SQL 语言的规则与规范

  • 基本规则
  • 注释
  • 语法规则
  • 命名规则
    • 基本命名规则
    • 具体命名规范
    • 其他注意事项
  • 数据导入指令

在这里插入图片描述

SQL(Structured Query Language,结构化查询语言)的规则与规范是确保SQL语句能够正确执行、提高代码可读性和可维护性的基础。

基本规则

  1. 语句结构

    • SQL语句可以写在一行或多行中,为了提高可读性,建议将各子句分行写,必要时使用缩进。
    • 关键字不能被缩写也不能分行。
    • 每条SQL命令通常以分号(;)结束,也可以在MySQL中使用\g或\G作为命令结束符(特别是在客户端工具中)。
  2. 标点符号

    • 必须保证所有的括号(())、单引号(')、双引号(")是成对结束的。
    • 必须使用英文状态下的半角输入方式。字符串型和日期时间类型的数据必须使用单引号(')括起来。
    • 列的别名尽量使用双引号(" "),且不建议省略AS关键字(尽管在某些数据库系统中可以省略)。
  3. 大小写规范

    • SQL关键字、函数名等通常不区分大小写(如SELECTselect在大多数数据库系统中是等效的)。但是,为了保持代码的一致性和可读性,建议采用统一的书写规范。
    • 在MySQL中,数据库名、表名、列名(或字段名)在Windows环境下是大小写不敏感的,而在Linux环境下是大小写敏感的。推荐的做法是将数据库名、表名、列名等小写,而将SQL关键字、函数名大写。
  4. 命名规则

    • 数据库、表名不得超过一定字符数限制(如MySQL中通常为30个字符),变量名也有类似限制。
    • 名称必须只能包含字母(A-Z, a-z)、数字(0-9)和下划线(_),且不能包含空格或特殊字符。
    • 同一个数据库软件中,数据库名不能重名;同一个库中,表名不能重名;同一个表中,字段名不能重名。
    • 字段名不应与保留字、数据库系统或常用方法冲突,若冲突可使用反引号(`)将字段名括起来。

注释

SQL支持单行注释和多行注释,以提高代码的可读性。

  • 单行注释
    • 使用#(MySQL特有)或--(后跟一个空格)进行注释。
  • 多行注释
    • 使用/* 注释内容 */进行注释。

语法规则

SQL语言包含多种类型的语句,每种语句都有其特定的语法规则。例如:

  • 数据定义语言(DDL):用于定义数据库的结构,如CREATE TABLEALTER TABLEDROP TABLE等。
  • 数据操纵语言(DML):用于对数据库中的数据进行增、删、改等操作,如INSERT INTOUPDATEDELETE等。
  • 数据查询语言(DQL):用于从数据库中检索数据,主要是SELECT语句。
  • 数据控制语言(DCL):用于定义数据库、表、字段的访问权限和安全级别,如GRANTREVOKE等。

在编写SQL语句时,需要遵循相应的语法规则,如SELECT语句后面必须跟FROM子句来指定查询的数据源,WHERE子句用于指定查询条件,GROUP BY子句用于对结果集进行分组等。

总之,SQL语言的规则与规范是确保SQL语句正确执行、提高代码质量的重要基础。在编写SQL语句时,应严格遵守这些规则和规范,以提高代码的可读性、可维护性和执行效率。

命名规则

SQL命名规则是数据库设计中至关重要的一部分,它有助于确保数据库对象(如表、列、视图等)的名称具有一致性、清晰性和可维护性。

基本命名规则

  1. 字符限制

    • 数据库名、表名、列名等对象名通常有一定的字符数限制,具体限制取决于数据库系统。例如,在MySQL中,数据库名和表名通常不超过64个字符,但为了统一规范、易于辨识以及减少传输量,推荐不超过30-32个字符。
    • 名称必须只能包含字母(A-Z, a-z)、数字(0-9)和下划线(_),且通常不能以数字开头。
  2. 大小写敏感性

    • 在不同的数据库系统中,对象名的大小写敏感性可能有所不同。例如,MySQL在Windows环境下是大小写不敏感的,而在Linux环境下是大小写敏感的。因此,推荐采用统一的命名规范,如全部小写,以避免潜在的混淆。
  3. 避免使用保留字

    • 数据库系统保留了一系列的关键字(如SELECTINSERT等),这些关键字不能用作数据库对象的名称。如果确实需要使用类似保留字的名称,可以使用反引号(`)将其括起来。
  4. 避免使用特殊字符

    • 除了下划线(_)之外,应避免在数据库对象名称中使用其他特殊字符,如空格、点(.)、斜杠(/)等。

具体命名规范

  1. 数据库名

    • 应简洁明了,通常使用项目名或产品名作为数据库名。
    • 避免使用特殊字符和下划线,除非必要。
  2. 表名

    • 应具有描述性,能够反映表中的数据内容。
    • 采用单数形式,如employee而不是employees
    • 如果表属于某个特定模块或系统,可以在表名前加上该模块或系统的缩写作为前缀。
    • 布尔类型的字段可以使用is_作为前缀,后接动词过去分词,如is_active
  3. 列名

    • 应具有描述性,能够反映列中的数据内容。
    • 避免使用数据类型作为列名的一部分,如int_id
    • 如果列名由多个单词组成,可以使用下划线(_)分隔,如first_name
    • 主键列通常命名为id表名_id(如employee_id),以表示其唯一性。
  4. 索引名

    • 索引名应具有描述性,能够反映索引的用途。
    • 非唯一索引通常按照idx_字段名的格式命名,唯一索引则按照uniq_字段名的格式命名。
  5. 视图名

    • 视图名应以view_作为前缀,以区分于表名。
    • 视图名应具有描述性,能够反映视图的功能。
  6. 存储过程、函数和触发器

    • 存储过程名通常以sp_usp_等作为前缀。
    • 函数名通常以fn_作为前缀。
    • 触发器名可以根据其操作类型(如Insert、Delete、Update)和表名来命名,如tr_employee_i表示在employee表上执行的Insert触发器。

其他注意事项

  • 命名一致性:在整个数据库中,应保持命名的一致性。例如,如果某个表名采用了驼峰命名法(CamelCase),那么其他表名也应采用相同的命名法。
  • 简洁性:名称应尽可能简洁,避免使用冗长的名称。但是,简洁性不应以牺牲描述性为代价。
  • 可读性:名称应具有良好的可读性,以便于其他开发人员理解和维护。

综上所述,SQL命名规则是确保数据库对象名称一致性、清晰性和可维护性的重要手段。在设计和命名数据库对象时,应遵循上述规则和建议。

数据导入指令

在 MySQL 中,source 命令是一个非常有用的指令,它允许你从文件中读取并执行 SQL 语句。这个命令通常用于导入数据库结构(如表定义)或数据到 MySQL 数据库中。

要使用 source 命令,你需要首先登录到 MySQL 命令行界面(CLI)或使用 MySQL 的客户端工具,如 MySQL Workbench、phpMyAdmin(尽管在 phpMyAdmin 中不直接使用 source 命令,但可以通过类似的界面上传并执行 SQL 文件)。

以下是在 MySQL 命令行界面中使用 source 命令的基本步骤:

  1. 登录到 MySQL
    首先,你需要通过命令行或终端登录到 MySQL 服务器。使用如下命令(根据你的实际用户名、密码和主机名进行替换):

    mysql -u 用户名 -p
    

    输入命令后,系统会提示你输入密码。

  2. 选择数据库
    在导入数据之前,确保你已经选择了正确的数据库。使用 USE 语句来选择数据库:

    USE 数据库名;
    
  3. 使用 source 命令导入数据
    现在,你可以使用 source 命令来导入 SQL 文件中的数据了。在 MySQL 命令行中,执行如下命令(将 文件路径 替换为你的 SQL 文件的实际路径):

    source 文件路径;
    

    注意:在 Windows 系统中,文件路径可能需要使用双反斜杠(\\)或单斜杠(/)作为路径分隔符,而在 Unix/Linux/macOS 系统中,通常使用单斜杠(/)。

    例如,在 Unix/Linux/macOS 系统中,如果你的 SQL 文件位于 /home/user/data/import.sql,则命令将是:

    source /home/user/data/import.sql;
    

    而在 Windows 系统中,如果文件位于 C:\Users\User\Documents\data\import.sql,则命令可能是(取决于你的命令行解释器):

    source C:\\Users\\User\\Documents\\data\\import.sql;
    

    source C:/Users/User/Documents/data/import.sql;
    
  4. 验证导入
    导入完成后,你可以通过查询数据库中的表来验证数据是否已成功导入。

请注意,使用 source 命令时,MySQL 会读取并执行 SQL 文件中的每一条 SQL 语句。因此,请确保你的 SQL 文件是安全的,不包含任何可能对数据库造成损害的语句。此外,对于非常大的 SQL 文件,导入过程可能需要一些时间,具体取决于你的服务器性能和数据量。

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

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

相关文章

HarmonyOS开发实战( Beta5.0)Native Drawing自绘制能力替代Canvas提升性能

简介 Canvas 画布组件是用来显示自绘内容的组件,它具有保留历史绘制内容、增量绘制的特点。Canvas 有 CanvasRenderingContext2D/OffscreenCanvasRenderingContext2D 和 DrawingRenderingContext 两套API,应用使用两套API绘制的内容都可以在绑定的 Canv…

语音测试(一)ffmpeg视频转音频

视频转音频 下载ffmpeg工具进入bin目录cmd进入控制台输入命令 ffmpeg.exe -i ./视频.mp4 ./音频.wav命令说明 ffmpeg -i input.mp4 output.mkv FFmpeg 可能会尝试自动选择合适的编码器对视频和音频进行重新编码,以便适应 MKV 格式的要求ffmpeg -i input.mp4 -c c…

Java项目:140 springboot203医疗挂号管理系统

作者主页:舒克日记 简介:Java领域优质创作者、Java项目、学习资料、技术互助 文中获取源码 项目介绍 一共有管理员、挂号人员、划价人员、医生 四个角色 管理员登录进入本系统操作的功能包括对挂号人员,划价人员,患者&#xff0…

初始QT!

作业:了解QT文件夹初始代码的意义 QT core gui #QT工程所需得类库 core是核心库 gui图形化界面相关库类 greaterThan(QT_MAJOR_VERSION, 4): QT widgets #版本超过4.0会加上widgetsCONFIG c11 #该编辑器支持c11后的版本 # The following define makes you…

ngrok forward本地argocd并设置为github repo webhook

为什么需要ngrok 我们刚学了argocd的安装和部署应用,但是argocd什么时候部署部署我们的应用,就取决于repo的sync机制。我们采用以下cmd设置为autosync。 argocd app list # to get our app argocd app set argocd/tekton-learning-nginx --sync-polic…

小试牛刀-SOL链创建Token

目录 1.编写目的 2.账户结构 3.环境及使用依赖 4.步骤分解 4.1.导入相关依赖 4.2. 初始化变量 4.3. 创建并初始化Mint Account 4.4. 创建并初始化Metadata Account 4.5. 发送创建和初始化mint Account 4.6 铸造Token 5.源码分享 Welcome to Code Blocks blog 本篇文…

震惊,从仿真走向现实,3D Map最大提升超12,Cube R-CNN使用合成数据集迁移到真实数据集

震惊,从仿真走向现实,3D Map最大提升超12,Cube R-CNN使用合成数据集迁移到真实数据集 Abstract 由于摄像机视角多变和场景条件不可预测,在动态路边场景中从单目图像中准确检测三维物体仍然是一个具有挑战性的问题。本文介绍了一…

基于飞桨paddle2.6.1+cuda11.7+paddleRS开发版的目标提取-道路数据集训练和预测代码

基于飞桨paddle2.6.1cuda11.7paddleRS开发版的目标提取-道路数据集训练和预测代码 预测结果: 预测影像: (一)准备道路数据集 下载数据集地址: https://aistudio.baidu.com/datasetdetail/56961 mass_road.zip …

国际标准图像分辨率测试ISO12233 - 2017中文翻译

参考:https://blog.csdn.net/jgw2008/article/details/116519404?spm1035.2023.3001.6557&utm_mediumdistribute.pc_relevant_bbs_down_v2.none-task-blog-2~default~OPENSEARCH~Rate-2-116519404-bbs-392397517.264^v3^pc_relevant_bbs_down_v2_default&d…

SpringBoot与Minio的极速之旅:解锁文件切片上传新境界

目录 一、前言 二、对象存储(Object Storage)介绍 (1)对象存储的特点 (2)Minio 与对象存储 (3)对象存储其他存储方式的区别 (4)对象存储的应用场景 三、…

万龙觉醒辅助:VMOS云手机助力资源采集!挂机升级!

《万龙觉醒》是一款策略型游戏,玩家需要合理规划资源采集、建筑升级、科技研发等来提升实力。在本文中,我们将为您提供一篇详细的游戏辅助攻略,并介绍如何使用VMOS云手机来提升您的游戏体验,实现24小时的自动化管理。 使用VMOS云…

R3M: A Universal Visual Representation for Robot Manipulation

R3M [25] explores how visual representations obtained by training on diverse human video data using time-contrastive learning and video-language can enable data-efficient learning(实际上就是小样本学习) of downstream robotic manipulati…

【FreeRTOS】事件组实验-改进姿态控制

目录 0 前言1 事件组实验_改进姿态控制2 改进思路2.1 创建事件2.2 等待事件2.3 设置事件2.4 Debug2.5 设置MPU6050寄存器 3 总结 0 前言 学习视频: 【FreeRTOS 入门与工程实践 --由浅入深带你学习 FreeRTOS(FreeRTOS 教程 基于 STM32,以实际项…

pdf文件怎么编辑?6个pdf编辑方法学起来(图文教程)

pdf文件怎么编辑?现今的互联网时代,我们的办公也趋向于数字化办公。PDF文件已经成为我们日常工作和学习中不可或缺的格式文件。然而,编辑PDF文档不是一件容易的事。很多人会因为编辑pdf文档感到非常苦恼,尤其是当需要对PDF进行内容…

Linux内核编程(十五)网络设备驱动

本文目录 一、常见的网络协议二、传输介质三、RJ-45接口 对于网络知识不太熟悉的同学可以查看这篇文章:计算机网络知识点详情总结。 一、常见的网络协议 TCP、UDP协议:详情查看-TCP、UDP系统编程。DNS协议:是互联网中用于将域名&#xff08…

【刷题笔记】删除并获取最大点数粉刷房子

欢迎来到 破晓的历程的 博客 ⛺️不负时光&#xff0c;不负己✈️ 题目一 题目链接&#xff1a;删除并获取最大点数 思路&#xff1a; 预处理状态表示 状态转移方程 代码如下&#xff1a; class Solution { public:int deleteAndEarn(vector<int>& nums) {int N1…

八股(7)——Redis

八股&#xff08;7&#xff09;——Redis 4.3 RedisRedis 基础简单介绍一下 Redis!分布式缓存常见的技术选型方案有哪些&#xff1f;说一下 Redis 和 Memcached 的区别和共同点缓存数据的处理流程是怎样的&#xff1f;为什么要用 Redis/为什么要用缓存&#xff1f;Redis 除了做…

2024 年全国大学生数学建模竞赛(国赛)浅析

需要完整资料&#xff0c;请关注WX&#xff1a;“小何数模”&#xff01; &#xff08;需要完整B、C和E题资料请关注WX&#xff1a;“小何数模”&#xff0c;获取资料链接&#xff01;&#xff09; 本次万众瞩目的全国大学生数学建模赛题已正式出炉&#xff0c;无论是赛题难度…

Floorp Browser:开源自由,打造更个性化的浏览环境!

前言 "技术引领未来&#xff0c;创新改变世界。" 在这个日新月异的数字化时代&#xff0c;网络浏览器作为我们探索互联网世界的窗口&#xff0c;其重要性不言而喻。正是在这样的背景下&#xff0c;Floorp浏览器应运而生&#xff0c;它不仅继承了Mozilla Firefox的强…

基于SpringBoot的外卖点餐系统

你好呀&#xff0c;我是计算机学姐码农小野&#xff01;如果有相关需求&#xff0c;可以私信联系我。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBootJSP 工具&#xff1a;IDEA/Eclipse、Navicat、Maven、Tomcat 系统展示 首页 用户管理界…