sqlite3学习---基础知识、增删改查和排序和限制、打开执行关闭函数

目录

 一、数据库基础知识

1.分类

2.名词

3.嵌入式数据库

4.特点

5.sqlite3的安装

5.1在线安装 

5.2编译

5.3验证是否安装成功

5.4sqlite3的使用

6.创建一个数据库

7.系统维护命令

二、数据库的创建和删除

1.创建一个表

1.1用法

1.2代码示例

2.删除一个表

2.1用法

三、数据库的常规操作:增加,删除,修改,查询

1.向表中增加数据

1.1用法

1.2代码示例

2. 删除表中数据

2.1用法

2.2代码示例

3.修改表中数据

3.1用法

3.2代码示例

4.查询表中的数据

4.1用法

4.2代码示例

5.排序

5.1用法

5.2代码示例

6.限制

6.1用法

6.2代码示例

四、插入时间列

1.用法

2.代码示例

五、自动增长列

1.用法

2.代码示例

六、sqlite3 数据库编程接口

1.需要的头文件

2.编译过程

3.编程框架

3.1 打开数据库---sqlite3_open

3.1.1函数原型

3.1.2功能

3.1.3参数

3.1.4返回值

3.2执行操作---sqlite3_exec

3.2.1功能

3.2.2参数

3.2.3返回值

3.2.4注意

3.3 关闭数据库---sqlite3_close

3.3.1函数原型

3.3.2功能

3.3.3参数

3.3.4返回值

4.代码示例

 一、数据库基础知识

1.分类

大型    中型     小型
ORACLE   MYSQL/MSSQL   SQLITE  DBII powdb
关系型数据库        

2.名词

DB 数据库 select update database
DBMS 数据库管理系统
MIS     管理信息系统
OA      办公自动化

3.嵌入式数据库

sqlite3    www.sqlite.org  www.kernal.org
GNU   

4.特点

  1)开源  C语言开发
  2)代码量少 1万行左右,总大小10M以内
  3)绿色软件无需安装
  4)文件型数据库,可以移动。
  5)数据容量最大 2T   

5.sqlite3的安装

LTS long term support 

5.1在线安装 

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

5.2编译

gcc test.c -lsqlite3 -lpthread

5.3验证是否安装成功

sqlite3 --version
sqlite3 --help

5.4sqlite3的使用

1)启动sqlite3 
sqlite3 xxx.db  
===>用sqlite3 来打开一个名称为test.db的本地数据库。

2)出现如下提示符:表明数据库管理系统启动。
sqlite> 

3)退出数据库: 
    .q 命令

4)注意:如果一直出现如下符号:
...>   
则写'  ;  '结束。

6.创建一个数据库

1)touch  xxx.db
2)sqlite3 xxx.db

7.系统维护命令

    ===> .help

出现所有相关的系统维护命令,都是以 "."开头。

1).database  列出当前库和系统中那个文件在关联

2).tables    列出当期数据库中的所有表

3).schema xxx 列出当前指定的xxx表结构

4).dump user   ===>导出数据库

5)重定向
sqlite3 test.db .dump > 123.sql
sqlite3 xxx.db < test.sql ===>导入数据库

二、数据库的创建和删除

1.创建一个表

1.1用法

1)create table  表名(表字段1,表字段2,...);

eg: create table user(id,name,age);         char 

注意:以上表的表字段,支持如下数据类型。int text real blob
  默认是text类型。char

2)create table 表名 (表字段 类型,表字段 类型,。。。。);

1.2代码示例

2.删除一个表

2.1用法

drop table  表名;

eg:drop table user;

eg: create table user(id int  ,name char,age int);

三、数据库的常规操作:增加,删除,修改,查询

1.向表中增加数据

1.1用法

insert into 表名 (字段名称 ) values (值名称);

eg:insert into user (id,age) values (1,10);

     insert into user values(3,"wang",11);

     insert into user (age) values ( 12);

