HANA开发指南
建模方面
1、建模方式:图像化建模、SQL建模、CE语言建模
2、维护:SQL和CE比图形化建模更容易维护和修改
3、性能:图形化和CE会经过系统优化,性能一般优于SQL语言
4、可按需要设置参数、变量、Hierachy、聚合类型等
5、在S4系统里,HANA View可配合CDS视图使用,效果不错
6、计算视图节点有Projection、Join、Union、Rank、Aggregation,其中Rank主要用作按维度排序和取前几行
7、为减少重复工作,建模层次应该遵循基础层、转换层、集市层、报表层等类似于BW模型的规范
8、属性视图类似于BW infoObject的属性、分析视图类似于BW DSO、计算视图类似于BW CUBE
9、建模应该考虑性能,影响性能主要有:层次间传输的数据量、Join操作、Query Result、复合表达式(IF、CASE)和Intermediate results(需要耗费时间写入缓存)
10、CE语言:CE_COLUMN_TABLE、CE_JOIN_VIEW、CE_OLAP_VIEW、CE_CALC_VIEW、CE_JOIN、CE_PROJECTION、CE_CALC、CE_AGGREGATION、CE_UNION、CE_RANK
11、Input Parameter用于参数化或Filter,Variable用于FIlter
SQL和存储过程方面
1、SQL可CREATE或者DELETE Data Type、Function、Procedure
2、Procedure属性READS SQL DATA(只读)、LANGUAGE(指定语言、默认SQLScript)、WITH RESULT VIEW(可直接在SQL中使用Procedure的输出参数)
3、可使用SQL EDITOR或者在Content package中创建
4、可使用控制语句:WHILE、FOR、IF、CASE等
性能优化方面
1、尽量在底层Filter数据
2、在OLAP和Join Engine执行Join,最好使用Key Column或者Index Column进行Join
3、在聚合前,不要进行计算
4、不通的Engine(Join、OLAP、Calculation)之间使用聚合方式减少数据传输,
5、聚合后执行计算、并尽量避免复合表达式(IF、CASE)
6、使用HAVING、TOP、LIMIT尽量避免输出结果数据量过大
7、Join应该在属性视图或者分析视图执行而不是在计算视图进行
8、Left Join比Inner Join更快
9、不要使用CURSOR,因为无法并行执行
10、避免使用Casting、mixed script
11、使用Visualize Plan 可查看HANA执行的过程和耗时
12、可在HANA中开启SQL Trace监控和分析SQL执行情况
ABAP调用方面
1、可使用第二数据库连接HANA:
SELECT * INTO FROM TABLE CONNECTION LV_DBCON_NAME
2、可使用NativeSQL:
EXEC SQL ENDEXEC或者CL_SQL_CONNECTION、CL_SQL_STATEMENT、CL_SQL_RESULT_SET
3、功能代码下沉到HANA中计算,而不是在ABAP中计算
4、减少数据传输到应用层
5、使用CDS、AMDP等可在应用层开发
用户和权限管理方面
1、权限分为:OBJECT SQL权限、Package权限、System权限、分析权限
2、OBJECT SQL权限:SELECT、UPDATE、DELETE、CALL
3、Package权限:access packages in the repository
4、System权限:Create or Change Schema、User、Role
5、分析权限:Row-level Authorization View
6、分析权限参考文章:https://www.cnblogs.com/omygod/archive/2013/05/01/3052739.html
7、动态分析权限参考文章:https://archive.sap.com/documents/docs/DOC-65734
集成方面
1、集成方式有SLT、SDA、SDI、Data Service、Vora等
2、和ERP或者Oracle、SQLServer等可以使用SLT
3、和Hadoop集成可以使用SDA、SDI、Vora
4、SDA:虚拟表,SQL直接在对方系统执行
5、SDI:实体表,对方系统的表更新实时同步到HANA中
6、Vora:可以读取,也可以回写,功能强大
SQL语法方面
1、数据类型:DATE(日期) 、TIME(时间) 、SECONDDATE(日期+时间)、 TIMESTAMP(时戳) 、TINYINT、 SMALLINT 、INTEGER 、BIGINT 、DEC( p, s)、SMALLDECIMAL 、REAL 、DOUBLE 、FLOAT( n )、VARCHAR 、NVARCHAR 、ALPHANUM 、SHORTTEXT 、VARBINARY 、BLOB 、CLOB 、NCLOB 、TEXT
2、谓词:= 、!=、 >、 <、 <>、 <=、 >=、 BETWEEN、 IN、 EXISTS、 LIKE、 NULL、 CONTRAINS( select * from T where CONTAINS( (column1,column2,column3), 'cats OR dogz', FUZZY(0.7)) )
3、合并操作UNION、UNION ALL、INTERSECT(交集)、EXCEPT(差集)
4、函数:CAST、TO_DATS、TO_INT、TO_VARCHAR、ADD_DAYS、LAST_DAY、DAYS_BETWEEN、CURRENT_UTCTIMESTAMP、NEXT_DAY、NOW、ABS、CEIL、GREATEST、LEAST、LOG、MOD、POWER、ROUND、CONCAT、LEFT、LPAD、LTRIM、REPLACE、UCASE、CURRENT_SCHEMA、NULLIF、SESSION_CONTEXT等
5、正则表达式:LIKE_REGEXPR、SUBSTRING_REGEXPR、OCCURRENCES_REGEXPR、REPLACE_REGEXPR
PAL方面
1、PAL主要用于数据预测与分析、针对大数据量
2、PAL函数主要包括:聚类、分类、关联分析、时间序列分析、统计分析
3、使用步骤:
1)生成AFL_WRAPPER_GENERATOR 与 AFL_WRAPPER_ERASER存储过程
2)生成算法的实例,CALL SYSTEM.AFL_WRAPPER_GENERATOR( '<procedure_name>', '<area_name>','<function_name>', <signature_table>);
3)调用算法实例 CALL <procedure_name>
XS方面
1、可根据View创建OData
2、可创建XSJS服务,UI5应用等
相关文章:
HANA开发指南
建模方面 1、建模方式:图像化建模、SQL建模、CE语言建模 2、维护:SQL和CE比图形化建模更容易维护和修改 3、性能:图形化和CE会经过系统优化,性能一般优于SQL语言 4、可按需要设置参数、变量、Hierachy、聚合类型等 5、在S4系…...

