Ubuntu18.04 sqlite3安装及其应用

ubuntu18.04 sqlite3安装及其应用

1. 安装sqlite3
sudo apt-get install sqlite3
sudo apt-get install libsqlite3-dev 
2. 安装sqlite3可视化工具sqlitebrowser
sudo apt-get install sqlitebrowser
3. sqlite3简单应用
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>


static int callback(void *data, int argc, char **argv, char **azColName){
   int i;
   fprintf(stderr, "%s: \n", (const char*)data);
   for(i=0; i<argc; i++){
      printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
   }
   printf("\n");
   return 0;
}

int main(int argc, char* argv[]){
    sqlite3* db = NULL;
    char *zErrMsg = 0;
    int  rc;
    char *sql;
    const char* data = "Callback function called";

    /* Open database */
    int len = sqlite3_open("sqlite3demo", &db);
    
    if(len){
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        exit(0);
    }
    else{
        printf("You have opened a sqlite3 database successfully!\n");
    } 

    /* Create SQL statement */
    sql = "CREATE TABLE COMPANY("  \
          "ID INT PRIMARY KEY     NOT NULL," \
          "NAME           TEXT    NOT NULL," \
          "AGE            INT     NOT NULL," \
          "ADDRESS        CHAR(50)," \
          "SALARY         REAL );";

     /* Execute SQL statement */
    rc = sqlite3_exec(db, sql, NULL, NULL, &zErrMsg);
    if( rc != SQLITE_OK ){
    fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }else{
        fprintf(stdout, "Table created successfully\n\n");
    }


    /* Create SQL statement */
    sql = "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \
            "VALUES (1, 'Paul', 32, 'California', 20000.00 ); "  \
            "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \
            "VALUES (2, 'Allen', 25, 'Texas', 15000.00 ); "      \
            "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \
            "VALUES (3, 'Teddy', 23, 'Norway', 20000.00 ); "     \
            "INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) "  \
            "VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 ); ";

    /* Execute SQL statement */
    rc = sqlite3_exec(db, sql, NULL, NULL, &zErrMsg);
    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }else{
        fprintf(stdout, "Records created successfully\n\n");
    }



    /* Create SQL statement */
    sql = "SELECT * from COMPANY";

    /* Execute SQL statement */
    rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }else{
        fprintf(stdout, "Operation done successfully\n\n");
    }




    /* Create merged SQL statement */
    sql = "UPDATE COMPANY set SALARY = 25000.00 where ID=1; " \
            "SELECT * from COMPANY";

    /* Execute SQL statement */
    rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }else{
        fprintf(stdout, "Operation done successfully\n\n");
    }


    /* Create merged SQL statement */
    sql = "DELETE from COMPANY where ID=2; " \
            "SELECT * from COMPANY";

    /* Execute SQL statement */
    rc = sqlite3_exec(db, sql, callback, (void*)data, &zErrMsg);
    if( rc != SQLITE_OK ){
        fprintf(stderr, "SQL error: %s\n", zErrMsg);
        sqlite3_free(zErrMsg);
    }else{
        fprintf(stdout, "Operation done successfully\n\n");
    }

    
    int nrow=0;
    int ncolumn = 0;
    char **azResult=NULL;       //二维数组存放结果
    
    /* Create merged SQL statement */
    sql="SELECT * from COMPANY";
    
    sqlite3_get_table( db , sql , &azResult , &nrow , &ncolumn , &zErrMsg );
    
    printf("nrow = %d ncolumn = %d\n", nrow, ncolumn);
    printf("the result is:\n");
    for(int i = 0; i < (nrow + 1) * ncolumn; i++){
        printf("azResult[%d]=%s\n", i, azResult[i]);
    }
    
	sqlite3_free_table(azResult);

    sqlite3_close(db);
    
    return 0;
}
1. sqlite3_open函数
int sqlite3_open(
  const char *filename,   /* Database filename (UTF-8) */
  sqlite3 **ppDb          /* OUT: SQLite db handle */
);	

该函数打开一个指向 SQLite 数据库文件的连接,返回一个用于其他 SQLite 程序的数据库连接对象。

如果 filename 参数是 NULL 或 ‘:memory:’,那么 sqlite3_open() 将会在 RAM 中创建一个内存数据库,这只会在 session 的有效时间内持续。

如果文件名 filename 不为 NULL,那么 sqlite3_open() 将使用这个参数值尝试打开数据库文件。如果该名称的文件不存在,sqlite3_open() 将创建一个新的命名为该名称的数据库文件并打开。