1.2代码示例

2. 删除表中数据

2.1用法

delete from 表名  满足条件:

eg:delete from user ;  ///删除表中所有数据
       delete from user where id  = 1; ///删除id=1 的数据;
        delete from user where id =1 and name = "zhang";
        delete from user where id = 1 or id  = 2;

2.2代码示例

3.修改表中数据

3.1用法

update 表名 set 表字段 = 值  满足条件:

eg: update user set id = 1 where name = 'li';
         update user set id = 1 where name = "li" and passwd = "123";
         update user set id = 2 where name = "li" or  name = "zhao";

3.2代码示例

4.查询表中的数据

4.1用法

select 列名 from 表名  条件;

eg:select * from user ;
       select id from user;
       select id,name from user where not  age <30

1)where name

2)like '三一'   

3)通配符:%   、 _ 

4)and   or  & &  ||

5)asc

6)select *from user where age>20 or age<50 order by age desc limit 2 ;

4.2代码示例

模糊查找

5.排序

5.1用法

select *from user order by id; 正序

select *from user order by id desc; 倒序

eg:select *from user where age>20 or age<50 order by age desc limit 2 ;

5.2代码示例

6.限制

6.1用法

where (group by having) order by [desc] limit;

select * from user where id<10 order by id limit 2;  

6.2代码示例

要最后的十个

四、插入时间列

1.用法

CREATE TABLE user1(id int,name char,age int,dt datetime);'2022-07-01 19:00:00'

insert into user1 values (2,'张三',23,datetime('now','+8 hours'));

2.代码示例

五、自动增长列

1.用法

sqlite> CREATE TABLE user3(id INTEGER PRIMARY KEY ASC,name char,age int,dt datetime);  主键 
sqlite> insert into user3 (NULL,'李四',23,datetime('now'));   

2.代码示例

六、sqlite3 数据库编程接口

1.需要的头文件

sqlite3.h

2.编译过程

-lsqlite3

3.编程框架

打开数据库 ==》读写数据库(增,删,改,查) ==》关闭数据库

3.1 打开数据库---sqlite3_open

3.1.1函数原型

int sqlite3_open(char * path,sqlite3 ** db);

3.1.2功能

打开指定path路径+文件名称的数据库,并将打开的地址指向db变量的句柄。

3.1.3参数

path 要打开的数据库路径+名称
db  要打开的数据库地址指针

3.1.4返回值

成功  0
失败  -1;

3.2执行操作---sqlite3_exec

3.2.1功能

该函数用于sqlite3_exec执行select语句的
 结果集返回数据。

3.2.2参数

arg 由sqlite3_exec传入的参数
  f_num 执行该命令所返回测结果集的字段个数。
  f_value 查询结果集中的字段的值。
  f_name  查询结果集中的字段的名称。

3.2.3返回值

成功 0
失败 非0

3.2.4注意

该回调函数必须有返回值,否则可能导致查询异常。

3.3 关闭数据库---sqlite3_close

3.3.1函数原型

int sqlite3_close(sqlite3 *db);

3.3.2功能

关闭指定的数据库

3.3.3参数

要关闭的数据库地址

3.3.4返回值

成功  0
失败  -1;

4.代码示例

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/916751.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/916751.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Class24AlexNet

Class24AlexNet AlexNet AlexNet于2012年ImageNet 图像识别挑战赛&#xff08;ILSVRC-2012&#xff09;中以 top-5 错误率15.3%获得冠军&#xff0c;远远领先第二名。它首次在大型图像数据集上证明了深层卷积神经网络的强大能力。 AlexNet 的总体结构 AlexNet 总共有 8 层具有学…

枚举中间位置高级篇