请问你见过吐代码的泡泡吗(冒泡排序)
🤩本文作者:大家好,我是paperjie,感谢你阅读本文,欢迎一建三连哦。 🥰内容专栏:这里是《算法详解》,笔者用重金(时间和精力)打造,将算法知识一网打尽,希望可以…...

【VM服务管家】VM4.0平台SDK_2.1环境配置类
目录 2.1.1 环境配置:CSharp二次开发环境配置方法2.1.2 环境配置:Qt二次开发环境配置方法2.1.3 环境配置:MFC二次开发环境配置方法2.1.4 环境配置:VB.Net二次开发环境配置方法2.1.5 环境配置:运行出现Vm.Core.Solution…...

最新研究:可审计的具有拜占庭鲁棒的联邦学习方案
Y. Liang, Y. Li and B. -S. Shin, “Auditable Federated Learning With Byzantine Robustness,” in IEEE Transactions on Computational Social Systems, doi: 10.1109/TCSS.2023.3266019. 可免费下载:https://download.csdn.net/download/liangyihuai/87727720…...

JDK1.8下载、安装和环境配置教程
🎉🎉🎉点进来你就是我的人了博主主页:🙈🙈🙈戳一戳,欢迎大佬指点! 欢迎志同道合的朋友一起加油喔🦾🦾 目录 window系统安装java 下载JDK 配置环境变量 …...
天津超算,青索帮助文档
连接 第一步,点击 配置VPN(切换到局域网用)和机器(也就是各套超算系统)。 第二步,点击 机器 选择对应的机器。通常会在下方显示可用的机器,单击其中一个即可。如果只有一个机器,…...
SpringMVC的拦截器和异常处理器
目录 lerInterceptor 拦截器 1、拦截器的作用 2、拦截器的创建 3、拦截器的三个抽象方法 4、拦截器的配置 5、多个拦截器的执行顺序 SpringMVC的异常处理器 1、异常处理器概述 2、基于配置文件的异常处理 3、基于注解的异常处理 lerInterceptor 拦截器 1、拦截器的作…...