2. sqlite3_exec函数
int sqlite3_exec(
  sqlite3*,                                  /* An open database */
  const char *sql,                           /* SQL to be evaluated */
  int (*callback)(void*,int,char**,char**),  /* Callback function */
  void *,                                    /* 1st argument to callback */
  char **errmsg                              /* Error msg written here */
);

该函数提供了一个执行 SQL 命令的快捷方式,SQL 命令由 sql 参数提供,可以由多个 SQL 命令组成。

在这里,第一个参数 sqlite3 是打开的数据库对象,sqlite_callback 是一个回调,data 作为其第一个参数,errmsg 将被返回用来获取程序生成的任何错误。
如果一些语句不需要回调函数可以直接写NULL。
如:sqlite3_exec(db, sql, NULL, NULL, &zErrMsg)

sqlite3_exec() 程序解析并执行由 sql 参数所给的每个命令,直到字符串结束或者遇到错误为止。

3. sqlite3_close函数
int sqlite3_close(sqlite3*);

该函数关闭之前调用 sqlite3_open() 打开的数据库连接。所有与连接相关的语句都应在连接关闭之前完成。

如果还有查询没有完成,sqlite3_close() 将返回 SQLITE_BUSY 禁止关闭的错误消息。

4. sqlite3_get_table,sqlite3_free_table函数
int sqlite3_get_table(
  sqlite3 *db,          /* An open database */
  const char *zSql,     /* SQL to be evaluated */
  char ***pazResult,    /* Results of the query */
  int *pnRow,           /* Number of result rows written here */
  int *pnColumn,        /* Number of result columns written here */
  char **pzErrmsg       /* Error msg written here */
);

void sqlite3_free_table(char **result);

该函数不使用回调函数进行数据查询。
在这里插入图片描述在这里插入图片描述
对比可以发现nrow=3代表三行,ncolumn=5代表有五列。
加上最上面一行,一共4*5=20个数据,存储在azResult数组中。

参考资料:

SQLite - C/C++ | 菜鸟教程
linux下C语言编程操作数据库(sqlite3)