参考资料来源灵神在力扣所发的题单&#xff0c;仅供分享学习笔记和记录&#xff0c;无商业用途。 核心思路&#xff1a;参考枚举中间位置基础篇-CSDN博客 力扣题单练习(灵神题单中摘取题目) 447. 回旋镖的数量 核心思路&#xff1a; 因给出的点都不相同&#xff0c;所以不会…

主数据管理系统能代替数据中台吗?

目录 一、主数据管理系统≠数据中台 1. 主数据管理系统&#xff1a;管的是 “不变的核心数据” 2. 数据中台&#xff1a;管的是 “流动中的价值” 二、为什么企业更该先建 MDM&#xff1f; 1. 数据中台解决不了数据本身问题 2. MDM 可以解决常见的基础问题 3. 数字化转型…

Nmap 终极教程:安装、常用命令及法律法规指南

Nmap 终极教程&#xff1a;安装、常用命令及法律法规指南 Nmap&#xff08;Network Mapper&#xff09;是一款强大的 网络扫描和安全审计工具&#xff0c;广泛用于渗透测试、网络探测和系统管理。本教程涵盖 安装方法、常用命令详解、输出解析 以及 法律法规注意事项&#xff…

开源嵌入式数组引擎TileDB的简单使用

TileDB 是C编写的存储和访问通用多维数组引擎&#xff0c;它的官方Github网站https://github.1git.de/TileDB-Inc/TileDB 1.下载源代码和二进制库 源代码https://github.1git.de/TileDB-Inc/TileDB/archive/refs/tags/2.28.1.tar.gz 选择符合你的机器CPU架构和操作系统的库 二进…

AI对服务器行业的冲击与启示:从挑战走向重构

更多云服务器知识&#xff0c;尽在hostol.comAI&#xff08;人工智能&#xff09;技术的迅猛发展&#xff0c;已深刻影响了多个行业&#xff0c;服务器行业亦不例外。在过去&#xff0c;服务器的主要任务是简单地提供存储、计算和传输数据的服务。然而&#xff0c;随着AI的崛起…

基于三台主机搭建 Web 服务环境:Nginx、NFS 与 DNS 配置全流程

基于三台主机搭建 Web 服务环境&#xff1a;Nginx、NFS 与 DNS 配置全流程 一、引言 在当今数字化的时代&#xff0c;搭建一个稳定、高效的 Web 服务环境是许多开发者和运维人员的常见需求。本文将详细介绍如何利用三台主机搭建一个包含 Nginx、NFS 和 DNS 服务的 Web 环境&…

MySQL——MVCC

1.为什么需要MVCC在并发场景下&#xff0c;读写操作会面临严重的冲突问题&#xff1a;1.读操作如果遇到写操作&#xff0c;要么“读到未提交的脏数据”&#xff0c;要么“被写操作阻塞&#xff08;等待锁释放&#xff09;”&#xff1b;2.写操作如果遇到读操作&#xff0c;要么…

数据结构第2问:什么是算法?

算法 算法是一组用于解决具体问题的、明确的、有序的步骤或规则&#xff0c;能够在有限的时间内通过这些步骤得到问题的答案。 算法的5个重要特性&#xff1a; 有穷性&#xff1a;算法必须在有限的步骤内结束&#xff0c;不能无限循环&#xff0c;保证最终能够得到结果。确定性…

12-大语言模型—Transformer 打地基,下游任务盖出百样房,指标来验收|下游任务白话指南

目录 1、核心逻辑&#xff1a;Transformer 的 “语言处理闭环” 2、转导与感知 → 模型咋 “理解语言”&#xff1f; 2.1、 人类 vs 机器的 “语言理解逻辑” 2.2、 自注意力机制&#xff1a;模型 “理解语言” 的数学核心 2.2.1、通俗拆解 2.2.1.1、是什么&#xff1f; …

深入探索爬虫与自动化脚本:释放效率的利器

