delphi xe -芒果数据库(FDConnection,DataSource,FDMongoQuery,FDMongoDataSet)连接,查询(展示数据),这里有mongodb为例子
一、连接
1、FDConnection:创建一个临时连接定义
资料:http://www.cnblogs.com/zhenfei/p/4105515.html
连接芒果数据库:选则Mongo(芒果),服务器地址。

2、FDMongoQuery:与数据库、表关联,并与上面的Connection连接。
直接选择连接

代码连接

FDMongoQuery1.Close;
FDMongoQuery1.FieldDefs.Clear;
// Setup new connection
FDMongoQuery1.DatabaseName := EditDatabase.Text;
FDMongoQuery1.CollectionName := EditCollection.Text;
FDMongoQuery1.QMatch := EditMatch.Text;//查询条件
FDMongoQuery1.QSort := EditSort.Text;//排序
FDMongoQuery1.QProject := EditProjection.Text;//显示字段(0不显示,1显示)
dsQuery.DataSet := FDMongoQuery1;
FDMongoQuery1.Open;
FDMongoQuery1.FieldDefs.Count;//最外层字段个数
FDMongoQuery1.FindField("grades") != NULL//找到某字段
FDMongoGQ_devch.QProject:='{"name":1}';//要显示的字段
FDMongoGQ_devch.QProject:='{"vdev.channels.2":0,"vdev.channels.32dplqsx":0}';//不要显示整个内嵌
FDMongoGQ_devch.FindField('_id').Visible:=False;//隐藏不需要显示的字段
例子:


