【PostgreSQL】从零开始:(八)PostgreSQL-数据库PSQL元命令
元命令
postgres=# \?
General\bind [PARAM]... set query parameters\copyright show PostgreSQL usage and distribution terms\crosstabview [COLUMNS] execute query and display result in crosstab\errverbose show most recent error message at maximum verbosity\g [(OPTIONS)] [FILE] execute query (and send result to file or |pipe);\g with no arguments is equivalent to a semicolon\gdesc describe result of query, without executing it\gexec execute query, then execute each value in its result\gset [PREFIX] execute query and store result in psql variables\gx [(OPTIONS)] [FILE] as \g, but forces expanded output mode\q quit psql\watch [[i=]SEC] [c=N] execute query every SEC seconds, up to N timesHelp\? [commands] show help on backslash commands\? options show help on psql command-line options\? variables show help on special variables\h [NAME] help on syntax of SQL commands, * for all commandsQuery Buffer\e [FILE] [LINE] edit the query buffer (or file) with external editor\ef [FUNCNAME [LINE]] edit function definition with external editor\ev [VIEWNAME [LINE]] edit view definition with external editor\p show the contents of the query buffer\r reset (clear) the query buffer\s [FILE] display history or save it to file\w FILE write query buffer to fileInput/Output\copy ... perform SQL COPY with data stream to the client host\echo [-n] [STRING] write string to standard output (-n for no newline)\i FILE execute commands from file\ir FILE as \i, but relative to location of current script\o [FILE] send all query results to file or |pipe\qecho [-n] [STRING] write string to \o output stream (-n for no newline)\warn [-n] [STRING] write string to standard error (-n for no newline)Conditional\if EXPR begin conditional block\elif EXPR alternative within current conditional block\else final alternative within current conditional block\endif end conditional blockInformational(options: S = show system objects, + = additional detail)\d[S+] list tables, views, and sequences\d[S+] NAME describe table, view, sequence, or index\da[S] [PATTERN] list aggregates\dA[+] [PATTERN] list access methods\dAc[+] [AMPTRN [TYPEPTRN]] list operator classes\dAf[+] [AMPTRN [TYPEPTRN]] list operator families\dAo[+] [AMPTRN [OPFPTRN]] list operators of operator families\dAp[+] [AMPTRN [OPFPTRN]] list support functions of operator families\db[+] [PATTERN] list tablespaces\dc[S+] [PATTERN] list conversions\dconfig[+] [PATTERN] list configuration parameters\dC[+] [PATTERN] list casts\dd[S] [PATTERN] show object descriptions not displayed elsewhere\dD[S+] [PATTERN] list domains\ddp [PATTERN] list default privileges\dE[S+] [PATTERN] list foreign tables\des[+] [PATTERN] list foreign servers\det[+] [PATTERN] list foreign tables\deu[+] [PATTERN] list user mappings\dew[+] [PATTERN] list foreign-data wrappers\df[anptw][S+] [FUNCPTRN [TYPEPTRN ...]]list [only agg/normal/procedure/trigger/window] functions\dF[+] [PATTERN] list text search configurations\dFd[+] [PATTERN] list text search dictionaries\dFp[+] [PATTERN] list text search parsers\dFt[+] [PATTERN] list text search templates\dg[S+] [PATTERN] list roles\di[S+] [PATTERN] list indexes\dl[+] list large objects, same as \lo_list\dL[S+] [PATTERN] list procedural languages\dm[S+] [PATTERN] list materialized views\dn[S+] [PATTERN] list schemas\do[S+] [OPPTRN [TYPEPTRN [TYPEPTRN]]]list operators\dO[S+] [PATTERN] list collations\dp[S] [PATTERN] list table, view, and sequence access privileges\dP[itn+] [PATTERN] list [only index/table] partitioned relations [n=nested]\drds [ROLEPTRN [DBPTRN]] list per-database role settings\drg[S] [PATTERN] list role grants\dRp[+] [PATTERN] list replication publications\dRs[+] [PATTERN] list replication subscriptions\ds[S+] [PATTERN] list sequences\dt[S+] [PATTERN] list tables\dT[S+] [PATTERN] list data types\du[S+] [PATTERN] list roles\dv[S+] [PATTERN] list views\dx[+] [PATTERN] list extensions\dX [PATTERN] list extended statistics\dy[+] [PATTERN] list event triggers\l[+] [PATTERN] list databases\sf[+] FUNCNAME show a function's definition\sv[+] VIEWNAME show a view's definition\z[S] [PATTERN] same as \dpLarge Objects\lo_export LOBOID FILE write large object to file\lo_import FILE [COMMENT]read large object from file\lo_list[+] list large objects\lo_unlink LOBOID delete a large objectFormatting\a toggle between unaligned and aligned output mode\C [STRING] set table title, or unset if none\f [STRING] show or set field separator for unaligned query output\H toggle HTML output mode (currently off)\pset [NAME [VALUE]] set table output option(border|columns|csv_fieldsep|expanded|fieldsep|fieldsep_zero|footer|format|linestyle|null|numericlocale|pager|pager_min_lines|recordsep|recordsep_zero|tableattr|title|tuples_only|unicode_border_linestyle|unicode_column_linestyle|unicode_header_linestyle)\t [on|off] show only rows (currently off)\T [STRING] set HTML <table> tag attributes, or unset if none\x [on|off|auto] toggle expanded output (currently off)Connection\c[onnect] {[DBNAME|- USER|- HOST|- PORT|-] | conninfo}connect to new database (currently "postgres")\conninfo display information about current connection\encoding [ENCODING] show or set client encoding\password [USERNAME] securely change the password for a userOperating System\cd [DIR] change the current working directory\getenv PSQLVAR ENVVAR fetch environment variable\setenv NAME [VALUE] set or unset environment variable\timing [on|off] toggle timing of commands (currently off)\! [COMMAND] execute command in shell or start interactive shellVariables\prompt [TEXT] NAME prompt user to set internal variable\set [NAME [VALUE]] set internal variable, or list all if no parameters\unset NAME unset (delete) internal variable
postgres=#
中文对照表
一般命令
| 参数 | 中文说明 |
|---|---|
| \bind [PARAM]... | 绑定参数 |
| \copyrigh | 显示PostgreSQL的信息 |
| \crosstabview [COLUMNS] | 执行查询并在交叉表中显示结果 |
| \errverbose | 以最大详细程度显示最新的错误消息 |
| \g [(OPTIONS)] [FILE] | 执行查询(并将结果发送到文件或|管道); \没有参数的g相当于分号 |
| \gdesc | 描述查询的结果,而不执行它 |
| \gexec | 执行查询,然后执行其结果中的每个值 |
| \gset [PREFIX] | 执行查询并将结果存储在psql变量中 |
| \gx [(OPTIONS)] [FILE] | 如\g,但强制扩展输出模式 |
| \q | 退出 |
| \watch [[i=]SEC] [c=N] | 每{SEC}秒执行一次查询,最多{N}次 |
帮助命令
| 参数 | 中文说明 |
|---|---|
| \? [commands] | 显示反斜杠命令的帮助 |
| \? options | 显示有关psql命令行选项的帮助 |
| \? variables | 显示有关特殊变量的帮助 |
| \h [NAME] | 有关SQL命令语法的帮助,*适用于所有命令 |
缓存区查询命令
| 参数 | 中文说明 |
|---|---|
| \e [FILE] [LINE] | 编辑查询缓冲区(或文件) |
| \ef [FUNCNAME [LINE]] | 编辑函数定义 |
| \ev [VIEWNAME [LINE]] | 编辑视图定义 |
| \p | 显示查询缓冲区的内容 |
| \r | 重置(清除)查询缓冲区 |
| \s [FILE] | 显示历史记录或将其保存到文件 |
| \w FILE | 将查询缓冲区写入文件 |
输入输出命令
| 参数 | 中文说明 |
|---|---|
| \copy ... | 对客户端主机的数据流执行SQL COPY |
| \echo [-n] [STRING] | 将字符串写入标准输出(-n表示没有换行符) |
| \i FILE | 从文件执行命令 |
| \ir FILE | 与\i一样,但路径起始位置为当前脚本的位置 |
| \o [FILE] | 将所有查询结果发送到文件或|管道 |
| \qecho [-n] [STRING | 将字符串写入\o(-n表示没有换行符) |
| \warn [-n] [STRING] | 将字符串写入标准错误(-n表示没有换行符) |
条件语句命令
| 参数 | 中文说明 |
|---|---|
| \if EXPR | 开始条件 |
| \elif EXPR | 当前条件内的备选方案 |
| \else | 当前条件外的其他方案 |
| \endif | 结束条件 |
查看信息详情命令
S=显示系统对象,+=显示更多信息,[PATTERN]=模式,[ROLEPTRN]=角色模式,[DBPTRN]数据库模式,[FUNCPTRN]=功能模式,[OPPTRN]=运算模式,[TYPEPTRN]=类型模式,
| 参数 | 中文说明 |
|---|---|
| \d[S+] | 显示表、视图、序列 |
| \d[S+] NAME | 显示表、视图、序列或索引的详细信息 |
| \da[S] [PATTERN] | 显示聚合 |
| \dA[+] [PATTERN] | 显示索引列表 |
| \dAc[+] [AMPTRN [TYPEPTRN]] | 显示运算符类 |
| \dAf[+] [AMPTRN [TYPEPTRN]] | 显示运算符族 |
| \dAo[+] [AMPTRN [OPFPTRN]] | 显示运算符族的运算符 |
| \dAp[+] [AMPTRN [OPFPTRN]] | 显示运算符族的支持功能 |
| \db[+] [PATTERN] | 显示表空间 |
| \dc[S+] [PATTERN | 列表转换方式 |
| \dconfig[+] [PATTERN] | 显示配置参数 |
| \dC[+] [PATTERN] | 列表强制转换 |
| \dd[S] [PATTERN] | 显示其他地方未显示的对象描述 |
| \dD[S+] [PATTERN] | 显示域 |
| \ddp [PATTERN] | 显示默认权限 |
| \dE[S+] [PATTERN] | 显示外部表 |
| \des[+] [PATTERN] | 显示外部服务器 |
| \det[+] [PATTERN] | 显示外部表 |
| \deu[+] [PATTERN] | 显示用户映射 |
| \dew[+] [PATTERN] | 显示外部数据包 |
| \df[anptw][S+] [FUNCPTRN [TYPEPTRN ...]] | 显示[仅agg/normal/process/trigue/window]函数 |
| \dF[+] [PATTERN] | 显示文本搜索配置 |
| \dFd[+] [PATTERN] | 列表文本搜索词典 |
| \dFp[+] [PATTERN] | 列表文本搜索解析器 |
| \dFt[+] [PATTERN] | 列表文本搜索模板 |
| \dg[S+] [PATTERN] | 显示角色信息 |
| \di[S+] [PATTERN] | 显示索引关系 |
| \dl[+] | 显示大对象,与\lo_list相同 |
| \dL[S+] [PATTERN] | 显示支持语言 |
| \dm[S+] [PATTERN] | 显示视图 |
| \dn[S+] [PATTERN] | 显示模式 |
| \do[S+] [OPPTRN [TYPEPTRN [TYPEPTRN]]] | 列表运算符 |
| \dO[S+] [PATTERN] | 列表排序规则 |
| \dp[S] [PATTERN] | 列表表、视图和序列访问权限 |
| \dP[itn+] [PATTERN] | list[仅索引/表]分区的关系[n=嵌套] |
| \drds [ROLEPTRN [DBPTRN]] | 按数据库显示角色设置 |
| \drg[S] [PATTERN] | 显示角色权限 |
| \dRp[+] [PATTERN] | 显示复制发布 |
| \dRs[+] [PATTERN] | 显示复制订阅 |
| \ds[S+] [PATTERN] | 列表序列 |
| \dt[S+] [PATTERN] | 查看表占用空间大小 |
| \dT[S+] [PATTERN] | 显示数据类型 |
| \du[S+] [PATTERN] | 显示角色 |
| \dv[S+] [PATTERN] | 显示试图 |
| \dx[+] [PATTERN] | 显示扩展 |
| \dX [PATTERN] | 显示扩展统计信息 |
| \dy[+] [PATTERN] | 显示事件触发器 |
| \l[+] [PATTERN] | 显示数据库 |
| \sf[+] FUNCNAME | 查看函数定义信息 |
| \sv[+] VIEWNAME | 显示视图的定义信息 |
| \z[S] [PATTERN] | 列出表、视图和序列访问权限,与 \dp 相同 |
大对象命令
| 参数 | 中文说明 |
|---|---|
| \lo_export LOBOID FILE | 将大型对象写入文件 |
| \lo_import FILE | 从文件中读取大型对象 |
| \lo_list[+] | 显示大型对象 |
| \lo_unlink LOBOID | 删除大对象 |
格式化命令
| 参数 | 中文说明 |
|---|---|
| \a | 在未对齐和对齐输出模式之间切换 |
| \C [STRING] | 设置表格标题,如果没有则取消设置 |
| \f [STRING] | 显示或设置未对齐查询输出的字段分隔符 |
| \H | 切换HTML输出模式(当前关闭) |
| \pset [NAME [VALUE]] | 设置表格输出选项 (border|column|csv_fieldsep|expanded|fieldsep| fieldsep_zero|footer|format|linestyle|null| numericlocale|pager|pager_min_lines|recordsep| recordsep_zero|tableattr|title|tuples_only| unicode_border_linestyle|unicode_column_nestyle| unicode_header_linestyle) |
| \t [on|off] | 显示行号(当前关闭) |
| \T [STRING] | 设置HTML<table>标记属性,如果没有则取消设置 |
| \x [on|off|auto] | 切换成竖式显示(当前关闭) |
链接命令
| 参数 | 中文说明 |
|---|---|
| \c[onnect] {[DBNAME|- USER|- HOST|- PORT|-] | conninfo} | 切换当前工作的数据库、用户 |
| \conninfo | 显示当前连接的信息 |
| \encoding [ENCODING] | 显示或设置客户端编码 |
| \password [USERNAME] | 更改用户的密码 |
操作系统命令
| 参数 | 中文说明 |
|---|---|
| \cd [DIR] | 更改当前工作目录 等同于 liunx CD命令 |
| \getenv PSQLVAR ENVVAR | 获取环境变量 |
| \setenv NAME [VALUE] | 设置设置环境变量 |
| \timing [on|off] | 切换命令的计时(当前关闭) |
| \! [COMMAND] | 在shell中执行命令或启动交互式shell |
变量命令
| 参数 | 中文说明 |
|---|---|
| \prompt [TEXT] NAME | 提示用户设置内部变量 |
| \set [NAME [VALUE]] | 设置内部变量,如果没有参数则列出所有变量 |
| \unset NAME | 取消设置(删除)内部变量 |
相关文章:
【PostgreSQL】从零开始:(八)PostgreSQL-数据库PSQL元命令
元命令 postgres# \? General\bind [PARAM]... set query parameters\copyright show PostgreSQL usage and distribution terms\crosstabview [COLUMNS] execute query and display result in crosstab\errverbose show most recent error…...
02 使用Vite创建Vue3项目
概述 A Vue project is structured similarly to a lot of modern node-based apps and contains the following: A package.json fileA node_modules folder in the root of your projectVarious other configuration files are usually contained at the root level, such …...
Shell三剑客:sed(简介)
一、前言 Stream EDitor:流编辑 sed 是一种在线的、非交互式的编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后&…...
tp连接数据库
ThinkPHP内置了抽象数据库访问层,把不同的数据库操作封装起来,我们只需要使用公共的Db类进行操作,而无需针对不同的数据库写不同的代码和底层实现,Db类会自动调用相应的数据库驱动来处理。采用PDO方式,目前包含了Mysql…...
jmeter,断言:响应断言、Json断言
一、响应断言 接口A请求正常返回值如下: {"status": 10013, "message": "user sign timeout"} 在该接口下创建【响应断言】元件,配置如下: 若断言成功,则查看结果树的接口显示绿色,若…...
dockerfite创建镜像---INMP+wordpress
搭建dockerfile---lnmp 在192.168.10.201 使用 Docker 构建 LNMP 环境并运行 Wordpress 网站平台 [rootdocker1 opt]# mkdir nginx mysql php [rootdocker1 opt]# ls #分别拖入四个包: nginx-1.22.0.tar.gz mysql-boost-5.7.20.tar.gz php-7.1.10.tar.bz2 wor…...
服务器数据恢复—raid5热备盘未激活崩溃导致上层oracle数据丢失的数据恢复案例
服务器数据恢复环境: 某品牌X系列服务器,4块SAS硬盘组建了一组RAID5阵列,还有1块磁盘作为热备盘使用。服务器上层安装的linux操作系统,操作系统上部署了一个基于oracle数据库的OA(oracle已经不再为该OA系统提供后续服务…...
生产派工自动化:MES系统的关键作用
随着制造业的数字化转型和智能化发展,生产派工自动化成为了提高生产效率、降低成本,并实现优质产品生产的关键要素之一。制造执行系统(MES)在派工自动化中发挥着重要作用,通过实时数据采集和智能调度,优化生…...
netty-daxin-2(netty常用事件讲解)
文章目录 netty常用事件讲解ChannelHandler接口ChannelHandler适配器类ChannelInboundHandler 子接口Channel 的状态调用时机ChannelHandler 生命周期示例NettServer&CustomizeInboundHandlerNettyClient测试分析 ChannelInboundHandlerAdapter适配器类SimpleChannelInboun…...
使用playbook部署k8s集群
1.部署ansible集群 使用python脚本一个简单的搭建ansible集群-CSDN博客 2.ansible命令搭建k8s: 1.主机规划: 节点IP地址操作系统配置server192.168.174.150centos7.92G2核client1192.168.174.151centos7.92G2核client2192.168.174.152centos7.92G2 …...
Python基础入门第四节,第五节课笔记
第四节 第一个条件语句 if 条件: 条件成立执行的代码1 条件成立执行的代码2 ...... else: 条件不成立执行的代码1 条件不成立执行的代码2 …… 代码如下: 身高 float(input("请输入您的身高(米):")) if 身高 >1.3:print(f您的身高是{身高},已经超过1.3米,您需…...
基于Java SSM框架实现智能停车场系统项目【项目源码+论文说明】
基于java的SSM框架实现智能停车场系统演示 摘要 本论文主要论述了如何使用JAVA语言开发一个智能停车场管理系统,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述…...
React系列:useEffect的使用
useEffect的使用 useEffect的第二个参数不同,useEffect的加载不同 当第二个参数为没有的时候 只在组件初始渲染和组件更新之后加载当第二个参数为[] 的时候 只在初始渲染之后加载当第二个参数为[有依赖] 的时候 只在初始渲染之后和依赖修改的时候进行加载 functi…...
Ps:形状工具 - 描边选项
在形状工具的工具选项栏或“属性”面板中,单击“设置形状描边类型” Set shape stroke type菜单图标可打开“描边选项” Stroke Options面板。 描边预设 Stroke Type 默认列出了实线、虚线和点线三种类型的描边,单击可应用。 自己创建并存储的描边类型&a…...
C#基础知识 - 变量、常量与数据类型篇
C#基础知识 - 变量、常量与数据类型篇 第3节 变量、常量与数据类型3.1 C#变量3.1.1 变量使用3.1.2 自定义变量3.1.2 接收用户输入 3.2 C#常量3.2.1 常量的使用 3.3 C#数据类型3.3.1 数据类型之值类型3.3.2 数据类型之引用类型 更多C#基础知识详解请查看:C#基础知识 …...
Java面向对象思想以及原理以及内存图解
文章目录 什么是面向对象面向对象和面向过程区别创建一个对象用什么运算符?面向对象实现伪代码面向对象三大特征类和对象的关系。 基础案例代码实现实例化创建car对象时car引用的内存图对象调用方法过程 成员变量和局部变量作用范围在内存中的位置 关于对象的引用关系简介相关…...
Gitbook----基于 Windows 10 系统本地安装配置 Gitbook 编写属于自己的电子书
查看原文 文章目录 一、安装 Nodejs二、安装 Gitbook三、gitbook 的使用方法四、设计电子书的目录结构五、设置 gitbook 常用配置 一、安装 Nodejs 若要在 Windows 10 系统即本地使用 Gitbook,需要安装 gitlab-cli 工具,而 gitbook-cli 工具是基于 Node…...
springMVC-Restful风格
基本介绍 REST:即Representational State Transfer。(资源)表现层状态转化。是目前最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用. 1.HTTP协议里面,四个表示操…...
【OS】操作系统总复习笔记
操作系统总复习 文章目录 操作系统总复习一、考试题型1. 论述分析题2. 计算题3. 应用题 二、操作系统引论(第1章)2.1 操作系统的发展过程2.2 操作系统定义2.3 操作系统的基本特性2.3.1 并发2.3.2 共享2.3.3 虚拟2.3.4 异步 2.4 OS的功能2.5 OS结构2.5 习…...
powerbuilder游标的使⽤
在某些PowerBuilder应⽤程序的开发中,您可能根本⽤不到游标这样⼀个对象。因为在其它⼯具开发中很多需⽤游标实现的⼯作,在PowerBuilder中却已有DataWin-dow来代劳了。事实上,DataWindow不仅可以替代游标进⾏从后台数据库查询多条记录的复杂操作,⽽且还远不⽌这些。但是同DataW…...
利用最小二乘法找圆心和半径
#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...
Linux应用开发之网络套接字编程(实例篇)
服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …...
测试微信模版消息推送
进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...
MPNet:旋转机械轻量化故障诊断模型详解python代码复现
目录 一、问题背景与挑战 二、MPNet核心架构 2.1 多分支特征融合模块(MBFM) 2.2 残差注意力金字塔模块(RAPM) 2.2.1 空间金字塔注意力(SPA) 2.2.2 金字塔残差块(PRBlock) 2.3 分类器设计 三、关键技术突破 3.1 多尺度特征融合 3.2 轻量化设计策略 3.3 抗噪声…...
golang循环变量捕获问题
在 Go 语言中,当在循环中启动协程(goroutine)时,如果在协程闭包中直接引用循环变量,可能会遇到一个常见的陷阱 - 循环变量捕获问题。让我详细解释一下: 问题背景 看这个代码片段: fo…...
《用户共鸣指数(E)驱动品牌大模型种草:如何抢占大模型搜索结果情感高地》
在注意力分散、内容高度同质化的时代,情感连接已成为品牌破圈的关键通道。我们在服务大量品牌客户的过程中发现,消费者对内容的“有感”程度,正日益成为影响品牌传播效率与转化率的核心变量。在生成式AI驱动的内容生成与推荐环境中࿰…...
多模态商品数据接口:融合图像、语音与文字的下一代商品详情体验
一、多模态商品数据接口的技术架构 (一)多模态数据融合引擎 跨模态语义对齐 通过Transformer架构实现图像、语音、文字的语义关联。例如,当用户上传一张“蓝色连衣裙”的图片时,接口可自动提取图像中的颜色(RGB值&…...
【ROS】Nav2源码之nav2_behavior_tree-行为树节点列表
1、行为树节点分类 在 Nav2(Navigation2)的行为树框架中,行为树节点插件按照功能分为 Action(动作节点)、Condition(条件节点)、Control(控制节点) 和 Decorator(装饰节点) 四类。 1.1 动作节点 Action 执行具体的机器人操作或任务,直接与硬件、传感器或外部系统…...
2025 后端自学UNIAPP【项目实战:旅游项目】6、我的收藏页面
代码框架视图 1、先添加一个获取收藏景点的列表请求 【在文件my_api.js文件中添加】 // 引入公共的请求封装 import http from ./my_http.js// 登录接口(适配服务端返回 Token) export const login async (code, avatar) > {const res await http…...
C语言中提供的第三方库之哈希表实现
一. 简介 前面一篇文章简单学习了C语言中第三方库(uthash库)提供对哈希表的操作,文章如下: C语言中提供的第三方库uthash常用接口-CSDN博客 本文简单学习一下第三方库 uthash库对哈希表的操作。 二. uthash库哈希表操作示例 u…...
