- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试在 MySQL 中创建 UDF 函数。
我想根据输入参数返回 7 位十进制/ double 。
我将以下函数安装到 MySQL 中,如下所示:
CREATE FUNCTION postrank_udf RETURNS REAL SONAME 'postrank.so'
我的函数 Select postrank(120, 0, 1444763428) 的正确结果应该是 13.8604775。但是,除非我执行 postrank(120, 0, 1444763428.0000000),否则它现在返回 14。下面是我的 UDF 函数。有什么想法吗?
#ifdef STANDARD
/* STANDARD is defined, don't use any mysql functions */
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#ifdef __WIN__
typedef unsigned __int64 ulonglong;/* Microsofts 64 bit types */
typedef __int64 longlong;
#else
typedef unsigned long long ulonglong;
typedef long long longlong;
#endif /*__WIN__*/
#else
#include <my_global.h>
#include <my_sys.h>
#if defined(MYSQL_SERVER)
#include <m_string.h>/* To get strmov() */
#else
/* when compiled as standalone */
#include <string.h>
#define strmov(a,b) stpcpy(a,b)
#define bzero(a,b) memset(a,0,b)
#define memcpy_fixed(a,b,c) memcpy(a,b,c)
#endif
#endif
#include <mysql.h>
#include <ctype.h>
#ifdef HAVE_DLOPEN
#if !defined(HAVE_GETHOSTBYADDR_R) || !defined(HAVE_SOLARIS_STYLE_GETHOST)
static pthread_mutex_t LOCK_hostname;
#endif
#include <math.h>
my_bool postrank_init(UDF_INIT *initid, UDF_ARGS *args, char *message);
void postrank_deinit(UDF_INIT *initid __attribute__((unused)));
double postrank(UDF_INIT* initid, UDF_ARGS* args __attribute__((unused)),
char* is_null __attribute__((unused)), char* error __attribute__((unused)));
my_bool postrank_init(UDF_INIT *initid, UDF_ARGS *args, char *message)
{
if(!(args->arg_count == 3)) {
strcpy(message, "Expected three arguments");
return 1;
}
args->arg_type[0] = REAL_RESULT;
args->arg_type[1] = REAL_RESULT;
args->arg_type[2] = REAL_RESULT;
return 0;
}
void postrank_deinit(UDF_INIT *initid __attribute__((unused)))
{
}
double postrank(UDF_INIT* initid, UDF_ARGS* args __attribute__((unused)),
char* is_null __attribute__((unused)), char* error __attribute__((unused)))
{
double ups = *((double *)(args->args[0]));
double downs = *((double *)(args->args[1]));
double d = *((double *)(args->args[2]));
double final = 0.00;
double my_sign = 1.0;
if(ups - downs > 0){
my_sign = 1.0;
}else if(ups - downs < 0){
my_sign = -1.0;
}else{
my_sign = 0.0;
}
int myups = (int) ups;
int mydowns = (int) downs;
int my_max = 1;
if(abs(myups-mydowns) > 1){
my_max = abs(myups-mydowns);
}
double dbmy_max = (double) my_max;
double result = log10(dbmy_max) * my_sign + ((d - 1444000000.0) / 64800.0);
final = round( 10000000.0 * result ) / 10000000.0;
return final;
}
#endif /* HAVE_DLOPEN */
最佳答案
您的代码很好,请尝试这个小调试代码,它会打印出您所期望的内容。
#include <usual.h>
int main( )
{
// int ups = *((int *)(args->args[0]));
// int downs = *((int *)(args->args[1]));
// double d = *((double *)(args->args[2]));
int ups = 120;
int downs = 0;
double d = 1444763428;
double debugd = 0.00;
double my_sign = 1.0;
if ( ups - downs > 0 )
{
my_sign = 1.0;
}
else if ( ups - downs < 0 )
{
my_sign = -1.0;
}
else
{
my_sign = 0.0;
}
int my_max = 1;
if ( abs( ups - downs ) > 1 )
{
my_max = abs( ups - downs );
}
double dbmy_max = ( double ) my_max;
double result =
log10( dbmy_max ) * my_sign + ( d - 1444000000.0 ) / 64800.0;
// return round(10000000.0 * result) / 10000000.0;
debugd = round( 10000000.0 * result ) / 10000000.0;
printf( "\n debugd == %5.7f ", debugd );
}
关于MySQL UDF 只返回整数 - double 想要,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33115783/
下面的代码有效,我觉得double(double)和double(*)(double)没有区别,square和 &square,我说得对吗? #include double square(doubl
我知道我的作业很草率,这是我在这门课上的第 4 次作业。任何帮助将不胜感激,谢谢。 double getPrincipal(0); double getRate(0); double getYe
我遇到了那个错误,当我使用类时,我在使用函数指针时遇到了这个错误。我的函数'ope'函数我该如何解决 evaluator::function(){ double (*ope) (dou
问题://故事从哪里开始 Graphics 类型中的方法 drawLine(int, int, int, int) 不适用于参数 (double, double, double, double) g.
我有一张 map> m1 形式的 map .我可以将其复制到 map m2 形式的 map 吗?这样键是相同的,并且 m2 中的值是 get(m1->second) 不使用循环?谢谢! 最佳答案 这样
有没有办法获取vector> 的“.first”和“.second”的连续内存? ?我的意思是: void func(int N, double* x, double* y) { for (i
我正在尝试将自定义 lambda 传递给需要函数指针的函数(更准确地说是 zero 中的 Brent library 函数)。 我的想法是,我将使用参数创建一次 lambda,然后用多个值对其求值 x
这是一个很简单的问题,让我很困惑。 我收到一个源文件的以下错误,但另一个没有: 4 src/Source2.cpp:1466: error: no matching function for cal
struct CalculatorBrain { private var accumulator: Double? func changeSign(operand: Double) -
在我正在进行的项目中,我尝试使用 curlpp库来发出一个简单的 html GET 请求。当我将 cpp 文件传递给 g++ 时,出现以下错误: /usr/local/include/curlpp
不使用double就能获得quadruple精度超过16位的数字吗?如果可能的话,这取决于编译器还是其他?因为我知道有人说他使用double精度,并且具有22位精度。 最佳答案 数据类型double
我正在寻找有关特斯拉 GPU 中硬件如何实现 double 的信息。我读到,两个流处理器正在处理单个 double 值,但我没有找到 nvidia 的任何官方论文。 提前致谢。聚苯硫醚为什么大多数 G
这个问题在这里已经有了答案: Passing capturing lambda as function pointer (10 个答案) 关闭 2 年前。 我有这个错误 error: cannot
情况:我有一个元组列表,其中添加了一个元组: List> list = new List>(); list .Add(new Tuple(2.2, 6.6)); 一切似乎都还好。但是......在 D
我有一个 JList,里面有一堆名字,还有一个包含这些名字值的数组 final Double[] filmcost = { 5.00, 5.50, 7.00, 6.00, 5.00 }; 我想做的是,
我试图找出牛顿法来求方程的根。这个错误出来了,我无法处理。 double fn(double n){ return sin(n)+log(n)-1; } double f1n(double n
我有一个 junit 测试断言两个 Double 对象,具有以下内容: Assert.assertEquals(Double expected, Double result); 这很好,然后我决定将其
我正在尝试引入部分数据文件来填充数组,用户尝试了三次输入正确的数据文件名。我一再遇到这些错误。我知道像 arr 这样的数组只是一个指向内存块的指针。 #include #include #incl
我正在尝试完成复习题(为即将到来的编程决赛),但是,我无法解决这个问题,因为我不断收到错误(标题)。正如预期的那样,我将发布问题和我尝试的解决方案。 问题: 给定以下函数定义:void swap(do
任何人都知道如何实现这一目标。我已经尝试了通常的公式,但我只得到正数 Double.NEGATIVE_INFINITY) return d; } } 这将以相同的概率
我是一名优秀的程序员,十分优秀!