Linux下sqlite3編程

------------------------------------------------------------------------------------------------------------------------------html

交叉編譯器:arm-linux-gcc-4.5.4linux

Linux內核版本:Linux-3.0ios

主機操做系統:Centos 6.5sql

開發板:FL2440數據庫

溫度傳感器:ds18b20服務器

注:此程序的客戶端是在裝有ds18b20模塊並有ds18b20驅動的系統上跑的,本人寫的ds18b20的驅動併發

------------------------------------------------------------------------------------------------------------------------------socket

如下操做是創建在你有sqlite3數據庫的狀況下,sqlite3數據庫的安裝參考連接:http://www.linuxidc.com/Linux/2012-07/66854.htm函數

注:數據庫安裝好以後會在/home下自動建立一個sqlite-3.6.18的用戶,其中保存了數據庫sqlite3全部的執行文件,頭文件還有庫函數。spa

如下程序實現的功能是:客戶端讀取溫度傳感器的溫度以及當時的時間,並向服務器發送數據。若鏈接服務器失敗則保存數據到數據庫。等待客戶端能夠鏈接上服務器的時候把保存的數據發送給服務器。

 

1、客戶端代碼

  1 /*********************************************************************************
  2  *      Copyright:  (C) 2016 2013dianxin_3
  3  *                  All rights reserved.
  4  *
  5  *       Filename:  mclient.c
  6  *    Description:  This file 
  7  *                 
  8  *        Version:  1.0.0(08/16/2016)
  9  *         Author:  xiaohexiansheng <1392195453@qq.com>
 10  *      ChangeLog:  1, Release initial version on "08/16/2016 07:16:44 PM"
 11  *                 
 12  ********************************************************************************/
 13 #include <sys/types.h>
 14 #include <sys/ioctl.h>
 15 #include <termios.h>
 16 #include <sys/stat.h>
 17 #include <fcntl.h>
 18 #include <sys/time.h>
 19 #include <stdio.h>
 20 #include <stdlib.h>
 21 #include <string.h>
 22 #include <errno.h>
 23 #include <sys/types.h>
 24 #include <sys/socket.h>
 25 #include <netinet/in.h>
 26 #include <sqlite3.h>
 27 
 28 #define MAXLINE                 4096
 29 char                            get_sql[4096]; 
 30 /********************************************************************************
 31  *  Description:
 32  *   Input Args:
 33  *  Output Args:
 34  * Return Value:
 35  ********************************************************************************/
 36 double get_tem(void)        //獲取溫度的函數
 37 {
 38     int fd;
 39     double result = 0;
 40     unsigned char buff[2];
 41     unsigned short temp = 0;
 42     int flag = 0;
 43 
 44     if ((fd=open("/dev/ds18b20",O_RDWR | O_NDELAY | O_NOCTTY)) < 0)
 45     {
 46         perror("open device ds18b20 failed.\r\n");
 47         exit(1);
 48     }
 49 
 50     printf("open device ds18b20 success.\r\n");
 51     
 52     read(fd, buff, sizeof(buff));
 53     temp=((unsigned short)buff[1])<<8;
 54     temp|=(unsigned short)buff[0];
 55     result=0.0625*((double)temp);
 56     close(fd);
 57     printf("temperature is %4f \r\n", result);
 58     return result;
 59 }
 60 
 61 int save_tem(char *s_temp)            //將數據保存到數據庫
 62 {
 63     char sql[128];
 64     sqlite3 *db;
 65     FILE *fd;
 66 
 67     sqlite3_open("temperature.db", &db);
 68     memset(sql, '\0', 128);
 69     strcpy(sql, "create table tb(id INTEGER PRIMARY KEY, data TEXT)");
 70     sqlite3_exec(db, sql, NULL, NULL, NULL);
 71 
 72     memset(sql, '\0', 128);
 73     strcpy(sql, "insert into tb(data) values(\"");
 74     strcat(sql, s_temp);
 75     strcat(sql, "\")");
 76     sqlite3_exec(db, sql, NULL, NULL, NULL);
 77     sqlite3_close(db);
 78     return 0;
 79 }
 80 
 81 int wf_callback(void *addr, int nr, char **values, char **names)        //回掉函數依次將數據庫中的數據發送給服務器
 82 {
 83 
 84     int         sockfd;
 85     char        sendline[MAXLINE];
 86     struct sockaddr_in servaddr;
 87 
 88     if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
 89     {
 90         printf("create socket error: %s(errno: %d).\n", strerror(errno), errno);
 91         return 0;
 92     }
 93 
 94     memset(&servaddr, 0, sizeof(servaddr));
 95     servaddr.sin_family = AF_INET;
 96     servaddr.sin_port = htons(6666);
 97     if(inet_pton(AF_INET, addr, &servaddr.sin_addr) <= 0)
 98     {
 99         printf("inet_pton error for %s.\n", addr);
100         return 0;
101     }
102 
103     memset(sendline, 0, sizeof(sendline));
104     if(connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0)
105     {
106         printf("connect error: %s(errno: %d)\n", strerror(errno), errno);
107         return 0;
108     }
109 
110     if(send(sockfd, values[1], strlen(values[1]), 0) < 0)
111     {
112         printf("send msg error: %s(errno: %d)\n", strerror(errno), errno);
113         return 0;
114     }
115     close(sockfd);
116     return 0;
117 }
118 
119 int read_sql(char *addr)        //讀取數據庫中的數據併發送的函數
120 {
121     char sql[128];
122     sqlite3 *db;
123 
124     sqlite3_open("test.db", &db);
125     sqlite3_exec(db, "select * from tb", wf_callback, addr, NULL);        //讀取數據,並調用回調函數
126     
127     sqlite3_close(db);
128     return 0;
129 }
130 
131 int delet_sql(void)                //刪除數據庫中表的函數
132 {
133     char sql[128];
134     sqlite3 *db;
135 
136     sqlite3_open("test.db", &db);
137     sqlite3_exec(db, "DROP TABLE tb;", NULL, NULL, NULL);
138 
139     sqlite3_close(db);
140     return 0;
141 }
142 
143 int main (int argc, char **argv)
144 {
145     double      temperature;
146     int         sockfd;
147     int         ret;
148     char        timE[80];
149     time_t      rawtime;
150     char        temp[25];
151     char        sendline[MAXLINE];
152     char        recvline[MAXLINE];
153     struct tm* timeinfo;
154     struct sockaddr_in servaddr;
155 
156     if(argc != 2)        //第二個參數爲客戶端的Ip地址,必需要有
157     {
158         printf("usage: ./client <ipaddress>.\n");
159         return 0;
160     }
161 
162     if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)        //打開一個socket的文件描述符
163     {
164         printf("create socket error: %s(errno: %d).\n", strerror(errno), errno);
165         return 0;
166     }
167     
168     memset(&servaddr, 0, sizeof(servaddr));
169     servaddr.sin_family = AF_INET;
170     servaddr.sin_port = htons(6666);            //使用6666號端口
171     if(inet_pton(AF_INET, argv[1], &servaddr.sin_addr) <= 0)
172     {
173         printf("inet_pton error for %s.\n", argv[1]);
174         return 0;
175     }
176 
177     temperature = get_tem();        //獲取溫度值並返回給temperature
178     gcvt(temperature, 4, temp);            //將溫度值轉換爲字符串類型的
179     memset(sendline, 0, sizeof(sendline));
180     strcpy(sendline, "the degrees is ");
181     strcat(sendline, temp);
182    
183     memset(timE, 0, sizeof(timE));
184     time(&rawtime);
185     timeinfo=localtime(&rawtime);
186     strftime(timE,80,"%y-%m-%d %I:%M:%S",timeinfo);            //獲取當前時間
187 
188     strcat(sendline, "℃, time is ");
189     strcat(sendline, timE);
190 
191     if(connect(sockfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) < 0)
192     {
193         ret = save_tem(sendline);                //若鏈接客戶端失敗則調用save_tem函數保存數據
194         printf("connect error: %s(errno: %d)\n", strerror(errno), errno);
195         return 0;
196     }
197     
198     if(send(sockfd, sendline, strlen(sendline), 0) < 0)
199     {
200         printf("send msg error: %s(errno: %d)\n", strerror(errno), errno);
201         return 0;
202     }
203     else
204     {
205         read_sql(argv[1]);                //若是能夠鏈接數據庫則讀取數據庫併發送
206         delet_sql();                    //讀取完了以後刪除數據庫
207     }
208 
209     close(sockfd);                        //關閉socket文件描述符
210     return 0;
211 } /* ----- End of main() ----- */

 

