4.星型模式与雪花模式
我们之前看到的在一个事实表上创建数据立方,在事实表上或与事实表join联接的表上创建维度。这是最常见的映射方法,称之为 星型模式。
但一个维度可能是基于一个以上的表格,指定了定义好的与事实表的路径路径。这种维度称之为雪花模式,并使用操作进行定义。举个例子:
< Cube name="Sales">
...
< Dimension name="Product" foreignKey="product_id">
< Hierarchy hasAll="true" primaryKey="product_id" primaryKeyTable="product">
< Join leftKey="product_class_key" rightAlias="product_class" rightKey="product_class_id">
< Table name="product"/>
< Join leftKey="product_type_id" rightKey="product_type_id">
< Table name="product_class"/>
< Table name="product_type"/>
Join >
Join >
Hierarchy >
Dimension >
Cube >
这里定义了一个’product’维度,包含了3个表格。事实表联接’product’表(通过外键product_id),’product’表联接了表’product_class’表(通过外键product_class_id),’product_class’表联接了表’product_type’表(通过外键product_type_id)。我们请求一个嵌套在元素中的元素,因为需要两个操作参数,参数的类型可以是表格,join,或者query查询。
这种表格的安排似乎很复杂,简单的规则是根据表格包含的行数多少来排序。’product’表拥有最多的行,因此它首先联接事实表,并第一个显示;’product_class’行数较少,然后最少的是’product_type’,放在雪花型的最外端。
需要注意的是,外层的元素有一个rightAlias属性,这是必须要有的,因为当前联接的右边的部分包含一个以上的表。这种情况下,leftAlias属性不需要,因为product表中的leftKey列不会出现冲突。
4.1 共享的维度
当针对一个join生成SQL时,Mondiran需要知道join哪个列。如果联接到一个join,那么我们需要告诉Mondrian那个列属于join联接中的哪个表(通常会是join中的第一个表)。
由于共享的维度不属于某个cube数据立方,我们必须为其指定一个显性的表格(或其他数据源)。当我们在某个特定的cube中使用这个共享维度时,我们需要指定foreign key(外键)。下面的例子展示了 Store Type维度通过外键 sales_fact_1997.store_id 联接到了 Sales数据立方,并通过外键 warehouse.warehouse_store_id 联接到了Warehouse 数据立方。
< Dimension name="Store Type">
< Hierarchy hasAll="true" primaryKey="store_id">
< Table name="store"/>
< Level name="Store Type" column="store_type" uniqueMembers="true"/>
Hierarchy >
Dimension >
< Cube name="Sales">
< Table name="sales_fact_1997"/>
...
< DimensionUsage name="Store Type" source="Store Type" foreignKey="store_id"/>
Cube >
< Cube name="Warehouse">
< Table name="warehouse"/>
...
< DimensionUsage name="Store Type" source="Store Type" foreignKey="warehouse_store_id"/>
Cube >
4.2 Join 优化
schema模式文件中映射的表格会告诉Mondrian如何去获取数据,但Mondrian足够智能,不需要按行读取模式文件。在生成查询的过程中,Mondrian会应用许多优化策略:
(1)TODO: 描述大批量维度支持
(2)如果一个维度(更准确地说,所获取的维度的层级)在事实表中,Mondrian就不会进行join操作。
(3)如果两个维度通过一样的join路径接入同一张表,那么Mondrian仅仅会join这两个表一次。举个例子,[Gender]和[Age]维度都属于customers表中的字段,通过sales_1997.cust_id = customers.cust_id进行连接。
5 高级逻辑结构
5.1 虚拟数据立方
一个虚拟数据立方包含两个或更多的普通数据立方。虚拟数据立方在元素中定义。
< VirtualCube name="Warehouse and Sales">
< CubeUsages >
< CubeUsage cubeName="Sales" ignoreUnrelatedDimensions="true"/>
< CubeUsage cubeName="Warehouse"/>
CubeUsages >
< VirtualCubeDimension cubeName="Sales" name="Customers"/>
< VirtualCubeDimension cubeName="Sales" name="Education Level"/>
< VirtualCubeDimension cubeName="Sales" name="Gender"/>
< VirtualCubeDimension cubeName="Sales" name="Marital Status"/>
< VirtualCubeDimension name="Product"/>
< VirtualCubeDimension cubeName="Sales" name="Promotion Media"/>
< VirtualCubeDimension cubeName="Sales" name="Promotions"/>
< VirtualCubeDimension name="Store"/>
< VirtualCubeDimension name="Time"/>
< VirtualCubeDimension cubeName="Sales" name="Yearly Income"/>
< VirtualCubeDimension cubeName="Warehouse" name="Warehouse"/>
< VirtualCubeMeasure cubeName="Sales" name="[Measures].[Sales Count]"/>
< VirtualCubeMeasure cubeName="Sales" name="[Measures].[Store Cost]"/>
< VirtualCubeMeasure cubeName="Sales" name="[Measures].[Store Sales]"/>
< VirtualCubeMeasure cubeName="Sales" name="[Measures].[Unit Sales]"/>
< VirtualCubeMeasure cubeName="Sales" name="[Measures].[Profit Growth]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Store Invoice]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Supply Time]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Units Ordered]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Units Shipped]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Warehouse Cost]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Warehouse Profit]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Warehouse Sales]"/>
< VirtualCubeMeasure cubeName="Warehouse" name="[Measures].[Average Warehouse Sale]"/>
< CalculatedMember name="Profit Per Unit Shipped" dimension="Measures">
< Formula >[Measures].[Profit] / [Measures].[Units Shipped] Formula >
CalculatedMember >
VirtualCube >
其中< CubeUsages > 元素时可选的,它指明了导入到虚拟数据立方中的cubes数据立方。目前,我们可以从基础数据立方中定义一个虚拟数据立方度量以及相似的引入,而不用通过定义这个基础数据立方的CubeUsage。
虚拟数据立方频繁用于现实应用中,当事实表有不同的粒度(比如一个维度是在day层级,另一个维度在month层级时),或者事实表的不同维度(比如一个在Product,Time,Customer上,另一个在Product,Time,Warehouse上),并且希望将数据结果呈现给不知道数据结构情况的最终客户时。
任意的公共维度——即共享维度(被所有数据立方使用)是自动同步的,比如,[Time]和[Product]是共享维度,那么如果当前使用的是 [Time].[1997].[Q2] , [Product].[Beer].[Miller Lite],那么其他数据立方的度量会关联到当前上下文中。
只属于某个数据立方的维度称之为非一致性维度,[Gender]维度就是一个非一致性维度,它在Sales立方中,但不在Warehouse立方中。如果存在[Gender].[F] , [Time].[1997].[Q1],它会去从[Sales]立方中的[Unit Sales]度量中获取值,却不会从[Warehouse]立方中的[Units Ordered]度量中去获取。此时在[Gender].[F]的值中,[Units Ordered]度量是NULL。
5.2 父-子层次结构
传统的层次结构有一个固定的层级集合,和依附这些层级的成员。比如,Product层级中,任何Product Name层级的成员都有一个父层级在Brand Name层级中,而这个父层级又有一个父层级在Product Subcategory层级中。这种结构特性在处理现实中的数据时,有时会显得过于僵化。
parent-child 层次结构只有一个level层级(不包括特殊的’all’层级),但任何成员都可以拥有同层级的成员作为其父层级。下面是一个典型的Employee的层次结构:
< Dimension name="Employees" foreignKey="employee_id">
< Hierarchy hasAll="true" allMemberName="All Employees" primaryKey="employee_id">
< Table name="employee"/>
< Level name="Employee Id" uniqueMembers="true" type="Numeric" column="employee_id" nameColumn="full_name" parentColumn="supervisor_id" nullParentValue="0">
< Property name="Marital Status" column="marital_status"/>
< Property name="Position Title" column="position_title"/>
< Property name="Gender" column="gender"/>
< Property name="Salary" column="salary"/>
< Property name="Education Level" column="education_level"/>
< Property name="Management Role" column="management_role"/>
Level >
Hierarchy >
Dimension >
其中重要的属性是:parentColumn 和 nullParentValue:
parentColumn属性是一个列的名字,它将一个成员链接到它的父成员中,在本例这种情况下,它就是一个外键列,指向employee的supervisor。
nullParentValue属性的值能代表一个element元素是否有parent。默认值是 null,但由于很多数据库中没有null值的索引,因此schema模式设计者通常使用空字符串,0,或者 -1 代替 null值。
5.2.1 调整parent-child结构
在上述定义的parent-child结构中存在一个严重的问题,比如employee表中包含下面的数据:
如果我们想为Bill做所有的工资预算,我们需要对Eric和 Carla(Bill的下属)还有Mark的工资加总。通常Mondrian生成一个sql的Group by的语句来计算总和,却没有(普遍有效)一个sql结构用于Hierarchies层次结构中。所以,Mondrian默认为每一个supervisor生成一个SQL语句,并获取和汇总supervisor的直接汇报者。
但这种方法有两个缺点,其一,如果一个层次结构中包含了上百个成员时,执行效率不高;其二,由于Mondrian在生成SQL时使用了distinct-count聚合,我们不能定义一个distinct-count度量在任何包含parent-child层次结构的数据立方cube中。
这个问题该如何解决?答案就是:强化数据,因此Mondrian能使用标准SQL时也可以获取它需要的信息。针对这个目的,Mondrian支持一种称之为“closure table 闭合表”的机制。
5.2.2 closure tables闭合表
闭合表就是一个sql表,里面包含了employee与supervisor的对照关系信息和关系深度信息。“关系深度”列不是必须的,但它可以有利于表的统计计算。
在XML文件中,元素将level层级映射到闭合表中。
< Dimension name="Employees" foreignKey="employee_id">
< Hierarchy hasAll="true" allMemberName="All Employees" primaryKey="employee_id">
< Table name="employee"/>
< Level name="Employee Id" uniqueMembers="true" type="Numeric"
column="employee_id" nameColumn="full_name" parentColumn="supervisor_id" nullParentValue="0">
< Closure parentColumn="supervisor_id" childColumn="employee_id">
< Table name="employee_closure"/>
Closure >
< Property name="Marital Status" column="marital_status"/>
< Property name="Position Title" column="position_title"/>
< Property name="Gender" column="gender"/>
< Property name="Salary" column="salary"/>
< Property name="Education Level" column="education_level"/>
< Property name="Management Role" column="management_role"/>
Level >
Hierarchy >
Dimension >
闭合表使得在单纯的SQL中可以进行汇总计算。尽管这种方法在查询中引入了额外的表,但数据库优化器很擅长处理join连接。建议申明supervisor_id和employee_id为NOT NULL,并建立索引:
CREATE UNIQUE INDEX employee_closure_pk ON employee_closure (
supervisor_id,
employee_id);
CREATE INDEX employee_closure_emp ON employee_closure (
employee_id);
5.3 成员属性Member properties
成员属性定义在元素的元素内部,比如:
< Level name="MyLevel" column="LevelColumn" uniqueMembers="true">
<Property name="MyProp" column="PropColumn" formatter="com.example.MyPropertyFormatter"/>
< Level />
formatter属性用于定义成员的格式。
一旦属性在模式文件中定义好了,就可以在MDX语句中通过 member .Properties(“propertyName ") 函数来使用这个属性。比如:
SELECT {[Store Sales]} ON COLUMNS,
TopCount(Filter([Store].[Store Name].Members,
[Store].CurrentMember.Properties("Store Type") = "Supermarket"),
10,
[Store Sales]) ON ROWS
FROM [Sales]
Mondrian会尽可能地推导出成员表达式。如果属性名是一个字符串常量,那么这个属性的类型是来自于属性定义中的type属(String,Numeric,Boolean)性。如果属性的名字是一个表达式(比如:CurrentMember.Properties("Store " + "Type")),Mondrian会返回一个无类型的值。
5.4 计算成员 Calculated members
如果需要生成一个度量,这个度量不是来源于事实表中的列,而是来自于MDX表达式,一种方法是使用WITH MEMBER 语句,比如:
WITH MEMBER [Measures].[Profit] AS '[Measures].[Store Sales]-[Measures].[Store Cost]',
FORMAT_STRING = '$#,###'
SELECT {[Measures].[Store Sales], [Measures].[Profit]} ON COLUMNS,
{[Product].Children} ON ROWS
FROM [Sales]
WHERE [Time].[1997]
但是如果不想每次使用时都要在MDX中写一遍的话,可以在模式文件中定义这个计算成员,作为数据立方定义中的一部分:
< CalculatedMember name="Profit" dimension="Measures">
< Formula >[Measures].[Store Sales] - [Measures].[Store Cost] Formula >
< CalculatedMemberProperty name="FORMAT_STRING" value="$#,##0.00"/>
CalculatedMember >
其中FORMAT_STRING 的值还可以是表达式:
< CalculatedMemberProperty name="FORMAT_STRING" expression="Iif(Value < 0, '|($#,##0.00)|style=red', ‘|$#,##0.00|style=green')"/>
5.5 Named集合
WITH SET语句能在MDX语句中申明一个集合的表达式,这个集合能在query中使用。比如:
WITH SET [Top Sellers] AS
'TopCount([Warehouse].[Warehouse Name].MEMBERS, 5, [Measures].[Warehouse Sales])'
SELECT
{[Measures].[Warehouse Sales]} ON COLUMNS,
{[Top Sellers]} ON ROWS
FROM [Warehouse]
WHERE [Time].[Year].[1997]
类似于WITH MEMBER语句,WITH SET语句也可以在模式文件中使用元素定义:
...
TopCount([Warehouse].[Warehouse Name].MEMBERS, 5, [Measures].[Warehouse Sales])
在MDX中的使用如下:
SELECT
{[Measures].[Warehouse Sales]} ON COLUMNS,
{[Top Sellers]} ON ROWS
FROM [Warehouse]
WHERE [Time].[Year].[1997]
6.插件程序
6.1用户自定义方法
方法中必须要有public类型的构造函数,并implements mondrian.spi.UserDefinedFunction.
如:
public class PlusOneUdf implements UserDefinedFunction {
}
然后在模式文件中申明:
...
在MDX文件中使用:
WITH MEMBER [Measures].[Unit Sales Plus One]
AS 'PlusOne([Measures].[Unit Sales])'
SELECT
{[Measures].[Unit Sales]} ON COLUMNS,
{[Gender].MEMBERS} ON ROWS
FROM [Sales]
7.国际化
8. 聚合表 Aggregate tables
当事实表中包含大量的行时,比如百万级或以上的行数,聚合表是提高Mondrian效率的一种方法。一个聚合表本质上是对事实表中的数据进行预先计算汇总。
下面是一个聚合表的简单实例:
这个表中没有显示出来的元素,可以让我们在不用引入维度表中的列到聚合表中的前提下,直接引用维度表。在“aggregate tables guide 聚合表使用指导”中有描述。
实际使用过程中,一个基于非常大的事实表的数据立方cube,可能会有多个聚合表。在模式定义的XML文件中,不方便对每张聚合表进行显式地申明,而且这里有更好的方法。下面的例子中,Mondrian通过模式匹配来申明聚合表:
这个定义告诉Mondrian将所有能匹配上agg_.*_sales_fact_1997 的表作为聚合表,除了agg_c_14_sales_fact_1997 和 agg_lc_100_sales_fact_1997 。Mondrian使用相应的规则来推导这些表中的列所具有的角色,所以依靠严格的命名习惯是很重要的。命名习惯也在“aggregate tables guide ”中做了说明。
针对使用指导的相关建议,在“choosing aggregate tables ”做了说明。
9. 数据获取控制(数据阅读的权限控制)
你可能感兴趣的:(OLAP,翻译,Mondrian)
简介Shell、zsh、bash
zhaosuningsn
Shell zsh bash shell linux bash
Shell是Linux和Unix的外壳,类似衣服,负责外界与Linux和Unix内核的交互联系。例如接收终端用户及各种应用程序的命令,把接收的命令翻译成内核能理解的语言,传递给内核,并把内核处理接收的命令的结果返回给外界,即Shell是外界和内核沟通的桥梁或大门。Linux和Unix提供了多种Shell,其中有种bash,当然还有其他好多种。Mac电脑中不但有bash,还有一个zsh,预装的,据说
Shell、Bash、Zsh这都是啥啊
小白码上飞
bash linux 开发语言
Zsh和Bash都是我们常用的Shell,那先搞明白啥是shell吧。Shell作为一个单词,他是“壳”的意思,蛋壳坚果壳。之所以叫壳,是为了和计算机的“核”来区分,用它表示“为使用者提供的操作界面”。所以这个命名其实很形象,翻译成中文,直译过来叫“壳层”。个人认为这个叫法很奇怪,意译貌似也没有什么好的词汇来匹配。就还是叫shell吧。维基百科给的定义是:Incomputing,ashellisa
可以赚钱的app,你们都在用哪些?
配音新手圈
1.七猫免费小说2.有柿3.番茄小说兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。4.速读免费小说5.得间免费小说6.快手7.快手极速8.抖音火山版(可提0.2,可能我懒赚的慢,但真不推荐)9.拼多多10.淘宝11.点淘12.美
[Python] 数据结构 详解及代码
AIAdvocate
算法 python 数据结构 链表
今日内容大纲介绍数据结构介绍列表链表1.数据结构和算法简介程序大白话翻译,程序=数据结构+算法数据结构指的是存储,组织数据的方式.算法指的是为了解决实际业务问题而思考思路和方法,就叫:算法.2.算法的5大特性介绍算法具有独立性算法是解决问题的思路和方式,最重要的是思维,而不是语言,其(算法)可以通过多种语言进行演绎.5大特性有输入,需要传入1或者多个参数有输出,需要返回1个或者多个结果有穷性,执行
免费的GPT可在线直接使用(一键收藏)
kkai人工智能
gpt
1、LuminAI(https://kk.zlrxjh.top)LuminAI标志着一款融合了星辰大数据模型与文脉深度模型的先进知识增强型语言处理系统,旨在自然语言处理(NLP)的技术开发领域发光发热。此系统展现了卓越的语义把握与内容生成能力,轻松驾驭多样化的自然语言处理任务。VisionAI在NLP界的应用领域广泛,能够胜任从机器翻译、文本概要撰写、情绪分析到问答等众多任务。通过对大量文本数据的
浅评《记忆像铁轨一样长》中的修辞手法
后会定无期
《记忆像铁轨一样长》是已逝世的余光中先生在一九八四年创作的一篇散文,后成为其代表作之一。余光中先生作为著名的作家、诗人和翻译家,素有文坛“璀璨五彩笔”、“诗文双绝”和“诗坛最后的守夜人”等美誉。《记忆像铁轨一样长》这篇散文也继承了作者一贯的风格,全文语言优美隽永,结构清晰紧凑,节奏张弛有度,想象天马行空,感情细腻真挚。其中运用了大量的修辞手法,或新颖巧妙,或生动有趣,用词准确灵活,给读者留下了深刻
轻量级模型解读——轻量transformer系列
lishanlu136
# 图像分类 轻量级模型 transformer 图像分类
先占坑,持续更新。。。文章目录1、DeiT2、ConViT3、Mobile-Former4、MobileViTTransformer是2017谷歌提出的一篇论文,最早应用于NLP领域的机器翻译工作,Transformer解读,但随着2020年DETR和ViT的出现(DETR解读,ViT解读),其在视觉领域的应用也如雨后春笋般渐渐出现,其特有的全局注意力机制给图像识别领域带来了重要参考。但是tran
上班族怎么赚钱搞副业,每月让你多挣几千元的方法
配音就业圈
适合上班族的副业有哪些?1、投稿赚在线贡献,节省邮费,但也很快,一篇手稿也可以投资于许多手稿。文章不会写,找别人的改变,拼凑在一起,非常简单方便。兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。如果你不能写软文章,请去软文章网络学
后端开发刷题 | 把数字翻译成字符串(动态规划)
jingling555
笔试题目 动态规划 java 算法 数据结构 后端
描述有一种将字母编码成数字的方式:'a'->1,'b->2',...,'z->26'。现在给一串数字,返回有多少种可能的译码结果数据范围:字符串长度满足0=10&&num<=26){if(i==1){dp[i]+=1;}else{dp[i]+=dp[i-2];}}}returndp[nums.length()-1];}}
基于STM32的简易RTOS分析-预备知识
騏威
嵌入式
写下这篇文章的主要目的是对自己学习RTOS的历程做一个记录和总结,方便以后回忆翻看。以下内容主要来自宋岩先生翻译的《Cortex-M3权威指南》。目录一、Cortex-M3寄存器简介二、堆栈操作简介三、汇编指令简介LDR和STR指令STMDB和LDMIA指令B、BX、BL、BLX指令MRS和MSR指令四、中断简介中断响应过程简介SVC和PensSV中断简介软件中断五、汇编基础一、Cortex-M3
女孩子下班后可以做的兼职是什么,女生下班后可以做的事情有哪些
配音就业圈
一、女孩子下班后的兼职推荐女孩子下班后可以考虑一些灵活的兼职方式来增加收入。一种推荐的兼职是线上销售,兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。可以通过社交媒体或电商平台开店,销售自己喜欢的产品。另外,可以考虑做代理,代理一
【仿RabbitMQ消息队列项目day2】使用muduo库中基于protobuf的应用层协议进行通信
月夜星辉雪
rabbitmq 网络 分布式 c++ 后端 服务器 linux
一.什么是muduo?muduo库是⼀个基于非阻塞IO和事件驱动的C++高并发TCP网络编程库。简单来理解,它就是对原生的TCP套接字的封装,是一个比socket编程接口更好用的编程库。二.使用muduo库完成一个英译汉翻译服务TranslateServer.hpp:#pragmaonce#include#include#include#include#include"muduo/net/TcpC
【 日本鲫鱼钓 】浮游矶钓不同目标鱼不同钓法,日本专业矶钓书籍
夏说钓鱼
夏说钓鱼,聊海外钓鱼,助钓友钓技!浮游矶钓不同目标鱼不同钓法,翻译来自《日本図解釣り入門基礎から始める海のウキ釣り入門》说到浮钓,由于它的目标鱼类多种多样,因此针对不同类型的目标也会有不同的浮钓方式。下面介绍一下同种类的浮钓方法和目标鱼类。【伸缩竿的小型钓法】用4.5~5.3米的伸缩竿的钓鱼方法。与矶钓竿相比,这种钓鱼竿更加轻便,连儿童也可以使用。目标鱼类有鲰虎鱼、海鲫、沙氏下鱲、竹荚鱼、鲪鱼、小
抖音开始怎么吸粉(可以试试这几种办法)
配音新手圈
如何在抖音短视频平台上快速积累人气和粉丝,抖音短视频平台已成为“我们媒体”和全媒体矩阵,是客户获取、推广和收入的重要平台之一。兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。但对于初学者来说,如何在抖音上建立自己的品牌,积累粉丝,
骑文探古访百村(5):里水镇孔西村
钮海津
祝孔后再辉煌口钮海津2012年12月21的报网消息云,“广东省民间遗产抢救工程这股暖风昨天吹到了孔西村,让这个历史悠久、民风淳朴的村落洋溢着冬日的暖意”。孔西村古建筑群,听说过,在佛山市南海区里水镇。找个时间去看看。看看还有没有这句“子曰”:君子谋道不谋食。耕也,馁在其中矣;学也,禄在其中矣。君子忧道不忧贫。翻译过来就是,老孔对地位高的人说:君子用心谋求大道而不费心思去谋求衣食。即使你亲自去耕田种
解决:java.lang.IllegalStateException: Invalid host: lb://xxx_xxx_xxx
方九九
java 开发语言
在项目了配置了服务名gateway网关也配置了完全没有问题同时nacos这边也能发现服务但就是访问的时候状态码500报错java.lang.IllegalStateException:Invalidhost:lb://…翻译的一下大概是无效的主机解决办法:看自己的服务名是不是xxx_xxx(这种下滑线格式的),是的话去掉下划线或改成”-“就可以了。
陕西省家庭教育指导师,家庭教育指导师的薪资待遇
配音新手圈
一、陕西省家庭教育指导师的薪资待遇陕西省家庭教育指导师的薪资待遇多种多样,主要取决于个人经验、技能、知识背景及所在机构的规模和地理位置。兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。一般来说,初级家庭教育指导师的月薪在2000-
小红书怎么直播(小红书直播条件)
配音新手圈
小红书直播开通条件:1)身份证实名认证;2)年满18周岁;兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。3)绑定手机号;4)完成创作者认证(需满足实名认证、粉丝数不少于5千、近半年自然阅读量2千以上的原创合规笔记数不小于10篇)
麦克白读后感
学号叁拾
最光明的天使也会堕落,可是天使总是光明的;虽然小人全都貌似忠良,可是忠良的一定仍然不失他的本色。倏落秋零之际,黄叶正自凋残。看了辜正坤翻译的麦克白,全文采用了诗歌的形式,文字优美,语句漂亮,只是脑海中一边想着舞台剧一边读这种词总感觉别扭。麦克白作为苏格兰的骁勇大将,在战争大获全胜之后偶遇了三个女巫,女巫预言他会成为韦尔多王爵,又会成为国王。麦克白应该是很开心的吧,在封爵成功之后就告诉了自己的夫人这
前端使用react-intl-universal进行国际化
Stephy_Yy
# 调研 reactjs javascript css
一、国际化/i18n目前国际化,就是开发者写对象,一个key关联若干语种的翻译。相比于浏览器自带的翻译功能,语义更加准确。“国际化”的简称:i18n(其来源是英文单词internationalization的首末字符i和n,18为中间的字符数)二、react项目国际化react-intl是业界最受欢迎的软件包之一:React-intl是雅虎的语言国际化开源项目FormatJS的一部分,通过其提供的
golang-101-hacks(3)——包
_羊羽_
注:本文是对golang-101-hacks中文翻译,原文地址在“Go”中,包分为两种类型:(1)main包:用于生成可执行的二进制文件,main函数是程序的入口点。下面以helllo.go为例:packagemainimport"greet"funcmain(){greet.Greet()}(2)其他类型的包也可以在细分成两类:库文件包:用来生成可以被其他人重用的目标文件。如greet.go这个
学期复盘
高wen鑫
1我的大学生活之大学英语学习1)在这个学期的大学英语学习中,我的GPS[Gains]在这个学期的英语学习中我的听力能力提高了;多于长句的理解翻译能力也增加了;对于英语的文化背景的了解也增加了[Problems]听力能力提升空间还很大;对于语法还有很多不懂;词汇量也比较少[Suggestions]多背单词;多联系听力并适应英英互译2)在这个学期的复盘日志中,我的收获是:对于短语、句式的积累变多;英语
戏感大爆发台词,配音温柔的文案长文
声优配音圈
一、戏感大爆发台词戏剧作品中,戏感大爆发的台词常常令人深受震撼。兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。那些犀利而有力的台词,能够通过真实的表达,将人物内心的情感和冲突完美呈现。这些台词在剧情高潮的时刻,将观众带入紧张激动
【OCPP】ocpp1.6协议第5.17 TriggerMessage章节的介绍及翻译
"啦啦啦"
ocpp1.6协议 开源协议 学习
目录5.17TriggerMessage-概述主要内容1.概要2.操作流程3.参数说明4.示例4.1.TriggerMessage请求示例4.2.TriggerMessage响应示例5.应用场景实际应用结论5.17TriggerMessage-原文译文5.17TriggerMessage-概述在OCPP1.6协议中,第5.17章节描述了TriggerMessage操作。这个操作允许中央系统(Cen
ajax讲解
夜不眠,码三千
okhttp
1.AJAX概述1.1什么是ajaxAJAX(AsynchronousJavascriptAndXML)翻译成中文就是“异步Javascript和XML”。即使用Javascript语言与服务器进行异步交互,传输的数据为XML(当然,传输的数据不只是XML)。AJAX还有一个最大的特点就是,当服务器响应时,不用刷新整个浏览器页面,而是可以局部刷新。这一特点给用户的感受是在不知不觉中完成请求和响应过
心理咨询师的工作要求,北京心理咨询师招聘兼职
配音新手圈
一、心理咨询师的工作要求心理咨询师的工作要求主要包括以下几个方面:兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。1.心理学或相关专业的学士学位,具备扎实的心理学理论知识。2.心理咨询技巧和沟通能力,能够有效地与客户进行沟通和交流
只需一台电脑就可自雇赚钱的6种方法
高省APP珊珊
在互联网时代,利用一台电脑赚钱的方法有很多,以下是一些可能的选择:网络兼职:在互联网上找一些可以在家通过电脑进行的兼职工作,如写作、翻译、设计、在线客服等。可以通过一些自由职业平台或者网上招聘网站找到这些兼职机会。【高省】是一个自用省钱佣金高,分享推广赚钱多的平台,百度有几百万篇报道,也期待你的加入。高省APP,是2021年推出的平台,0投资,0风险、高省APP佣金更高,模式更好,终端用户不流失。
新质农业-再生农业的应用
橙蜂智农
人工智能 制造 创业创新
橙蜂智能公司致力于提供先进的人工智能和物联网解决方案,帮助企业优化运营并实现技术潜能。公司主要服务包括AI数字人、AI翻译、埃域知识库、大模型服务等。其核心价值观为创新、客户至上、质量、合作和可持续发展。橙蜂智农的智慧农业产品涵盖了多方面的功能,如智能化推荐、数据分析、远程监控和决策支持系统。用户可以通过应用获得个性化的作物种植建议、实时的生长状态监控以及精确的灌溉和施肥指导,提升农业生产效率。文
linux json编译报错
nancynull
c++ Linux linux c++ 编译
背景:ubuntu16.04,使用apt-get安装过jsoncpp问题一:编译时报找不到json.h问题二:编译.so时,提示/usr/bin/ld:cannotfind-ljson解决方案:https://stackoverflow.com/questions/36861355/fatal-error-with-jsoncpp-while-compiling具体翻译如下:针对问题一:修改#in
新手配音接单平台 声音挣钱的app哪个好
配音就业圈
新手配音接单平台的选择对于新手来说,选择一个合适的配音接单平台非常重要。兼职副业推荐公众号,配音新手圈,声优配音圈,新配音兼职圈,配音就业圈,鼎音副业,有声新手圈,每天更新各种远程工作与在线兼职,职位包括:写手、程序开发、剪辑、设计、翻译、配音、无门槛、插画、翻译、等等。。。每日更新兼职。可以考虑一些知名度较高且信誉良好的平台,例如某某配音网、某某配音平台等。另外,要注意平台的用户评价、支付方式、
继之前的线程循环加到窗口中运行
3213213333332132
java thread JFrame JPanel
之前写了有关java线程的循环执行和结束,因为想制作成exe文件,想把执行的效果加到窗口上,所以就结合了JFrame和JPanel写了这个程序,这里直接贴出代码,在窗口上运行的效果下面有附图。
package thread;
import java.awt.Graphics;
import java.text.SimpleDateFormat;
import java.util
linux 常用命令
BlueSkator
linux 命令
1.grep
相信这个命令可以说是大家最常用的命令之一了。尤其是查询生产环境的日志,这个命令绝对是必不可少的。
但之前总是习惯于使用 (grep -n 关键字 文件名 )查出关键字以及该关键字所在的行数,然后再用 (sed -n '100,200p' 文件名),去查出该关键字之后的日志内容。
但其实还有更简便的办法,就是用(grep -B n、-A n、-C n 关键
php heredoc原文档和nowdoc语法
dcj3sjt126com
PHP heredoc nowdoc
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Current To-Do List</title>
</head>
<body>
<?
overflow的属性
周华华
JavaScript
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
《我所了解的Java》——总体目录
g21121
java
准备用一年左右时间写一个系列的文章《我所了解的Java》,目录及内容会不断完善及调整。
在编写相关内容时难免出现笔误、代码无法执行、名词理解错误等,请大家及时指出,我会第一时间更正。
&n
[简单]docx4j常用方法小结
53873039oycg
docx
本代码基于docx4j-3.2.0,在office word 2007上测试通过。代码如下:
import java.io.File;
import java.io.FileInputStream;
import ja
Spring配置学习
云端月影
spring配置
首先来看一个标准的Spring配置文件 applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi=&q
Java新手入门的30个基本概念三
aijuans
java 新手 java 入门
17.Java中的每一个类都是从Object类扩展而来的。 18.object类中的equal和toString方法。 equal用于测试一个对象是否同另一个对象相等。 toString返回一个代表该对象的字符串,几乎每一个类都会重载该方法,以便返回当前状态的正确表示.(toString 方法是一个很重要的方法) 19.通用编程:任何类类型的所有值都可以同object类性的变量来代替。
《2008 IBM Rational 软件开发高峰论坛会议》小记
antonyup_2006
软件测试 敏捷开发 项目管理 IBM 活动
我一直想写些总结,用于交流和备忘,然都没提笔,今以一篇参加活动的感受小记开个头,呵呵!
其实参加《2008 IBM Rational 软件开发高峰论坛会议》是9月4号,那天刚好调休.但接着项目颇为忙,所以今天在中秋佳节的假期里整理了下.
参加这次活动是一个朋友给的一个邀请书,才知道有这样的一个活动,虽然现在项目暂时没用到IBM的解决方案,但觉的参与这样一个活动可以拓宽下视野和相关知识.
PL/SQL的过程编程,异常,声明变量,PL/SQL块
百合不是茶
PL/SQL的过程编程 异常 PL/SQL块 声明变量
PL/SQL;
过程;
符号;
变量;
PL/SQL块;
输出;
异常;
PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言PL/SQL 是对 SQL 的扩展,sql的执行时每次都要写操作
Mockito(三)--完整功能介绍
bijian1013
持续集成 mockito 单元测试
mockito官网:http://code.google.com/p/mockito/,打开documentation可以看到官方最新的文档资料。
一.使用mockito验证行为
//首先要import Mockito
import static org.mockito.Mockito.*;
//mo
精通Oracle10编程SQL(8)使用复合数据类型
bijian1013
oracle 数据库 plsql
/*
*使用复合数据类型
*/
--PL/SQL记录
--定义PL/SQL记录
--自定义PL/SQL记录
DECLARE
TYPE emp_record_type IS RECORD(
name emp.ename%TYPE,
salary emp.sal%TYPE,
dno emp.deptno%TYPE
);
emp_
【Linux常用命令一】grep命令
bit1129
Linux常用命令
grep命令格式
grep [option] pattern [file-list]
grep命令用于在指定的文件(一个或者多个,file-list)中查找包含模式串(pattern)的行,[option]用于控制grep命令的查找方式。
pattern可以是普通字符串,也可以是正则表达式,当查找的字符串包含正则表达式字符或者特
mybatis3入门学习笔记
白糖_
sql ibatis qq jdbc 配置管理
MyBatis 的前身就是iBatis,是一个数据持久层(ORM)框架。 MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。MyBatis对JDBC进行了一次很浅的封装。
以前也学过iBatis,因为MyBatis是iBatis的升级版本,最初以为改动应该不大,实际结果是MyBatis对配置文件进行了一些大的改动,使整个框架更加方便人性化。
Linux 命令神器:lsof 入门
ronin47
lsof
lsof是系统管理/安全的尤伯工具。我大多数时候用它来从系统获得与网络连接相关的信息,但那只是这个强大而又鲜为人知的应用的第一步。将这个工具称之为lsof真实名副其实,因为它是指“列出打开文件(lists openfiles)”。而有一点要切记,在Unix中一切(包括网络套接口)都是文件。
有趣的是,lsof也是有着最多
java实现两个大数相加,可能存在溢出。
bylijinnan
java实现
import java.math.BigInteger;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class BigIntegerAddition {
/**
* 题目:java实现两个大数相加,可能存在溢出。
* 如123456789 + 987654321
Kettle学习资料分享,附大神用Kettle的一套流程完成对整个数据库迁移方法
Kai_Ge
Kettle
Kettle学习资料分享
Kettle 3.2 使用说明书
目录
概述..........................................................................................................................................7
1.Kettle 资源库管
[货币与金融]钢之炼金术士
comsci
金融
自古以来,都有一些人在从事炼金术的工作.........但是很少有成功的
那么随着人类在理论物理和工程物理上面取得的一些突破性进展......
炼金术这个古老
Toast原来也可以多样化
dai_lm
android toast
Style 1: 默认
Toast def = Toast.makeText(this, "default", Toast.LENGTH_SHORT);
def.show();
Style 2: 顶部显示
Toast top = Toast.makeText(this, "top", Toast.LENGTH_SHORT);
t
java数据计算的几种解决方法3
datamachine
java hadoop ibatis r-langue r
4、iBatis
简单敏捷因此强大的数据计算层。和Hibernate不同,它鼓励写SQL,所以学习成本最低。同时它用最小的代价实现了计算脚本和JAVA代码的解耦,只用20%的代价就实现了hibernate 80%的功能,没实现的20%是计算脚本和数据库的解耦。
复杂计算环境是它的弱项,比如:分布式计算、复杂计算、非数据
向网页中插入透明Flash的方法和技巧
dcj3sjt126com
html Web Flash
将
Flash 作品插入网页的时候,我们有时候会需要将它设为透明,有时候我们需要在Flash的背面插入一些漂亮的图片,搭配出漂亮的效果……下面我们介绍一些将Flash插入网页中的一些透明的设置技巧。
一、Swf透明、无坐标控制 首先教大家最简单的插入Flash的代码,透明,无坐标控制: 注意wmode="transparent"是控制Flash是否透明
ios UICollectionView的使用
dcj3sjt126com
UICollectionView的使用有两种方法,一种是继承UICollectionViewController,这个Controller会自带一个UICollectionView;另外一种是作为一个视图放在普通的UIViewController里面。
个人更喜欢第二种。下面采用第二种方式简单介绍一下UICollectionView的使用。
1.UIViewController实现委托,代码如
Eos平台java公共逻辑
蕃薯耀
Eos平台java公共逻辑 Eos平台 java公共逻辑
Eos平台java公共逻辑
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月1日 17:20:4
SpringMVC4零配置--Web上下文配置【MvcConfig】
hanqunfeng
springmvc4
与SpringSecurity的配置类似,spring同样为我们提供了一个实现类WebMvcConfigurationSupport和一个注解@EnableWebMvc以帮助我们减少bean的声明。
applicationContext-MvcConfig.xml
<!-- 启用注解,并定义组件查找规则 ,mvc层只负责扫描@Controller -->
<
解决ie和其他浏览器poi下载excel文件名乱码
jackyrong
Excel
使用poi,做传统的excel导出,然后想在浏览器中,让用户选择另存为,保存用户下载的xls文件,这个时候,可能的是在ie下出现乱码(ie,9,10,11),但在firefox,chrome下没乱码,
因此必须综合判断,编写一个工具类:
/**
*
* @Title: pro
挥洒泪水的青春
lampcy
编程 生活 程序员
2015年2月28日,我辞职了,离开了相处一年的触控,转过身--挥洒掉泪水,毅然来到了兄弟连,背负着许多的不解、质疑——”你一个零基础、脑子又不聪明的人,还敢跨行业,选择Unity3D?“,”真是不自量力••••••“,”真是初生牛犊不怕虎•••••“,••••••我只是淡淡一笑,拎着行李----坐上了通向挥洒泪水的青春之地——兄弟连!
这就是我青春的分割线,不后悔,只会去用泪水浇灌——已经来到
稳增长之中国股市两点意见-----严控做空,建立涨跌停版停牌重组机制
nannan408
对于股市,我们国家的监管还是有点拼的,但始终拼不过飞流直下的恐慌,为什么呢?
笔者首先支持股市的监管。对于股市越管越荡的现象,笔者认为首先是做空力量超过了股市自身的升力,并且对于跌停停牌重组的快速反应还没建立好,上市公司对于股价下跌没有很好的利好支撑。
我们来看美国和香港是怎么应对股灾的。美国是靠禁止重要股票做空,在
动态设置iframe高度(iframe高度自适应)
Rainbow702
JavaScript iframe contentDocument 高度自适应 局部刷新
如果需要对画面中的部分区域作局部刷新,大家可能都会想到使用ajax。
但有些情况下,须使用在页面中嵌入一个iframe来作局部刷新。
对于使用iframe的情况,发现有一个问题,就是iframe中的页面的高度可能会很高,但是外面页面并不会被iframe内部页面给撑开,如下面的结构:
<div id="content">
<div id=&quo
用Rapael做图表
tntxia
rap
function drawReport(paper,attr,data){
var width = attr.width;
var height = attr.height;
var max = 0;
&nbs
HTML5 bootstrap2网页兼容(支持IE10以下)
xiaoluode
html5 bootstrap
<!DOCTYPE html>
<html>
<head lang="zh-CN">
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">