K,K线,Candle蜡烛图。

T,技术分析,工具平台

L,公式Language语言使用c++14,Lite小巧简易。

项目仓库:https://github.com/bbqz007/KTL

国内仓库:https://gitee.com/bbqz007/KTL

CoreAnimation for Windows: https://github.com/bbqz007/xw

zqt5 一个超简单的Qt5窗口语法: https://github.com/bbqz007/zhelper-qt5Widgets

zqlite3 一个超简单的流式语法,整合封装Sqlite3 capis 与 SQL 跟 c/c++程序绑定:https://github.com/bbqz007/sqlite3zz

KTL提供一个c++14编译平台,用户可以使用c++14编辑自定义技术指标等。

用户可以使用crt常用函数,c++标准库容器以及算法,c++14特性编程。

本期更新内容

添加方差等统计函数。

支持sqlite3 capi。

全新sqlite3zz流式语法,超简单使用sqlite3 capi,轻松绑定SQL跟c/c++程序

本平台在本期主要添加对sqlite3支持。

用户可以使用sqlite3存入结果,加载数据,分析数据等。

为方便使用sqlite3 capi,本平台开发了一个全新的sqlite3zz流式语法。

也许你是SQL高手,但是sqlite3 capi太繁琐,无法集中业务逻辑。

也许你轻舟熟驾CREATE, INSERT, UPDATE, SELECT,但是妨碍于不知如何整合在c/c++程序中运行,并绑定参数或结果。

也许太多问号要绑定,SQL语句是否写对了问号数量。

也许你忘了绑定的起始是0还是1,查文档调试太不想。

也许..., 还有一千零一个理由让你觉得麻烦。

现在本平台提供一个全新的sqlite3zz流式语法。

1. 对于基本的SQL语法应用,你甚至不用写任何SQL语句,也不必要认识SQL语法。

2. 简化批量插入更新流程。

3. 完全c++代码定义表结构。

4. 输出流(out << val)绑定参数变量。

5. 输入流(in >> val)输出结果到变量。

6. 自动生成SQL语句。

7. 编译期静态检测类型绑定。

示例1,c++代码定义表结构。

1   auto tbl2 = make_zqlite3_table(
2 select_para<int>("1"),
3 select_para<string>("2"),
4 select_para<double>("dbl"),
5 select_para<vector<char>>("blob"),
6 index_para("1", "2"),
7 index_para("1", "2"));
8
9

示例2,自动生成SQL语句

1     cout << tbl2.create_table_statment("abc") << endl;
2 cout << tbl2.insert_statment("abc") << endl;
3 cout << tbl2.update_statment("abc") << endl;
4 cout << tbl2.select_statment("abc") << endl;
1 CREATE TABLE IF NOT EXISTS `abc` (`1` INTEGER, `2` VARCHAR, `dbl` REAL, `blob` BLOB, UNIQUE (`1`  DESC, `2`  DESC), UNIQUE (`1`  DESC, `2`  DESC));
2 INSERT INTO `abc` (`1`, `2`, `dbl`, `blob`) VALUES (?,?,?,?);
3 UPDATE `abc` SET `1` = ?, `2` = ?, `dbl` = ?, `blob` = ?;
4 SELECT `1`, `2`, `dbl`, `blob` FROM `abc` ;

示例3,输出流绑定参数变量,批量插入更新。

 1     tbl2.open_db("db");
2 tbl2.create_table("abc");
3 {
4 auto oz = tbl2.insert_into("abc");
5 auto ou = tbl2.update_where("abc", "where `1`=? AND `2` = ?");
6 oz.begin_trans();
7 oz(1, "2", 4., {0, 0});
8 oz << 2 << "e" << 1. << make_pair((char*)NULL, 0) << ios_base::end;
9 if (oz.ignored())
10 ou << 2 << "e" << 1. << make_pair((char*)NULL, 0) << where_para<int>(2) << where_para<string>("e") << ios_base::end;
11 oz.commit_trans();
12 }

示例4,输入流查询count(0)输入到变量。

1 auto cnttbl = make_zqlite3_table(select_para<int>("count(0)").expr());
2 cnttbl.open_db("db");
3 {
4 //// select statment would not lock the database until finalized.
5 auto iz6 = cnttbl.select_from("abc");
6 int cnt = 0;
7 iz6 >> ios_base::beg >> cnt >> ios_base::end;
8 cout << cnt << endl;
9 }

对于上面4个示例,涉及create, insert, update, select的基本使用,完全可以不与SQL语法还有sqltie3 capi打交道。

示例5,输入流查询内联。

 1 auto join = make_zqlite3_table(
2 select_para<int>("a.`1`").expr(),
3 select_para<int>("b.`double`").expr());
4 5 join.open_db("db");
6 {
7 auto ij = join.select_from2("abc a, table1 b limit 1");
8 auto row = join.create_row();
9 ij >> ios_base::beg;
10 for (; !ij.eof(); ij >> ios_base::beg)
11 {
12 ij >> std::get<0>(row)
13 >> std::get<1>(row)
14 >> ios_base::end;
16 cout << std::get<0>(row) << ", "
17 << std::get<1>(row) << endl;
18 }
19 }

下期更新更加精彩。

