CYQ.Data V5 文本数据库支持SQL语句操作(实现原理解说)

简介:
CYQ.Data V5版本的文本数据库,以前有过相关的介绍: 周末一起用文本数据库玩玩Code First
数据的存储,是基于json格式或xml格式的,而实现的原理,也有一篇介绍:  CYQ.Data V5文本数据库技术原理解密
前几天实现基本功能后,也写了一篇突发想支持SQL语句的冲突想法的来源:  CYQ.Data 文本数据库解析SQL语法
 
对于文本数据库的原理:简单的说,就4步:
1:存储用json或xml。
2:读取时还原为MDataTable。
3:操作时操作MDataTable实现数据行的变化。
4:保存时重新写为json或xml。
 
PS:当然还有一个CodeFirst模式时自动产生用于记录表结构的"表名.ts"文件。

文本数据库的Where语句分拆: 
原先的功能,有Select( where),这个where是支持sql语句的,简单说就是对where进行了以下分析:
string  where= " id>1 and name like '%a%' order by id desc ";
分析出where,order by ,再分析出id,name及对应的值,循环进行值判断,提取出合适的行。 
从而达到查询的功能。

现在要支持SQL,看似复杂点又提升了点,因为简单的SQL语句大体如下:
Insert into ErrorLogs(PageUrl , ErrorMessage) values( ' http://... ', ' what ''  is the ... ')
Select count(*)  from ErrorLogs...
Select *  from ErrorLogs  where ...
Select id,name  from ErrorLogs ...
Update ErrorLogs  set id= 1 and name= ' name is Mr ''  Right '
Delete From ErrorLogs  where ...
 
对于这些字符串的处理,真是很考基本功:
比如:Insert into ErrorLogs(PageUrl , ErrorMessage) values( ' http://... ', ' what ''  is (the (name))... ')
把这条语句,分拆出:
1:操作:Insert
2: 表名:ErrorLogs
3:PageUrl : " http://... "
4: ErrorMessage : " 'what'' is (the (name))... " 
 
PS:我觉的可以适当的拿来做面试题了。。。。

大体整体的实现,基本上就等同于解析上面的SQL语法,然后回归到MDataTable的原始操作上去,细节就不啰嗦重复了。
 
下面看一下实现后的效果图:
 
项目截图就省略了,页面后台的代码:
  protected  void btnExec_Click( object sender, EventArgs e)
        {
             if (! string.IsNullOrEmpty(txtSql.Text))
            {
                MProc proc =  new MProc(txtSql.Text, txtConn.Text);
                 switch (ddlExeType.SelectedValue)
                {
                     case  " 0 ":
                        labTip.Text = proc.ExeScalar< string>();
                         break;
                     case  " 1 ":
                        labTip.Text = proc.ExeNonQuery().ToString();
                         break;
                     case  " 2 ":
                        MDataTable dt = proc.ExeMDataTable();
                        rptList.DataSource = dt;
                        rptList.DataBind();
                         break;
                }
                proc.Close();
            }
        }
 
上面这段代码很简单,执行指定链接的SQL语句,然后显示相应的信息。
 
操作数据库,基本配置文件里指定日志的链接字符串是必不可少的内容:
<add name= " LogConn "  connectionString= " txt path={0}App_Data " /> 
 
说明:把系统错误日志用文件数据库记录,CYQ.Data V5内置用了CodeFirst方式来实现异常的数据库执行日志错误:
表名为ErrorLogs
4个字段分别为:
1:ID,PageUrl,ErrorMessage,CreateTime。 
 
下面我们看界面:由于我的项目里本身就有日志,我们查询一下:
 
OK,下面我们删除所有数据库,执行成功后删除了5行数据:
再添加一行数据:
 最后更新这行1行数据:
 
 最终再查询显示一次:
 
 
至此,整个基本的SQL语法解析和实现就告终了,至于什么GroupBy,多表,视图,函数之类的,就在文本数据库的能力之外了。
功能的实现自己用两个Table去For还是while去实现自己需要的逻辑。 
 
下面再补充一下ErrogLogs这个日志说明:
默认的CodeFirst,简单说就是你指定哪种数据库类型,就会自动创建相应的表结构,然后把执行SQL的错误信息写到该日志里,方便查询分析和解决。
以前,我习惯把日志的链接写成:
<add name= " LogConn " connectionString= " Conn "/> 
其实就是指向Conn(CYQ.Data默认的主数据库配置顶),这样就把日志表放到和主数据库表同一个数据库。。
结果有时候,如果主数据库挂掉,异常日志就无法记录了,所以建议是存到其它数据库。
但有了文件数据库之后,用文本来存储日志,看似是个不错的选择,而且操作也相当方便。

CodeFirst时,如果有数据(第一条数据产生时,自动根据实体产生了表结构,如果是文本,在指定的目录下出来这个)
 
当然了,除了比较标准的,是自动生成的,如果你是自己手工创建,可以新建一个表名.ts表结构,内容:
 
ID, int;
PageUrl, string;
ErrorMessage, string;
CreateTime,datetime; 
 
 
CYQ.Data V5里文本数据库,实用价值:
 
包括网站站点的广告节点显示,友情链接,一些需要经常或偶尔编辑的Key,Value值等项,存文本数据库是最方便不过了。
有效的把非主站的附加数据,存储到文本数据库,利用文本数据完全内存表机制,高效,节能,又方便。
 
 
CYQ.Data V5在文本数据库、Access、SQLite、XHtmlAction等功能,都是不需要授权可以直接使用的。





     本文转自cyq1162 51CTO博客,原文链接:http://blog.51cto.com/cyq1162/1191805 ,如需转载请自行联系原作者



相关实践学习
基于Hologres轻松玩转一站式实时仓库
本场景介绍如何利用阿里云MaxCompute、实时计算Flink和交互式分析服务Hologres开发离线、实时数据融合分析的数据大屏应用。
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
7天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
45 10
|
24天前
|
SQL 存储 BI
【软件设计师备考 专题 】数据库语言(SQL)
【软件设计师备考 专题 】数据库语言(SQL)
89 0
|
1月前
|
SQL 监控 安全
SQL注入的实现原理以及防止
SQL注入的实现原理以及防止
|
1月前
|
SQL 数据库 数据安全/隐私保护
Sql Server数据库Sa密码如何修改
Sql Server数据库Sa密码如何修改
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
61 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
28天前
|
SQL 数据库
sql server中创建数据库和表的语法
sql server中创建数据库和表的语法
17 1
|
7天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
61 6
|
3天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
3天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
22 3
|
6天前
|
SQL 监控 数据库
数据库管理与电脑监控软件:SQL代码优化与实践
本文探讨了如何优化数据库管理和使用电脑监控软件以提升效率。通过SQL代码优化,如使用索引和调整查询语句,能有效提高数据库性能。同时,合理设计数据库结构,如数据表划分和规范化,也能增强管理效率。此外,利用Python脚本自动化收集系统性能数据,并实时提交至网站,可实现对电脑监控的实时性和有效性。这些方法能提升信息系统稳定性和可靠性,满足用户需求。
29 0