2、服務器代碼

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 #include<string.h>
 4 #include<errno.h>
 5 #include<sys/types.h>
 6 #include<sys/socket.h>
 7 #include<netinet/in.h>
 8 #include <sys/time.h>
 9 #include<time.h>
10 #include <sqlite3.h>
11 
12 #define MAXLINE 4096
13 
14 int save_tem(char *s_temp)
15 {
16     char sql[128];
17     sqlite3 *db;
18     FILE *fd;
19 
20     sqlite3_open("tem.db", &db);
21     memset(sql, '\0', 128);
22     strcpy(sql, "create table tb(id INTEGER PRIMARY KEY, data TEXT)");
23     sqlite3_exec(db, sql, NULL, NULL, NULL);
24 
25     memset(sql, '\0', 128);
26     strcpy(sql, "insert into tb(data) values(\"");
27     strcat(sql, s_temp);
28     strcat(sql, "\")");
29     sqlite3_exec(db, sql, NULL, NULL, NULL);
30     sqlite3_close(db);
31     return 0;
32 }
33 
34 int main(int argc, char** argv)
35 {
36     int         n;
37     int         listenfd;
38     int         connfd;
39     char        buff[4096];
40     struct  sockaddr_in     servaddr;
41     
42     if((listenfd = socket(AF_INET, SOCK_STREAM, 0)) == -1 )
43     {
44         printf("create socket error: %s(errno: %d)\n",strerror(errno),errno);
45         exit(0);
46     }
47 
48     memset(&servaddr, 0, sizeof(servaddr));
49     servaddr.sin_family = AF_INET;
50     servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
51     servaddr.sin_port = htons(6666);
52 
53     if(bind(listenfd, (struct sockaddr*)&servaddr, sizeof(servaddr)) == -1)
54     {
55         printf("bind socket error: %s(errno: %d)\n",strerror(errno),errno);
56         exit(0);
57     }
58 
59     if(listen(listenfd, 10) == -1)
60     {
61         printf("listen socket error: %s(errno: %d)\n",strerror(errno),errno);
62         exit(0);
63     }
64 
65     printf("======waiting for client's request======\n");
66     
67     while(1)
68     {
69         memset(buff, 0, sizeof(buff));
70         
71         if((connfd = accept(listenfd, (struct sockaddr*)NULL, NULL)) == -1)
72         {
73             printf("accept socket error: %s(errno: %d)",strerror(errno),errno);
74             continue;
75         }
76         n = recv(connfd, buff, MAXLINE, 0);
77         printf("%s\n", buff);
78         save_tem(buff);
79         close(connfd);
80     }
81     close(listenfd);
82 }
相關文章
相關標籤/搜索