查看库文件是32位还是64位|查看lib是静态库还是导入库|判断是debug模式还是release模式
文章目录 dll位数查看lib位数查看查看lib库是静态库还是导入库dll库文件信息查看lib库文件内容查看dll库查看编译模式是debug还是release方法一方法二方法三 lib静态库查看编译模式是debug还是release方法一方法二 lib导入库查看编译模式是debug还是release查看Linux下的.a库&a…...

Python小姿势 - Python爬取数据的库——Scrapy
Python爬取数据的库——Scrapy 一、爬虫的基本原理 爬虫的基本原理就是模拟人的行为,使用指定的工具和方法访问网站,然后把网站上的内容抓取到本地来。 爬虫的基本步骤: 1、获取URL地址: 2、发送请求获取网页源码; 3、…...

[C++初阶]栈和队列_优先级队列的模拟实现 deque类 的理解
为了更好的理解优先级队列priority_queue,这里会同时进行栈和队列的提及 文章目录 简要概念(栈和队列)栈和队列的模拟实现与使用stack(栈)deque的理解和操作queue priority_queue(优先级队列)框…...

Spring是什么?关于Spring家族
初识Spring 什么是Spring? Spring是一个开源的Java企业级应用程序开发框架,由Rod Johnson于2003年创建,并在接下来的几年里得到了广泛的发展和应用。它提供了一系列面向对象的编程和配置模型,支持开发各种类型的应用程序&#x…...
自然语言处理数据集集锦(持续更新ing...)
诸神缄默不语-个人CSDN博文目录 最近更新时间:2023.4.26 最早更新时间:2023.4.25 文本摘要主题的数据集见我之前写的另一篇博文:文本摘要数据集的整理、总结及介绍(持续更新ing…) 智能司法主题的数据集我准备等项目…...

93、Dehazing-NeRF: Neural Radiance Fields from Hazy Images
简介 论文:https://arxiv.org/pdf/2304.11448.pdf 从模糊图像输入中恢复清晰NeRF 使用大气散射模型模拟有雾图像的物理成像过程,联合学习大气散射模型和干净的NeRF模型,用于图像去雾和新视图合成 通过将NeRF 3D场景的深度估计与大气散射模…...
JAVA子类与继承
目录 JAVA子类与继承 一、子类与父类: 二、子类与对象 三、成员变量的隐藏和方法重写 四、super关键字(P122) 五、final关键字 六、对象的上转型对象(P126) 七、继承与多态(P128) 八、abstract类和…...

62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库
文章目录 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库62.1 创建数据库示例 62.2 查看数据库示例 62.3 选择数据库示例 62.4 删除数据库示例 62.5 备份数据库示例 62.6 恢复数据库示例 62 openEuler 22.03-LTS 搭建MySQL数据库服务器-管理数据库 62.1 创建数据库…...

【分布式搜索引擎ES01】
分布式搜索引擎ES 分布式搜索引擎ES1.elasticsearch概念1.1.ES起源1.2.倒排索引1.2.1.正向索引1.2.2.倒排索引 1.3.es的一些概念1.3.1.文档和字段1.3.2.索引和映射1.3.3.mysql与elasticsearch 1.4.1安装es、kibana、IK分词器1.4.2扩展词词典与停用词词典 2.索引库操作2.1.mappi…...
1.3 鞅、停时和域流-鞅(布朗运动与随机计算【习题解答】)
Let X = ( x n , F n ) , n = 1 , ⋯ , N X=\left(x_n, \mathcal{F}_n\right), n=1, \cdots, N X...

