linux sqlite3 数据库的安装与使用

简介: linux sqlite3 数据库的安装与使用

1, 本地安装,官网下载

sudo dpkg -i *.deb

2, 在线安装

sudo apt-get install sqlite3
sudo apt-get install libsqlite3-dev

安装完成后通过命令操作:
创建数据库
sqlite3 stu.db

在该数据库中创建表 stu
create table stu(id integer, name char, score integer);

查看有数据库表的结构图
.schema

查看
.table

插入数据
insert into stu values(1001, "zhangsan", 80);

查询
select * from stu

插入部分数据
insert into stu (name, score)values(1003, "wangwu");

删除数据
delete from stu

更新一个数据
update stu set name='wangwu' where id=1001;

查看打开的数据库
.databases

更改表, 插入一列
alter table stu add column address char;

删除一列,需要新建表,将原有表数据导入
create table stul as select id, name, score from stu;

删除表
drop table stu;

更改表的名字
alter table stu1 rename to stu;

通过c语言代码操作:
先通过命令创建表
create table usr (date text, chat text, from1 int, to1 int, state int);

插入数据
sprintf 通过拼接字符串发数据库命令
get_date(date);
sprintf(buf, "insert into usr values('%s', %d, %d, %d)", date, client_in.buf, client_in.host,client_in.dst, state);
if (sqlite3_exec(db, buf, NULL, NULL, &errmsg) != SQLITE_OK)
{

printf("%s", errmsg);
return -1;

}

简单的例子:

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

#define DATABASE  "stu.db"

int do_insert(sqlite3 *db)
{
    int id;
    char name[32] = {};
    int score;
    char *errmsg;
    char sql[128] = {};

    printf("input id:");
    scanf("%d", &id);

    printf("input name");
    scanf("%s", name);

    printf("input score");
    scanf("%d", &score);
    
    sprintf(sql, "insert into stu values(%d, %s, %d);", id, name, score);
    
    if (sqlite3_exec(db, sql, NULL, NULL, &errmsg) != SQLITE_OK)
    {
        printf("errmsg: %s\n", errmsg);
        return -1;
    }
    printf("insert success\n");
    return 0;
}


int do_delect(sqlite3 *db)
{
    int id;
    char *errmsg;
    char sql[128] = {};

    printf("input id:");
    scanf("%d", &id);
    
    sprintf(sql, "delete from stu where id = %d;", id);
    
    if (sqlite3_exec(db, sql, NULL, NULL, &errmsg) != SQLITE_OK)
    {
        printf("errmsg: %s\n", errmsg);
        return -1;
    }
    printf("delect done\n");
    return 0;
}


int do_update(sqlite3 *db)
{
    int id;
    int score;
    char *errmsg;
    char sql[128] = {};

    printf("update id:");
    scanf("%d", &id);

    printf("update score");
    scanf("%d", &score);
    
    sprintf(sql, "update stu set score = %d where id = %d;", score, id);
    
    if (sqlite3_exec(db, sql, NULL, NULL, &errmsg) != SQLITE_OK)
    {
        printf("errmsg: %s\n", errmsg);
        return -1;
    }
    printf("update done\n");
    return 0;
}

int callback(void *para, int f_num, char **f_value, char **f_name)
{
    int i = 0;

    for (i = 0; i < f_num; i++)
    {
        printf("%-11s", f_value[i]);
    }
    putchar(10);

    return 0;
}

int do_query(sqlite3 *db)
{
    char sql[128] = {};
    char *errmsg;
    
    sprintf(sql, "select * from stu;");

    if (sqlite3_exec(db, sql, callback, NULL, &errmsg) != SQLITE_OK)
    {
        printf("%s\n", errmsg);
    }
    else
    {
        printf("query done\n");
    }
}

int do_quit(sqlite3 *db)
{
    sqlite3_close(db);
}

int do_query1(sqlite3 *db)
{
    int i, j;
    char sql[128] = {};
    char **pazResult;
    int pnRow;       /* Number of result rows written here */
     int pnColumn; 
    char *errmsg;
    int index = 0;

    sprintf(sql, "select * from stu;");

    if (sqlite3_get_table(db, sql, &pazResult, &pnRow, &pnColumn, &errmsg)!= SQLITE_OK)
    {
        printf("%s\n", errmsg);
    }
    
    for (i = 0; i < pnRow; i++)
    {
        for(j = 0; j < pnColumn; j++)
            printf("%-11s ", pazResult[index++]);
        putchar(10);
    }
    return 0;
}

int main(int arge, char *argv[])
{
    sqlite3 *db;
    char *errmsg;
    int cmd;

    if ((sqlite3_open(DATABASE, &db)) != SQLITE_OK)
    {
        printf("%s\n", sqlite3_errmsg(db));
        return -1;
    }

    if (sqlite3_exec(db, "create table stu (id integer, name char, score integer);", NULL, NULL, &errmsg) != SQLITE_OK)
    {
        printf("%s\n", errmsg);
    }

    printf("creaete table or open success\n");
    printf("%d\n", SQLITE_OK);
    while(1)
    {
        printf("*******************\n");
        printf("1:insert 2:delect 3:query 4:update 5:quit\n");
        scanf("%d", &cmd);

        switch(cmd)
        {
            case 1:
                do_insert(db);
                break;
            case 2:
                do_delect(db);
                break;
            case 3:
                do_query(db);
                //do_query1(db);
                break;
            case 4:
                do_update(db);
                break;
            case 5:
                do_quit(db);
                return 0;
            default:
                printf("ERROR cmd \n");
        }
    }
    return 0;
}
相关文章
|
13天前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
59 8
|
1月前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
211 15
|
1月前
|
关系型数据库 MySQL Linux
MySQL数据库下载安装教程(Windows&Linux)
本文档详细介绍了MySQL的安装步骤,包括安装前的准备工作、下载安装包、Windows和Linux系统下的具体安装流程,以及如何配置MySQL服务、设置环境变量、启动服务和连接数据库等关键操作。
|
16天前
|
SQL Java 数据库连接
JDBC编程安装———通过代码操控数据库
本文,教你从0开始学习JBCD,包括驱动包的下载安装调试设置,以及java是如何通过JBDC实现对数据库的操作,以及代码的分析,超级详细
|
2月前
|
数据库连接 Linux Shell
Linux下ODBC与 南大通用GBase 8s数据库的无缝连接配置指南
本文详细介绍在Linux系统下配置GBase 8s数据库ODBC的过程,涵盖环境变量设置、ODBC配置文件编辑及连接测试等步骤。首先配置数据库环境变量如GBASEDBTDIR、PATH等,接着修改odbcinst.ini和odbc.ini文件,指定驱动路径、数据库名称等信息,最后通过catalog.c工具或isql命令验证ODBC连接是否成功。
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
|
2月前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
116 1
|
2月前
|
网络安全 数据库
gbase 8a 数据库 安装8ampp 常见ssh报错问题
gbase 8a 数据库 安装8ampp 常见ssh报错问题
|
2月前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
220 0
|
19天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
45 3