KTL 一个支持C++14编辑公式的K线技术工具平台 - 第五版,支持sqlite3,全新sqlite3zz语法超简单使用sqlite3; 添加方差等统计函数。的更多相关文章

  1. KTL 一个支持C++14编辑公式的K线技术工具平台 - 第六版,支持OpenGL,3D上帝视角俯视K线概貌。

    K,K线,Candle蜡烛图. T,技术分析,工具平台 L,公式Language语言使用c++14,Lite小巧简易. 项目仓库:https://github.com/bbqz007/KTL 国内仓库 ...

  2. KTL 一个支持C++14编辑公式的K线技术工具平台 - 第七版,体验GPGPU。

    K,K线,Candle蜡烛图. T,技术分析,工具平台 L,公式Language语言使用c++14,Lite小巧简易. 项目仓库:https://github.com/bbqz007/KTL 国内仓库 ...

  3. KTL 一个支持C++14编辑公式的K线技术工具平台 - 第四版,稳定支持Qt5编程,zqt5语法升级,MA函数提升性能1000%,更多公式算法的内置优化实现。

    K,K线,Candle蜡烛图. T,技术分析,工具平台 L,公式Language语言使用c++14,Lite小巧简易. 项目仓库:https://github.com/bbqz007/KTL 国内仓库 ...

  4. 小白学Python(14)——pyecharts 绘制K线图 Kline/Candlestick

    Kline-基本示例 from pyecharts import options as opts from pyecharts.charts import Kline data = [ [2320.2 ...

  5. 打造支持apk下载和html5缓存的 IIS(配合一个超简单的android APP使用)具体解释

    为什么要做这个看起来不靠谱的东西呢? 由于刚学android开发,还不能非常好的熟练控制android界面的编辑和操作,所以我的一个急着要的运用就改为html5版本号了,反正这个运用也是须要从serv ...

  6. SQL点滴14—编辑数据

    原文:SQL点滴14-编辑数据 数据库中的数据编辑是我们遇到的最频繁的工作,这一个随笔中我来总结一下最常用的数据编辑. select into 经常遇到一种情况是,我们希望创建一个新表,表中的数据来源 ...

  7. 在Office上怎么用MathType编辑公式

    随着无纸化的办公程序越来越深入普及到社会的各个层面,很多资料都是电子档.从前手写的内容全都转换到了电脑上.用Office办公时,有一个很大的问题,那就是其中的公式要怎么编辑? 从前用手写毫无困难,什么 ...

  8. 怎么让Word编辑公式又快又好

    现在很多办公学习都是在电脑中进行的.很多文件论文都是在Word中编写定稿以后再打印成册或者去投稿.毫无疑问,在Word中编辑各种各样的文字与符号是一项现在社会中非常必要的技能,而这其中一项就是对公式的 ...

  9. Word中怎么用MathType编辑公式

    现如今,用电脑办公学习已经是一个不可阻挡的潮流.而与之相应的就是需要在这些办公软件进行相应的使用,最典型的一种就是要在Word编辑公式.其实在Word中编辑公式是一个很常见的事情,虽然它很常见,但是却 ...

随机推荐

  1. 74CMS 3.0任意文件写入漏洞

    一. 启动环境 1.双击运行桌面phpstudy.exe软件 2.点击启动按钮,启动服务器环境 二.代码审计 1.双击启动桌面Seay源代码审计系统软件 2.因为74CMS3.0源代码编辑使用GBK编 ...

  2. MySQL&SQL server&Oracle&Access&PostgreSQL数据库sql注入详解

    判断数据库的类型 当我们通过一些测试,发现存在SQL注入之后,首先要做的就是判断数据库的类型. 常用的数据库有MySQL.Access.SQLServer.Oracle.PostgreSQL.虽然绝大 ...

  3. Snort中pcre和正则表达式的使用

    Snort中pcre和正则表达式的使用 1. 题目描述 If snort see two packets in a TCP flow with first packet has "login ...

  4. SpringBoot与SpringCloud的关系与区别?

    一.SpringBoot和SpringCloud简介 1.SpringBoot:是一个快速开发框架,通过用MAVEN依赖的继承方式,帮助我们快速整合第三方常用框架,完全采用注解化(使用注解方式启动Sp ...

  5. spring源码-扩展点

    /** * @Author quan * @Date 2020/11/13 * 扩展原理 * BeanPostProcessor bean后置处理器,bean创建对象初始化前后进行拦截工作 * * * ...

  6. 什么是bean装配?

    装配,或bean 装配是指在Spring 容器中把bean组装到一起,前提是容器需要知道bean的依赖关系,如何通过依赖注入来把它们装配到一起.

  7. 说出几点 Java 中使用 Collections 的最佳实践?

    这是我在使用 Java 中 Collectionc 类的一些最佳实践: a)使用正确的集合类,例如,如果不需要同步列表,使用 ArrayList 而不是 Vector. b)优先使用并发集合,而不是对 ...

  8. 顺利通过EMC实验(7)

  9. vue配置请求转发解决跨域问题

    通过nodejs的请求转发到后台,前端地址:http://localhost:8080   后端地址:http://localhost:8081 vue.config.js内容如下: let prox ...

  10. java中的方法(method)到底怎么用?给个例子

    7.方法(method)   被调例子, int add(int x, int y){ return x+y; } 主调例子, for example: int result = add(5,3); ...