LinuxC++/C,每过几分钟传进数据库一条数据,读取数据库条数,如果没传定时查询进行报警并且显示时间提示!

//读取数据库查询条数  sql.c

#include<stdio.h>

#include<stdlib.h>
#include<errno.h>
#include<mysql/mysql.h>

 

int mysql(void)

{
  char *sql;
  sql="SELECT COUNT(*) FROM test;";
  int res;//执行sql语句后的返回标志
  MYSQL_RES *res_ptr;//指向查询结果的指针
  MYSQL_FIELD *field;//字段结构指针
  MYSQL_ROW result_row;//按行返回查询信息
  int row,column;//查询返回的行数和列数
  MYSQL *conn;//一个数据库链接指针
  int i,j;
//初始化连接句柄
  conn = mysql_init(NULL);

 

  if(conn == NULL) { //如果返回NULL说明初始化失败

    printf("mysql_init failed!\n");
    return EXIT_FAILURE;
  }
 //进行实际连接
 //参数 conn连接句柄,host mysql所在的主机或地址,user用户名,passwd密码,database_name数据库名,后面的都是默认
  conn = mysql_real_connect(conn,"127.0.0.1","root","root","test",0,NULL,0);
  if (conn) {
    printf("Connection success!\n");
  } else {
    printf("Connection failed!\n");
  }
  mysql_query(conn,"set names gbk");//防止乱码。设置和数据库的编码一致就不会乱码

 

res = mysql_query(conn,sql);//正确返回0

  if(res) {
printf("error------");
    perror("my_query");
    mysql_close(conn);
    exit(0);
  } else{
    //把查询结果给res_ptr
    res_ptr = mysql_store_result(conn);
    //如果结果不为空,则输出
    if(res_ptr) {
      column = mysql_num_fields(res_ptr);
      row = mysql_num_rows(res_ptr);
      //输出结果的字段名
      for(i = 0;(field = mysql_fetch_field(res_ptr));i++) {
      }
      puts("");
      //按行输出结果
      for(i = 1;i < row+1;i++){
        result_row = mysql_fetch_row(res_ptr);
for(j = 0;j< column;j++) {
int Temp=atoi(result_row[j]);
printf("%d-a-a",Temp);
        row=Temp;
mysql_close(conn);
return Temp;

        }

         puts("");

      }
    }
}
  //退出前关闭连接
  mysql_close(conn);
  return row;

}

 

//alarm

//定时器循环查询是否传入,如果传入继续运行,不传入提示报警

#include <stdio.h>
#include <time.h>
#include <signal.h>
#include <unistd.h>
#include <string.h>
 

 

static char msg[] = "数据采集异常\n";

int len;

void show_msg(int signo)

{
write(STDERR_FILENO, msg, len);
}
int main()
{

struct sigaction act;
union sigval tsval;
act.sa_handler = show_msg;
act.sa_flags = 0;
sigemptyset(&act.sa_mask);
sigaction(50, &act, NULL);
len = strlen(msg);

         int firstTime;
 int  lastTime;
 while ( 1 )
{

         firstTime =  mysql(); //取首次查询条数
        printf("in,%d/n",firstTime);
        sleep(20); /*睡眠2秒*/
lastTime  =   mysql(); //取第三次查询条数
printf("%d,%d",lastTime,firstTime);
       if(lastTime-3!=firstTime){
      /*向主进程发送信号,实际上是自己给自己发信号*/
sigqueue(getpid(), 50, tsval);
time_t t;
    struct tm * lt;
    time (&t);//获取Unix时间戳。
    lt = localtime (&t);//转为时间结构。
    printf ( "%d/%d/%d %d:%d:%d\n",lt->tm_year+1900, lt->tm_mon, lt->tm_mday, lt->tm_hour, lt->tm_min, lt->tm_sec);//输出结果
         }
}
return 0;
}

 

编译命令

将查询生成.so,报警进行调用

gcc -Wall -g  -fPIC -c sql.c -o sql.o 

gcc -shared sql.o -o libsql.so 

gcc -o  main alarm.c -L. -lsql

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值