procedure TFrm_0201_dev.ds_CHSDataChange(Sender: TObject; Field: TField);
var
sdev,sch,styep:string;
begin
if(dbgrd_ch.DataSource.DataSet.FieldByName('_id').Value<>null) then
begin
sdev:=dbgrd_ch.DataSource.DataSet.FieldByName('dev').Value;
sch:=dbgrd_ch.DataSource.DataSet.FieldByName('ch').Value;
styep:=dbgrd_dev.DataSource.DataSet.FieldByName('type').Value;
if(styep='VIRTUAL')then
begin
FDMongoGQ_devch.Close;
FDMongoGQ_devch.Query.Options.Explain := False;
FDMongoGQ_devch.FieldDefs.Clear;
FDMongoGQ_devch.QMatch:='{"dev":'''+sdev+'''}';
FDMongoGQ_devch.QProject:='{"vdev.channels.'+sch+'.inputs" :1,"vdev.channels.'+sch+'.unit":1}';
ds_devch.DataSet := FDMongoGQ_devch;
FDMongoGQ_devch.Open;
FDMongoGQ_devch.FindField('_id').Visible:=False;
FDMongoGQ_devch.FindField('vdev').Visible:=False;
FDMongoGQ_devch.FindField('vdev.channels').Visible:=False;
FDMongoGQ_devch.FindField('vdev.channels.'+sch+'').Visible:=False;
end;
end
else Exit;
end;
二、批量修改,最后统一保存
cachedUpdates :true;//试过可以
3、DataSource:数据源控件用于数据集控件和数据显示控件的链接作用,比如grid 等一些数据显示控件都有 datasource 属性。

4、将grid与datasource连接就可以了。
5、为空时:if(FDMongoGQ_phdev.IsEmpty and (FDMongoGQ_phdev.FieldDefList.Count = 1)) then exit;
二、查询
1、一个grid查询
procedure TFrm_0201_dev.Act_QueryExecute(Sender: TObject);
var
q:TMongoWireQuery;
d:IJSONDocument;
i:Integer;
begin
BuildQuery;
FDMongoQuery1.Open;
end;
procedure TFrm_0201_dev.BuildQuery;
var
scondition :string;
begin
if(Trim(edt_dev.Text)<>'') then
scondition:=' {"dev" :{$regex:'+''''+edt_dev.Text+''''+'}}'//正则表达式:进行模糊查询
FDMongoQuery1.Close;
FDMongoQuery1.Query.Options.Explain := False;
FDMongoQuery1.FieldDefs.Clear;
FDMongoQuery1.QMatch := scondition;
end;
2、两个grid联动
procedure TFrm_0201_dev.DataSourceDataChange(Sender: TObject; Field: TField);
var
DataSetField: TDataSetField;
begin
BuildQuery1;
FDMongoQuery2.Open;
if(FDMongoQuery2.FindField('tags') <>nil) then
begin
DataSetField :=FDMongoQuery2.FieldByName('tags') as TDataSetField;//这个是数据集,后面会讲到,用来展示数组
ds_tags.DataSet := DataSetField.NestedDataSet;
end;
end;
procedure TFrm_0201_dev.BuildQuery1;
var
scondition:string;
begin
sID:= DBGrid1.DataSource.DataSet.FieldByName('_id').Value ;
FDMongoQuery2.Close;
FDMongoQuery2.Query.Options.Explain := False;
FDMongoQuery2.FieldDefs.Clear;
FDMongoQuery2.QMatch:='{"dev":'''+sID+'''}';//查询条件
DataSource1.DataSet := FDMongoQuery2;
end;
3、芒果数据库里,数组的展示,用到TDataSetField
网上的图

自己的例子,如tags数组

procedure TFrm_0201_dev.DataSourceDataChange(Sender: TObject; Field: TField);
var
DataSetField: TDataSetField;
begin
BuildQuery1;
FDMongoQuery2.Open;
if(FDMongoQuery2.FindField('tags') <>nil) then
begin
DataSetField :=FDMongoQuery2.FieldByName('tags') as TDataSetField;
ds_tags.DataSet := DataSetField.NestedDataSet;
end;
end;
delphi xe -芒果数据库(FDConnection,DataSource,FDMongoQuery,FDMongoDataSet)连接,查询(展示数据),这里有mongodb为例子的更多相关文章
- DELPHI XE MYSQL数据库操作类 MYSQLHELPER
注: 无需odbc配置 {* * MySQL Helper v1.0 * 2015.6.19 * 说明: * 这是一个操作MySQL的类,该类必须和libmysql.dll,dbxmys.dll两个文 ...
- 三十二:数据库之SQLAlchemy.query函数可查询的数据和聚合函数
准备工作 from sqlalchemy import create_engine, Column, Integer, String, Floatfrom sqlalchemy.ext.declara ...
- Delphi XE中使用dbExpress连接MySQL数据库疑难问题解决(对三层的例子配置有帮助)
Delphi IDE中包含一个Data Explorer的组件,如下图所示: 该组件基于dbExpress(包含TSQLConnection.TSQLDataSet.TSQLQuery.TSQLSto ...
- Delphi XE中使用dbExpress连接MySQL数据库疑难问题解决
Delphi IDE中包含一个Data Explorer的组件,如下图所示: 该组件基于dbExpress(包含TSQLConnection.TSQLDataSet.TSQLQuery.TSQLSto ...
- Delphi XE 10 跨平台三层数据库应用教程
Delphi XE 10 跨平台三层数据库应用教程 前言: Delphi XE 开始越来越庞大,比经典的Delphi7难用,但依然是目前所有跨平台开发工具中开发效率最高.最容易上手的,其快速设计RAD ...
- delphi 2010与delphi XE破解版的冲突
在系统中同时安装了Dephi 2010LITE版与Delphi XE lite后,总是会有一个有问题 是因为两者都是读取C:\ProgramData\Embarcadero目录下的license文件, ...
- [转载]: delphi中XLSReadWrite控件的使用(2)---delphi XE下安装
一.下载 官方下载网址: http://www.axolot.com/components/download.htm 从这里可以下载到从Delphi5到DelphiXE全部支持的版本. 二.软件安装 ...
- delphi XE Berlin ReadProcessMemory WriteProcessMemory
delphi XE,Berlin [dcc32 Error] Unit9.pas(93): E2033 Types of actual and formal var parameters must ...
- FastReport for delphi xe 安装步骤
FastReport for delphi xe 安装步骤 1.先关闭DELPHI:2.下载后解压到一个目录,比如:D:FR:3.打开D:FR,运行recompile.exe ->点击" ...
随机推荐
- scrapy抓取的中文结果乱码解决办法
使用scrapy抓取的结果,中文默认是Unicode,无法显示中文. 中文默认是Unicode,如: \u5317\u4eac\u5927\u5b66 在setting文件中设置: FEED_EXPO ...
- 静态资源打包:一个javescript 的src引用多个文件,一个link引用多个CSS文件
疑惑描述: 查看了淘宝网的首页源文件,看到这样的一个特殊的 <script src="http://a.tbcdn.cn/??s/kissy/1.1.6/kissy-min.js,p/ ...
- [k8s]kubectl windows配置(kubernetic) && kubectl config set-context使用Kubernetic
参考: https://feisky.gitbooks.io/kubernetes/components/kubectl.html https://kubernetes.io/docs/tasks/t ...
- [svc][op]如何查看当前Ubuntu系统的版本
如何查看当前Ubuntu系统的版本 说来也惭愧,用Ubuntu差不多快1个月了,双系统是让朋友安的,只知道自己使用的是什么12版本的,具体怎么看还不知道,下面写一下查看当前Linux系统的版本的方法 ...
- 斑马Zebra ZPLII指令集中文说明解释
我们最常用的斑马(Zebra)条码打印机,应用ZPLII命令来控制打印,说明书中有每条指令的详细说明及相关示例,下面是各指令的中文释义: ^A 对Zebra内置点阵字体缩放 ^A(可缩放/点阵字体 ...
- Ubuntu 的 apt-get 代理设置(zhuan)
url: http://qixinglu.com/post/ubuntu_apt-get_proxy_setup.html 升级到 Ubuntu10.04 后,发现 apt-get 的代理设置有改变了 ...
- python之版本管理
linux 环境下怎样对不同的python环境进行 方便的切换呢?update-alternatives工具能够非常方便的帮我们完成这个任务.而windows环境下可通过anaconda来完成. 1. ...
- SQL基础之聚合与排序
聚合函数是用来求和,平均值,最大最小值一类的函数. 常用的有COUNT.SUM.MAX.MIN.AVG. count() 参数为列名,也可以使用*,表示全部列. 默认*会统计所有行的数据,如果想过滤掉 ...
- php 给图片增加背景平铺水印代码
如果你想利用php 给图片增加背景平铺水印效果话,必须利用php的一个插件来实例,就是利用imagick,他可以给图片增加背景平铺水印效果哦,下面我们提供一款实例代码. 如果你想利用php教程 给图片 ...
- java的锁池和等待池
谢邀.不知道题中的一段文字出自何处.“锁池”和“等待池”这种翻译我还是头一回见.不过,题主的思路已经对了,即不拘泥于文字,而是在考虑这两个东西在锁的调度(即决定哪个线程可以获得锁的过程)中起到什么作用 ...