首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

自己动手写数据库系统:实现一个小型SQL解释器(上)

数据库系统有一个核心部件,那就是SQL解释器。...用过mySQL的同学都知道,我们需要写一系列由SQL语言组成的代码来驱动数据库的运行,由此它就必须要有一个SQL语言解释器来解读SQL代码,然后根据代码的意图来驱动数据库执行相应的操作,本节我们就完成一个简单的...SQL解释器。...实现一个解释器的首要步骤就是完成一个词法解析器,我在B站编译原理视频中实现过一个小型编译器(dragon-compiler),因此我将其对应的词法解析器直接拿过来稍作改动,让其能对SQL代码进行词法解析...接下来看看语法解析的实现,基于篇幅所限,这里我们只处理SQL的一小部分,有兴趣的同学可以自行补全我们这里完成的SQL解释器,首先我们先定义要解析的SQL语法部分: FIELD -> ID CONSTANT

40860
您找到你想要的搜索结果了吗?
是的
没有找到

自己动手写数据库系统:实现一个小型SQL解释器(中)

我们接上节内容继续完成SQL解释器的代码解析工作。...LEFT_PARAS Field RIGHT_PARAS 我们对上面的语法做一些基本说明: UpdateCmd -> INSERT | DELETE | MODIFY | CREATE 这句语法表明SQL...接着是左括号,跟着是由列名(column)组成的字符串,他们之间由逗号隔开,然后跟着右括号,接着是关键字VALUES,然后是左括号,接着是一系列常量和逗号组成的序列,最后以又括号结尾,其他语法大家可以参照SQL...) sqlParser.UpdateCmd() } 在main中,我们定义了一个create table的sql语句,然后调用UpdateCmd接口实现语法解析,大家可以在b站搜索”coding...Erichsen\", \"Skagen 21\", \"Stavanger\", 4006, \"Norway\")" sqlParser := parser.NewSQLParser(sql

25250

sql文件怎么导入sql server数据库_sql怎么导入数据库

工具/原料 Navicat for MySQL MySQL命令行界面 SQL脚本 方法一: 1、首先使用MySQL提供的命令行界面来导入数据库,确保电脑中安装了MySQL数据库,可以通过命令行来确认是否安装了...: 3、在将脚本拷到本地磁盘的根目录,这样方便进入找到脚本,这里以D盘来说明,使用test.sql:接着来到命令行,使用SOURCE d:/test.sql;来导入数据库,先进入mysql。...4、首先要在数据库中建立好数据库,然后导入脚本,所以先建立一个数据库哦,不要脚本是不知道要往哪个数据库中导入脚本的。...5、然后就可以输入导入.sql文件命令: mysql> USE 数据库名; mysql> SOURCE d:/test.sql; 6、看到上面的画面,说明mysql数据库已经导入成功了。...方法二:使用Navicat for MySQL图形界面来导入数据库,使用图形界面导入数据库的步骤很简单 1、在图形界面中建立好数据库之后,使用导入脚本的功能来导入数据库 2、点击选择脚本,选择D盘的test.sql

11.5K10

学习SQL【2】-数据库SQL

同时,它使用SQL(结构化查询语言)对数据进行操作。 4:关系数据库管理系统(RDBMS)的种类 ● oracle :甲骨文公司的RDBMS。 ● SQL server:微软公司的RDBMS。...● 根据SQL语句的内容返回的数据同样是二维表格式。 ● 表的行称为记录,表的列称为字段。 ● 关系数据库必须以行作为单位进行数据读写。 ● 一个单元格内只能输入一个数据。 如下图: ?...三:SQL概要 1:标准SQL 国际标准化组织(ISO)为SQL制定了相应的标准,以此为基准的SQL称为标准SQL 虽然不同的RDBMS存在一些特使的SQL语句,但学会标准SQL就可以在各种RDBMS...2:SQL语句及其种类 SQL使用关键字、表名、列名等组合成一句SQL语句来描述操作的内容。 根据指令种类不同,SQL语句可分为三种: ● DDL(数据定义语言):用来创建和删除数据库或表等对象。...3:SQL的基本书写规则 ● SQL语句要以分号(;)结尾。 ● SQL不区分关键字的大小写,但是插入到表中的数据是区分大小写的。

4K90

适合中小型公司的Mysql数据库使用规范

这个规范适合中小型公司,数据量不是特别大的。设计的单表容量在千万级。...数据库使用 MYSQL ,版本 5.7+ 数据库使用主要属性类型,数字用 int ,字符用 char ,比较多的字符用 text 或者 verchar, 根据实际情况,能用char的,尽量不要使用 verchar...需要数据库控制时间的用 timestamp 给默认值即可。不需要数据库控制时间的 使用 char ,用程序控制即可。...数据库相关的所有命名只能用小写英文字母,必须是有含义的英文单词,单词之间用 _ 进行间隔 2. 数据库名称需要与业务相关,或者直接使用项目名称。 3....这样万一有问题的时候,可以在数据库中了解整条数据创建和变化的时间点。tb_status 是标志位可以代表这一条数据的状态,一旦进入数据库的内容禁止物理删除。

1.1K30

sql数据库的基本介绍 sql数据库的作用

在这个过程中,数据库的作用是不容忽视的。数据库可以帮助人们将数据的收集、提取变得更简单、更方便。在大数据处理领域,一种名为sql数据库工具吸引着很多的人。那么这是一种什么工具?...sql数据库究竟有什么作用?下面就来为大家介绍一下。 image.png 一、功能众多的sql数据库 所谓sql,就是一种具有强大功能的数据库语言。...二、sql数据库的作用巨大 sql数据库有很多的优点。作为一个老牌的数据库整理程序,sql获得了广大用户的认可。就是因为其较其他数据库工具的优越性,使得sql逐渐的发展起来。...sql数据库在响应时间、服务器回应速度等细节方面占据了优势;在系统的接受与反馈方面超越了其他的数据库管理系统。除此之外,sql是一种非过程语言,这样的优点使得sql使用起来更加的方便。...同时sql是一种关系型数据库之间的公共语言,是其他语言之间的桥梁。 以上就是为大家带来的关于sql数据库的简单介绍。通过介绍,相信大家也了解到了sql数据库的具体优点。

5.4K30

数据库SQL语言)

