自学嵌入式day41,数据库

数据库可根据规模分为大型(如Oracle)、中型(如MySQL/MSSQL)和小型(如SQLite)。常见类型包括关系型数据库,它使用结构化查询语言(SQL)进行管理。相关名词包括:

  • DB(数据库):存储数据的实体。
  • DBMS(数据库管理系统):软件系统,用于管理数据库。
  • MIS(管理信息系统):集成数据库的业务系统。
  • OA(办公自动化):利用数据库的办公应用。
嵌入式数据库与SQLite

SQLite(www.sqlite.org)是一个开源的嵌入式数据库,由C语言开发,常用于Linux内核(www.kernel.org)和GNU项目。其特点包括:

  1. 开源且代码量少(约1万行),总大小在10MB以内。
  2. 绿色软件,无需安装即可使用。
  3. 文件型数据库,数据库文件可移动。
  4. 支持数据容量高达2TB。
安装与编译

在Linux系统中,安装SQLite及其开发库的命令如下:

bash 复制代码
sudo apt-get install sqlite3
sudo apt-get install libsqlite3-dev

编译SQLite程序时,使用gcc链接SQLite库:

bash 复制代码
gcc test.c -lsqlite3
SQLite终端指令

在SQLite命令行界面中,常用指令包括:

  • .database:查看关联的数据库文件。
  • .table:列出数据库中的表。
  • .schema:显示表的创建语句。
  • .q.quit.exit:退出数据库。
  • .header on:启用表头显示。
SQL语句基础

SQL语句必须以分号结尾。以下是基本操作示例:

  • 创建表 :定义表结构。

    sql 复制代码
    CREATE TABLE user(id INT, name CHAR, age INT);
  • 删除表 :移除表及其数据。

    sql 复制代码
    DROP TABLE user;
  • 插入数据 :添加新记录。

    sql 复制代码
    INSERT INTO user VALUES(3, 'wang', 11);
  • 查询数据 :检索满足条件的记录。

    sql 复制代码
    SELECT * FROM user WHERE age > 20 OR age < 50;
  • 修改数据 :更新现有记录。

    sql 复制代码
    UPDATE user SET id = 1 WHERE name = 'li';
  • 删除数据 :移除指定记录。

    sql 复制代码
    DELETE FROM user WHERE id = 1 OR id = 2;
SQLite编程(C语言API)

SQLite提供了C API用于数据库操作,基本步骤为:

  1. 打开数据库 :使用sqlite3_open函数。
  2. 执行SQL语句 :使用sqlite3_exec函数。
  3. 关闭数据库 :使用sqlite3_close函数。

以下是一个完整示例,演示如何插入数据:

c 复制代码
#include <sqlite3.h>
#include <stdio.h>

int main(int argc, char** argv) {
    sqlite3* db = NULL;
    int ret = sqlite3_open("123.db", &db);  // 打开数据库文件
    if (ret != SQLITE_OK) {
        fprintf(stderr, "sqlite3_open error: %s\n", sqlite3_errmsg(db));
        sqlite3_close(db);
        return 1;
    }

    char* errmsg = NULL;
    char sql_cmd[512] = "INSERT INTO user VALUES(6, 'lvbu', 31);";  // SQL插入语句
    ret = sqlite3_exec(db, sql_cmd, NULL, NULL, &errmsg);  // 执行语句

    if (ret != SQLITE_OK) {
        fprintf(stderr, "sqlite3_exec error: %s\n", errmsg);
        sqlite3_free(errmsg);  // 释放错误消息内存
        sqlite3_close(db);
        return 1;
    }

    sqlite3_close(db);  // 关闭数据库
    return 0;
}
相关推荐
尽兴-13 小时前
JVM对象创建与内存分配机制
jvm·指针压缩·内存分配机制·对象分配策略·分代模型
人道领域13 小时前
javaWeb从入门到进阶(MYSQL)
数据库·mysql·oracle
liux352813 小时前
MySQL读写分离全面解析:ProxySQL配置指南(十)
数据库·mysql
人工干智能13 小时前
LlamaIndex:使用向量数据库进行检索,loaded_query_engine.query(“..........?“)
数据库·llm
咸鱼翻身小阿橙13 小时前
SQL上半部分
服务器·数据库·sql
Elastic 中国社区官方博客13 小时前
Elasticsearch:监控 LLM 推理和 Agent Builder 使用 OpenRouter
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
知识分享小能手13 小时前
Oracle 19c入门学习教程,从入门到精通,Oracle 数据表对象 —— 语法知识点详解与案例实践(10)
数据库·学习·oracle
Gobysec13 小时前
Goby 漏洞安全通告|GNU InetUtils Telnetd USER环境变量注入 权限绕过漏洞(CVE-2026-24061)
数据库·安全·gnu·漏洞分析·漏洞预警
wregjru13 小时前
【QT】2.QT 信号和槽
数据库
麦兜*13 小时前
SpringBoot Profile多环境配置详解,一套配置应对所有场景
java·数据库·spring boot