在虚拟机中搭建SQLITE环境,并测试其是否安装成

简介:

1.下载压缩包后解压sqlite-3.6.3tar.gz到/home目录下

复制代码
tar -zxvf sqlite-3.6.3tar.gz -C /home

cd /home/

mkdir sqlite-ix86-linux/

cd /home/sqlite-ix86-linux/

/sqlite-3.6.3/configure --prefix=/home/sqlite-ix86-linux/
复制代码

其中--prefix=/home/sqlite-ix86-linux/的意思是将configure是用来进行用户个性配置的工具, 一般- -开头的说明的是需要配置的选项,--prefix就是说软件额安装目录设置在哪里,后面的=/usr就是你给出的安装目录,当然你完全可以换一个目录。

2.编译并安装,然后生成帮助文档

Make && make install && make doc

3.此时库文件已经生成在/home/sqlite-ix86-linux/lib目录下

可执行文件sqlite3已经生成在/home/sqlite-ix86-linux/bin目录下

4.测试编译安装是否成功

在命令行直接输入:/home/sqlite-ix86-linux/bin/sqlite3 test.db

当我们运行完这一句的时候,test.db会存在于当前的目录下。查看当前目录的命令pwd。

clip_image002_thumb

出现了SQLITE的版本号即其他信息,并且数据库test.db创建成功,表明编译安装已经成功

5.在程序中操作数据库

注:我的程序是在KDevelop中开发的。如果出现编译不通过的问题,请查看下文可能出现的问题。

复制代码
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <stdio.h>
#include <stdlib.h>

#include <sqlite3.h>
int main()
{
    sqlite3 *db=NULL;
    char *zErrMsg=0,*sql=NULL;
    int rc;
        //char *sql;
    rc=sqlite3_open("test.db",&db);
    if(rc)
    {
    fprintf(stderr,"can't open database:%s\n",sqlite3_errmsg(db));
    sqlite3_close(db);
    return 0;
    }
    else printf("you have opend a selite3 database3 named test.db successfully!\ncongraturations! have fun!\n");
    sqlite3_exec(db,sql,0,0,&zErrMsg);

    //创建一个表,如果该表存在,则不创建,并给出提示信息,存储在 zErrMsg 中
    sql = "CREATE TABLE SensorData(\
    ID INTEGER PRIMARY KEY,\
    SensorID INTEGER,\
    SiteNum INTEGER, \
    Time VARCHAR(12), \
    SensorParameter REAL \
    );";
    sqlite3_exec( db , sql , 0 , 0 , &zErrMsg );
    printf("ErrorMsg:%s",zErrMsg);
    //插入数据 
    sql = "INSERT INTO \"SensorData\" VALUES( NULL , 1 , 1 , '201205011206', 18.9 );" ;
    sqlite3_exec( db , sql , 0 , 0 , &zErrMsg );
    
    sql = "INSERT INTO \"SensorData\" VALUES( NULL , 1 , 1 , '201205011306', 16.4 );" ;
    sqlite3_exec( db , sql , 0 , 0 , &zErrMsg );
    sqlite3_close(db);
    return 0;
}
复制代码

运行完以下代码后,我们就可以在

你的工程目录/程序目录/debug/src/中看到test.db这个文件了。

image_thumb[5]

下面让我们输入一些命令看看表中的数据

image_thumb[4]

 

可能出现的错误:

1、用KDevelop编译的时候总是会出现错误,如下所示

提示如下错误: main.o(.text+0x9b):main.cpp: undefined reference to `sqlite3_open' 
main.o(.text+0xcb):main.cpp: undefined reference to `sqlite3_exec' 
main.o(.text+0xda):main.cpp: undefined reference to `sqlite3_close' 
main.o(.text+0x10d):main.cpp: undefined reference to `sqlite3_close' 
main.o(.text+0x14b):main.cpp: undefined reference to `sqlite3_errmsg' 
main.o(.text+0x173):main.cpp: undefined reference to `sqlite3_close' 明显示找不到lib库文件,

解决方法:在Kdevelop中添加SQLite的静态链接库

具体步骤: 
Kdevlop的project options->配置选项->C程序->编译器标志中写入如下参数: 
-L/home/sqlite-ix86-linux/lib -lsqlite3

其中/home/sqlite-ix86-linux/是你sqlite的安装目录。如果还不清楚,请参照下图操作

image_thumb