在当今信息爆炸的时代&#xff0c;高效获取和处理数据已成为核心竞争力。爬虫与自动化脚本正是解决这一痛点的关键技术——它们如同数字世界的勤劳助手&#xff0c;帮我们自动完成繁琐重复的任务。下面我们来系统了解这两项技术的核心要点、应用场景和最佳实践。一、爬虫与自动…

React函数组件的“生活管家“——useEffect Hook详解

&#x1f3af; React函数组件的"生活管家"——useEffect Hook详解 1. &#x1f31f; 开篇&#xff1a;从生活中的"副作用"说起 嘿&#xff0c;各位掘友们&#xff01;今天咱们来聊聊React函数组件里的一个“大管家”——useEffect Hook。你可能会问&#x…

python基础:request请求Cookie保持登录状态、重定向与历史请求、SSL证书校验、超时和重试失败、自动生成request请求代码和案例实践

Cookie保持登录状态cookie session鉴权机制 cookie是由web服务器保存在用户浏览器&#xff08;客户端&#xff09;上的小文本文件&#xff0c;他可以包含有关用户的信息。无论何时用户访问到服务器&#xff0c;都会带上该服务器的cookie信息&#xff0c;一般cookie都是有有效期…

Vulkan入门教程 | 第二部分:创建实例

前言&#xff1a;本教程为笔者依据教程https://docs.vulkan.net.cn/spec/latest/index.html#_about进行Vulkan学习并结合自己的理解整理的笔记&#xff0c;供大家学习和参考。 &#xff08;注意&#xff1a;代码仅为片段&#xff0c;非完整程序&#xff09; 学习前提&#xff1…

PHP云原生架构:容器化、Kubernetes与Serverless实践

引言 随着云计算的普及,PHP应用也在向云原生架构演进。本文将深入探讨PHP在云原生环境中的最佳实践,包括容器化部署、Kubernetes编排、Serverless架构以及云原生监控与日志方案,帮助开发者构建现代化、可扩展的PHP应用。 容器化PHP应用 基础Dockerfile优化 # 多阶段构建…

【华为机试】5. 最长回文子串

文章目录5. 最长回文子串描述示例 1示例 2示例 3示例 4提示解题思路方法一&#xff1a;中心扩展法&#xff08;推荐&#xff09;方法二&#xff1a;动态规划方法三&#xff1a;Manacher算法方法四&#xff1a;暴力解法代码实现复杂度分析测试用例完整题解代码5. 最长回文子串 …

【图像处理基石】如何对遥感图像进行实例分割?

遥感图像实例分割是指在遥感影像中&#xff0c;不仅要识别出不同类别的目标&#xff08;如建筑物、车辆、道路等&#xff09;&#xff0c;还要区分同一类别中的不同个体&#xff08;如建筑物1、建筑物2&#xff09;&#xff0c;并为每个实例生成精确的像素级掩码。 一、遥感图…

电子电气架构 --- 软件bug的管理模式

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 简单,单纯,喜欢独处,独来独往,不易合同频过着接地气的生活,除了生存温饱问题之外,没有什么过多的欲望,表面看起来很高冷,内心热情,如果你身…

【每日一错】Oracle 19c CDB中如何启动一个PDB

文章目录题目扩展学习CDB与PDB的概念CDB&#xff0c;PDB结构优势总结题目 扩展学习 CDB与PDB的概念 在Oracle 12c及以上版本&#xff0c;Oracle引入了多租户架构&#xff0c;这种架构让数据库的管理和资源使用更加高效。它由两种主要组成部分组成&#xff1a; CDB&#xff0…

Android studio自带的Android模拟器都是x86架构的吗,需要把arm架构的app翻译成x86指令?

Android studio自带的Android模拟器都是x86架构的吗&#xff0c;需要把arm架构的app翻译成x86指令&#xff1f; deepseek回答&#xff1a; Android Studio 自带的官方模拟器&#xff08;Android Emulator&#xff09;主要提供基于 x86 架构的系统镜像。当运行 ARM 架构的应用…