十、ElasticSearch 实战 - 源码运行
一、概述 想深入理解 Elasticsearch,了解其报错机制,并有针对性的调整参数,阅读其源码是很有必要的。此外,了解优秀开源项目的代码架构,能够提高个人的代码架构能力 阅读 Elasticsearch 源码的第一步是搭建调试环境&…...

GPT-3 论文阅读笔记
GPT-3模型出自论文《Language Models are Few-Shot Learners》是OpenAI在2020年5月发布的。 论文摘要翻译:最近的工作表明,通过对大量文本进行预训练,然后对特定任务进行微调(fine-tuning),在许多NLP任务和基准测试上…...

方案解析丨数字人主播如何成为电商直播新标配
浙江省政府办公厅近日印发《关于进一步扩大消费促进高质量发展若干举措》支持电子商务直播发展。抢抓电子商务直播快速发展机遇,发展数字人虚拟主播、元宇宙新消费场景等新业态新模式。 随着电商直播快速发展,企业怎么高效地实现引流获客,成为…...

龙虎榜——20250610
上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...

蓝牙 BLE 扫描面试题大全(2):进阶面试题与实战演练
前文覆盖了 BLE 扫描的基础概念与经典问题蓝牙 BLE 扫描面试题大全(1):从基础到实战的深度解析-CSDN博客,但实际面试中,企业更关注候选人对复杂场景的应对能力(如多设备并发扫描、低功耗与高发现率的平衡)和前沿技术的…...

令牌桶 滑动窗口->限流 分布式信号量->限并发的原理 lua脚本分析介绍
文章目录 前言限流限制并发的实际理解限流令牌桶代码实现结果分析令牌桶lua的模拟实现原理总结: 滑动窗口代码实现结果分析lua脚本原理解析 限并发分布式信号量代码实现结果分析lua脚本实现原理 双注解去实现限流 并发结果分析: 实际业务去理解体会统一注…...

零基础设计模式——行为型模式 - 责任链模式
第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...

select、poll、epoll 与 Reactor 模式
在高并发网络编程领域,高效处理大量连接和 I/O 事件是系统性能的关键。select、poll、epoll 作为 I/O 多路复用技术的代表,以及基于它们实现的 Reactor 模式,为开发者提供了强大的工具。本文将深入探讨这些技术的底层原理、优缺点。 一、I…...
.Net Framework 4/C# 关键字(非常用,持续更新...)
一、is 关键字 is 关键字用于检查对象是否于给定类型兼容,如果兼容将返回 true,如果不兼容则返回 false,在进行类型转换前,可以先使用 is 关键字判断对象是否与指定类型兼容,如果兼容才进行转换,这样的转换是安全的。 例如有:首先创建一个字符串对象,然后将字符串对象隐…...

DingDing机器人群消息推送
文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人,点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置,详见说明文档 成功后,记录Webhook 2 API文档说明 点击设置说明 查看自…...
【Nginx】使用 Nginx+Lua 实现基于 IP 的访问频率限制
使用 NginxLua 实现基于 IP 的访问频率限制 在高并发场景下,限制某个 IP 的访问频率是非常重要的,可以有效防止恶意攻击或错误配置导致的服务宕机。以下是一个详细的实现方案,使用 Nginx 和 Lua 脚本结合 Redis 来实现基于 IP 的访问频率限制…...

uniapp 小程序 学习(一)
利用Hbuilder 创建项目 运行到内置浏览器看效果 下载微信小程序 安装到Hbuilder 下载地址 :开发者工具默认安装 设置服务端口号 在Hbuilder中设置微信小程序 配置 找到运行设置,将微信开发者工具放入到Hbuilder中, 打开后出现 如下 bug 解…...