图1 打开project options

image

图2 设置编译器标志

 image
 


2、sqlite3如何退出...>状态,你会了吗?

一般是进入SQL数据语言模式了,此时要想退出…>状态,只要输入一条完整的SQL语句就行了,也就是末尾要加上;(分号)这个符号就可以退回到sqlite>状态

3、sqlite不会把附加过的数据库文件统一管理。
习惯了使用SQL Server Management Studio了,在SQL Server Management Studio中当数据库被附加过了,那么我们就可以通过SQL Server Management Studio进行管理,而不必每次使用,每次都进行附加。但是在sqlite中,附加过的数据库不会在sqlite中存有什么记录,如果要再次管理某个数据库,你需要再次运行sqlite3 数据库名,才能进行数据库的操作。这一点很重要,之前我就在这个地方困惑了很久。


参考连接

./configure --prefix=/usr 什么意思

Linux环境变量的设置和查看方法

本文转自陈哈哈博客园博客,原文链接http://www.cnblogs.com/kissazi2/archive/2013/06/14/3135222.html如需转载请自行联系原作者

kissazi2
相关文章
|
1月前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
43 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
1月前
|
缓存 Ubuntu Linux
Linux环境下测试服务器的DDR5内存性能
通过使用 `memtester`和 `sysbench`等工具,可以有效地测试Linux环境下服务器的DDR5内存性能。这些工具不仅可以评估内存的读写速度,还可以检测内存中的潜在问题,帮助确保系统的稳定性和性能。通过合理配置和使用这些工具,系统管理员可以深入了解服务器内存的性能状况,为系统优化提供数据支持。
41 4
|
1月前
|
机器学习/深度学习 自然语言处理 前端开发
前端神经网络入门:Brain.js - 详细介绍和对比不同的实现 - CNN、RNN、DNN、FFNN -无需准备环境打开浏览器即可测试运行-支持WebGPU加速
本文介绍了如何使用 JavaScript 神经网络库 **Brain.js** 实现不同类型的神经网络,包括前馈神经网络(FFNN)、深度神经网络(DNN)和循环神经网络(RNN)。通过简单的示例和代码,帮助前端开发者快速入门并理解神经网络的基本概念。文章还对比了各类神经网络的特点和适用场景,并简要介绍了卷积神经网络(CNN)的替代方案。
148 1
|
2月前
|
自然语言处理 机器人 Python
ChatGPT使用学习:ChatPaper安装到测试详细教程(一文包会)
ChatPaper是一个基于文本生成技术的智能研究论文工具,能够根据用户输入进行智能回复和互动。它支持快速下载、阅读论文,并通过分析论文的关键信息帮助用户判断是否需要深入了解。用户可以通过命令行或网页界面操作,进行论文搜索、下载、总结等。
72 1
ChatGPT使用学习:ChatPaper安装到测试详细教程(一文包会)
|
1月前
|
编解码 安全 Linux
网络空间安全之一个WH的超前沿全栈技术深入学习之路(10-2):保姆级别教会你如何搭建白帽黑客渗透测试系统环境Kali——Liinux-Debian:就怕你学成黑客啦!)作者——LJS
保姆级别教会你如何搭建白帽黑客渗透测试系统环境Kali以及常见的报错及对应解决方案、常用Kali功能简便化以及详解如何具体实现
|
2月前
|
分布式计算 Hadoop 大数据
大数据体系知识学习(一):PySpark和Hadoop环境的搭建与测试
这篇文章是关于大数据体系知识学习的,主要介绍了Apache Spark的基本概念、特点、组件,以及如何安装配置Java、PySpark和Hadoop环境。文章还提供了详细的安装步骤和测试代码,帮助读者搭建和测试大数据环境。
84 1
|
2月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
2月前
|
前端开发 JavaScript 应用服务中间件
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
本文是一篇详细的教程,介绍了如何在Linux系统上安装和配置nginx,以及如何将打包好的前端项目(如Vue或React)上传和部署到服务器上,包括了常见的错误处理方法。
851 0
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
|
2月前
|
测试技术 PHP 开发工具
php性能监测模块XHProf安装与测试
【10月更文挑战第13天】php性能监测模块XHProf安装与测试
36 0
|
1月前
|
Ubuntu 网络安全 虚拟化
VMware虚拟机ping不通原因排查及分析
下面以 VMware 虚拟机为例进行介绍。
843 3