SQL语言 结构化查询语言(Structured Query Language即SQL),可以通过命令行或图形化管理工具(navicat..)...作用与理解 SQL数据库查询和设计语言,用于存取数据、查询、更新、管理关系数据库。与其他程序设计语言的差别是,SQL由很少的关键字组成,每个SQL语言通过一个或多个关键字构成。...SQL的优点 一体化 ; 使用方式灵活:SQL2种使用方式,可以直接以命令方式交互使用;也可以嵌入到其他程序设计语言中使用(jdbc) ; 非过程化:只需要告诉计算机“做什么",而不需要使用SQL告诉计算机..."怎么做" ; 语言简洁; 注意: SQL语句不区分大小写; 在企业中为了方便辨认对SQL中的关键字进行大写,而对表名、列名、数据库名称使用小写;可以提高代码的阅读性和可维护性。...SQL语言分类 1.DDL(Data Definition Language):数据定义语言; 常见关键字:CREATE DROP ALTER 2.DML(Data Manipulate Language

2.5K10

sql数据库优化

SQL 执行的指导思想是什么? SQL 执行计划的正确依赖选择依赖于什么?统计信息为什么在 SQL 执行中起到关键性的作用?如何才能自动化收集统计信息?让 一起了解 SQL 执行优化的核心底座。...第一步就是 的用户业务在发送一个 SQL 语句到数据库,它首先是要经过解析器,通过词法分析,语法分析生成一个语法树,拿到了语法树以后,把它交给这个 SQL 的优化器,根据语法树看你要是做要查询哪些表,...接下来看一下统计信息在思维语句当中的一个这个层次关系,因为 进行数据库操作都使用SQL 语言,它也是一个结构化查询语言,它是一个高度的,并且是非过程化的一个编程语言。...既然是由于数据库内部自动完成了,因为 有很多不同的路径去选择,不同的操作方式去选择,那如何选择一个最优的?就是一个问题。...这是如果是复杂的一个场景,复杂 SQL 是这样计算的,如果是一个简单的SQL,比如说这个 SQL 我已经确定到,确定根据这个统计信息确定数据落在某一个 DN 上,就可以把这个 SQL 语句直接发到具体的

15200

小型数据库 RMAN CATALOG 备份恢复方案(二)

小型数据库呈现的是数据库并发少,数据库容量小,版本功能受限以及N多单实例等特点。尽管如此,数据库的损失程度也会存在零丢失的情形。...企业不愿意花太多的钱又要保证数据库的可靠稳定,可是苦煞了我这些搞DB的。接上一篇文章,中小型数据库 RMAN CATALOG 备份恢复方案(一),我们继续来给出基于中小型数据库的恢复的脚本与其部署。...1、RMAN还原shell脚本 --下面的shell脚本用于实现数据库的自动还原,还原成功后,数据库被关闭。...因为我们在Prod数据库无异常的情形下,不需要bak 的备用库open --shell脚本做还原时调用了catalog中的全局脚本global_restore --在脚本最尾部,我们将DB还原是否成功的状态输出到日志文件

48010

小型数据库 RMAN CATALOG 备份恢复方案(一)

对于数据库的稳定性,高可用,跨平台以及海量数据库的处理,Oracle 数据库通常是大型数据库和大企业的首选。...尽管如此,仍然不乏很多中小企业想要品尝一下Oracle腥味,因此在Oracle环境中也有不少中小型数据库。出于成本的考虑,通常有可能就搞个标准版了,跑在Linux上。谁叫Oracle太贵呢?...:建议对恢复目录数据库备份,方案多样不表 3、创建恢复目录数据库及其脚本       由于Prod服务器数据库较多,因此创建恢复目录数据库。...set limit channel ch2 kbytes=2048000; crosscheck archivelog all; delete noprompt archivelog all; sql...global script global_restore; printing stored global script: global_restore { restore controlfile; sql

81610

数据库数据库优化(SQL优化)

数据库数据库优化(SQL优化) sql语句优化 1.查询的模糊匹配 尽量避免在一个复杂查询里面使用 LIKE '%parm1%'—— 红色标识位置的百分号会导致相关列的索引无法使用,最好不要用。...排序 避免使用耗费资源的操作,带有DISTINCT,UNION,MINUS,INTERSECT,ORDER BY的SQL语句会启动SQL引擎 执行,耗费资源的排序(SORT)功能....b) 用下面的语句替换: select num from a where exists(select 1 from b where num=a.num) 23.并不是所有索引对查询都有效,SQL...是根据表中数据来进行查询优化的,当索引列有大量数据重复时,SQL查询可能不会去利用索引, 如一表中有字段sex,male、female几乎各一半,那么即使在sex上建了索引也对查询效率起不了作用。

5K40

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券