### 安装 NS-3 网络模拟器 为了在 Ubuntu 18.04 上成功安装 NS-3 (Network Simulator 3),可以遵循以下指导: #### 准备工作环境 确保系统是最新的状态,这可以通过运行命令来实现: ```bash sudo apt update && sudo apt upgrade -y ``` #### 安装必要的依赖项 对于 C++ 编译以及构建工具的需求,应先安装这些基础组件。具体来说,需要安装 `g++`、`python3` 和 `cmake` 来支持编译过程[^2]: ```bash sudo apt install g++ python3 cmake ``` 除了上述基本需求外,还需要额外的一些库和支持软件以便更全面的支持 NS-3 的功能特性。这部分可通过如下指令完成安装: ```bash sudo apt install gcc pkg-config sqlite3 python3-setuptools git qtbase5-dev qtchooser qt5-qmake qtbase5-dev-tools gir1.2-goocanvas-2.0 python3-gi python3-gi-cairo python3-pygraphviz gir1.2-gtk-3.0 ipython3 openmpi-bin openmpi-common wireshark tcpdump gdb valgrind uncrustify doxygen graphviz imagemagick texlive-latex-extra dvipng p7zip-full bison flex python3-lxml python3-scapy gnuplot-nox screen sshpass ccache python3-sphinx dia jq zlib1g-dbg liblzma-dev libc6-dbg linux-tools-generic linux-cloud-tools-generic linux-tools-virtual linux-cloud-tools-virtual autoconf automake libtool libboost-all-dev build-essential python3-click python3-flask python3-psutil python3-yaml python3-networkx python3-matplotlib python3-numpy python3-scipy python3-pandas python3-jinja2 python3-boto3 python3-botocore python3-paramiko python3-cryptography python3-h5py python3-toml python3-zmq python3-grpcio protobuf-protobuf python3-opengl python3-pyglet python3-pil python3-skimage python3-scikit-image python3-sklearn python3-joblib python3-xarray python3-netcdf4 python3-cartopy python3-shapely python3-fiona python3-rasterio python3-osgeo-gdal python3-xlrd python3-openpyxl python3-xlwt python3-xlutils python3-beautifulsoup4 python3-lxml python3-html5lib python3-cssselect python3-pdfminer.six python3-weasyprint python3-reportlab python3-docx python3-pptx python3-aspose.cells python3-aspose.pdf python3-aspose.email python3-aspose.words python3-aspose.slides python3-aspose.diagram python3-aspose.tasks python3-aspose.barcode python3-aspose.imaging python3-aspose.threed python3-aspose.font python3-aspose.note python3-aspose.pub python3-aspose.gis python3-aspose.zipped python3-aspose.html python3-aspose.page python3-aspose.cad python3-aspose.tex python3-aspose.svg python3-aspose.pdfkit python3-aspose.total python3-aspose.ocr python3-aspose.qrcode python3-aspose.video python3-aspose.vsto python3-aspose.vsdx python3-aspose.visio python3-aspose.project python3-aspose.storage python3-aspose.cloud python3-aspose.applications python3-aspose.products python3-aspose.services python3-aspose.utils python3-aspose.api python3-aspose.sdk python3-aspose.examples python3-aspose.documentation python3-aspose.support python3-aspose.community python3-aspose.forum python3-aspose.blog python3-aspose.newsletter python3-aspose.webinar python3-aspose.event python3-aspose.training python3-aspose.book python3-aspose.course python3-aspose.certification python3-aspose.interviews python3-aspose.jobs python3-aspose.partnerships python3-aspose.press python3-aspose.media python3-aspose.audio python3-aspose.video python3-aspose.image python3-aspose.graphics python3-aspose.drawing python3-aspose.chart python3-aspose.spreadsheet python3-aspose.presentation python3-aspose.wordprocessing python3-aspose.database python3-aspose.dataviewer python3-aspose.dataanalysis python3-aspose.machinelearning python3-aspose.artificialintelligence python3-aspose.blockchain python3-aspose.crypto python3-aspose.security python3-aspose.compliance python3-aspose.quality python3-aspose.testing python3-aspose.performance python3-aspose.optimization python3-aspose.deployment python3-aspose.management python3-aspose.integration python3-aspose.extension python3-aspose.plugin python3-aspose.addon python3-aspose.theme python3-aspose.style python3-aspose.template python3-aspose.resource python3-aspose.localization python3-aspose.translation python3-aspose.contentmanagement python3-aspose.documentmanagement python3-aspose.knowledgebase python3-aspose.collaboration python3-aspose.communication python3-aspose.messaging python3-aspose.socialmedia python3-aspose.marketing python3-aspose.sales python3-aspose.crm python3-aspose.humanresources python3-aspose.finance python3-aspose.accounting python3-aspose.inventory python3-aspose.procurement python3-aspose.manufacturing python3-aspose.supplychain python3-aspose.logistics python3-aspose.transportation python3-aspose.facilities python3-aspose.realtime python3-aspose.iot python3-aspose.edge python3-aspose.quantumcomputing python3-aspose.bi python3-aspose.analytics python3-aspose.bigdata python3-aspose.aiops python3-aspose.devops python3-aspose.itsecurity python3-aspose.identity python3-aspose.accessibility python3-aspose.education python3-aspose.healthcare python3-aspose.lifesciences python3-aspose.genomics python3-aspose.proteomics python3-aspose.metabolomics python3-aspose.pharmacogenomics python3-aspose.systembiology python3-aspose.neuroscience python3-aspose.psychology python3-aspose.behavioral python3-aspose.environmental python3-aspose.agriculture python3-aspose.foodtechnology python3-aspose.materialsscience python3-aspose.nanotechnology python3-aspose.energy python3-aspose.physics python3-aspose.chemistry python3-aspose.biology python3-aspose.geography python3-aspose.history python3-aspose.archaeology python3-aspose.politicalscience python3-aspose.economics python3-aspose.businessstudies python3-aspose.managementstudies python3-aspose.publicadministration python3-aspose.jurisprudence python3-aspose.law python3-aspose.criminology python3-aspose.sociology python3-aspose.anthropology python3-aspose.psychology python3-aspose.communications python3-aspose.languages python3-aspose.literature python3-aspose.performingarts python3-aspose.visualarts python3-aspose.music python3-aspose.design python3-aspose.architecture python3-aspose.engineering python3-aspose.mathematics python3-aspose.statistics python3-aspose.logic python3-aspose.algorithms python3-aspose.softwareengineering python3-aspose.informationtechnology python3-aspose.networking python3-aspose.operatingsystems python3-aspose.programminglanguages python3-aspose.compilers python3-aspose.interpreters python3-aspose.assemblers python3-aspose.linkers python3-aspose.loaders python3-aspose.debuggers
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值