文本数据库的使用心得

本文分享了在嵌入式编程中使用文本数据库的心得,包括配置文件的ini格式解析和日志文件的读写操作。通过标准文件I/O函数fopen、fgets、sscanf等实现日志的读取、增加、存储、删除和清空,强调了日志文件格式的重要性。
摘要由CSDN通过智能技术生成

文本数据库的使用心得

项目背景

在嵌入式编程中,有的时候应用程序需要读取配置文件以及一些日志文件,程序能够随时记录这些数据的变化,并且把他们存储到flash中。经常碰到的数据有下面几种:

  • 配置文件

    在嵌入式变成中,程序启动的时候往往需要进行配置,比如你应用程序的版本号、 服务器地址等,配置文件一般是key-value值。所以我一般都是采用ini文件来存储配置信息。解析ini文件网上有相应的方法,只需要dictionary.h、dictionary.c、iniparse.h以及iniparse.c文件添加到自己的工程目录中就可以,具体方法可以上网百度下。

  • 日志文件

    比如我在做一个电话记录的功能,此时你需要把之前的电话记录记下来,需要记录的项有:电话开始时间、电话号码、通话时间、电话归属地等。此时用上面所说的配置文件格式就不太合适了,一个电话一个section是不合适的。所以这个时候我们可以使用纯文本来记录通话记录。一个通话记录1行,这一行中每一个项目用空格隔开。在读取的时候,通过每一行的格式化读取,我们就可以把这个记录读取出来。

用到的知识以及解决问题的逻辑

所需要的知识点

经过思考,文本的存储本质上时文本的读写操作,所以可以转换为文件I/O的操作。由于我们这涉及到文本的操作,所以我们首选的是带缓冲的文件I/O操作,即fopen、fread、fgets等等标准函数,其实这些函数在实现上也是系统调用的,即这些标准的库(fopen、fread等)在实现上也是调用了open、read等API。

日志存储方案
日志文件读取

对一个日志记录,我们以一台新的手机设备进行类比,假设你现在有一个新的手机,插上了电话卡,你打开你的通话记录,此时你的通话记录是空的,这个时候你所做的操作是去查询电话记录。那么怎么查询呢?当然是去存储器中查询,也就是说此时你需要对磁盘文件进行写。下面这段代码是我读取安防报警txt中的安防报警记录。我们主要关注的是文件I/O的操作。

typedef struct
{
   
    unsigned long timestamp;    //报警时间
    GuardSensor sensor;         //报警传感器, 如烟雾
    GuardStatus status;       	//...
    GuardType type;             //...
    GuardState state;           //...
} GuardLog;

static GuardLog *GuardGetLog(int index)
{
   
	return &guardLogArray[index];
}

static void GuardReadLog()
{
   
	FILE *f = NULL;
    char buf[LENGTH] = {
   0};
    int i = 0, tmp_sensor = 0, tmp_status = 0;
    unsigned long tmp_time = 0;
    GuardLog* entry = NULL;

    f = 
TXTSQL是一种文本数据库,文件存储方式类似mysql,兼容部分sql语句.   PHP需4.0以上版本才能运行。   官方网站:http://txtsql.com/ txtSQL简单例子(来源:http://smvcn.xhblog.com/archives/2007/259845.shtml)   <?php   include('./txtSQL.class.php');   $sql = new txtSQL('./data');   $sql->connect('root', 'bar');   /*创建数据库   $sql->createdb(array('db' => 'demo')) or die('Error creating txtSQL DB, txtSQL said: '.$sql->get_last_error());   */   /*选择数据库*/   $sql->selectdb ( 'demo' );   /*创建表   $columns = array('id' => array('type' => 'int', 'auto_increment' => 1, 'permanent' => 1 ),   'name' => array('type' => 'string', 'max' => 50),   'email' => array('type' => 'string', 'max' => 50)   );   foreach($columns as $k => $v){   echo "\$colums[$k]=";   foreach($v as $k1 => $v1){   echo "$k1:$v1 ";   }   echo "<br>";   }   $sql->execute('create table',array(   'table' => 'table1',   'columns' => $columns)) or die('建表发生错误:'.$sql->get_last_error());   if($sql->table_exists('table1','demo')){   echo "建表成功";   }else{   echo "建表失败";   }   */   /*插入纪录   $value = array(0 => array('name' => 'abc','email' => 'abc@123.com'),   1 => array('name' => '123','email' => '123@bac.com'),   2 => array('name' => 'df','email' => 'reg@bac.com'),   3 => array('name' => 'trt','email' => 'hgh@bac.com'),   4 => array('name' => 'tyty','email' => 'ytyt@bac.com')   );   for($i=0;$i<5;$i++){   echo "\$value[$i]:";   foreach($value[$i] as $k => $v){   echo "[$k]=$v ";   }   echo "<br>";   }   for($i=0;$i<5;$i++){   if(!$sql->execute('insert',array('table' => 'table1','values' => $value[$i] ))){   die('An error occurred, txtSQL said: '.$sql->get_last_error());   }else{   echo "插入成功<br>";   }   }   */   /*修改表数据   $value = array('name' => 'abc','email' => 'aaa@123.com');   if(!$sql->execute('update',array('table' => 'table1','where' => array('id = 1'),'values' => $value))){   die('An error occurred, txtSQL said: '.$sql->get_last_error());   }else{   echo "修改成功";   }   */   /*删除表内容   $delete = array('table' => 'table1','where' => array('id > 1'));   $delcount = $sql->execute('delete',$delete);   echo $delcount;   */   /*显示表内容*/   $select = array('table' => 'table1','orderby' => array('id','asc')/*,'where' => array('email =~ %bac%'),'limit' => array(0,9)*/);   $data = $sql->execute('select',$select);   echo "<table border=1><tr><th>id</th><th>name</th><th>email</th></tr>";   foreach ( $data as $key => $row )   {   echo "<tr>";   foreach($row as $k => $v){   echo "<td>$v</td>";   }   echo "</tr>";   }   echo "</table>";   echo "表内共有 ".$sql->table_count('table1')." 行<BR>";   /*加入主键   $sql->execute('alter table',array('table' => 'table1','action' => 'addkey','name' => 'id','values' => array('name' => 'id')));   */   echo "最后插入ID号:".$sql->last_insert_id('table1') ;   $sql->disconnect();   ?>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值