哪个网站看电视剧最全还免费电商网站开发背景怎么写

张小明 2026/1/3 13:01:54
哪个网站看电视剧最全还免费,电商网站开发背景怎么写,昆山网站建设 熊掌号,网站的作用和意义pg兼容mysql框架之整体架构 前言: 本文简述了openHalo兼容mysql框架的基本思路和逻辑。 1 整体架构图图1#xff08;源于openhalo官方手册#xff09; 2 源码实现 区分mysql和pg的配置参数unvdb_database_mode实现 首先#xff0c;以GUC参数 unvdb_database_mode 作为PG模式…pg兼容mysql框架之整体架构前言: 本文简述了openHalo兼容mysql框架的基本思路和逻辑。1 整体架构图图1源于openhalo官方手册2 源码实现区分mysql和pg的配置参数unvdb_database_mode实现首先以GUC参数 unvdb_database_mode 作为PG模式和MySQL模式的区分参数参数定义 /* GUC variable */ int unvdb_database_mode UNVDBTX_COMPAT_MODE; guc定义 {unvdb_database_mode, PGC_UNVDBSVR, CUSTOM_OPTIONS, gettext_noop(Sets the database compat mode.), NULL, GUC_SUPERUSER_ONLY }, unvdb_database_mode, UNVDBTX_COMPAT_MODE, unvdb_database_mode_options, NULL, NULL, NULL }, static const struct config_enum_entry unvdb_database_mode_options[] { {unvdbtx, UNVDBTX_COMPAT_MODE, false}, {mysql, MYSQL_COMPAT_MODE, false}, {NULL, 0, false} };以unvdb_database_mode_options[]下标作为unvdb_database_mode 值 0为pg模式 ,1为Mysql模式对应枚举类型typedef enum { UNVDBTX_COMPAT_MODE, MYSQL_COMPAT_MODE, } DatabaseCompatModeType;因此通过上述转换在内核源码中以UNVDBTX_COMPAT_MODE,MYSQL_COMPAT_MODE 作为区分pg和mysql的最终依据。在每个关键模块入口用此参数走不同的执行逻辑。3 整体架构实现源码如图1所示 每个模块都设置了标准化引擎在init阶段根据上述所说的unvdb_database_mode 配置情况给相关模块的引擎赋于对应模式pg/mysql以下是初始化代码src/backend/utils/init/postinit.c 1142 /* set default namespace search path */ InitializeSearchPath(); /* initialize client encoding */ InitializeClientEncoding(); /* Initialize this backends session state. */ InitializeSession(); /* Initialize Parser Engine */ InitParserEngine(); /* Initialize Planner Engine */ InitPlannerEngine(); /* Initialize Exector Engine */ InitExecutorEngine(); /* Initialize ADT Extension */ InitADTExt(); /* Initialize fmgr extension */ InitFmgrExtension(); /* report this backend in the PgBackendStatus array */ if (!bootstrap) pgstat_bestart();每个引擎里定义了引擎类型和一些必要的函数指针成员 在初始化阶段会根据模式pg/mysql给引擎赋值不同的对应成员参数。引擎结构体以ParserEngine为例typedef struct ParserRoutine { NodeTag type; bool is_standard_parser; bool need_standard_parser; const ScanKeywordList *keywordlist; const uint16 *keyword_tokens; const uint8 *keyword_categories; raw_parser_function raw_parser; transformStmt_function transformStmt; transformSelectStmt_function transformSelectStmt; transformInsertStmt_function transformInsertStmt; transformDeleteStmt_function transformDeleteStmt; transformUpdateStmt_function transformUpdateStmt; transformSetOperationStmt_function transformSetOperationStmt; transformCallStmt_function transformCallStmt; transformOptionalSelectInto_function transformOptionalSelectInto; transformSetOperationTree_function transformSetOperationTree; analyze_requires_snapshot_function analyze_requires_snapshot; parse_sub_analyze_function parse_sub_analyze; transformGroupClause_function transformGroupClause; transformDistinctClause_function transformDistinctClause; transformOnConflictArbiter_function transformOnConflictArbiter; transformExpr_function transformExpr; transformCreateStmt_function transformCreateStmt; transformAlterTableStmt_function transformAlterTableStmt; assign_query_collations_function assign_query_collations; assign_list_collations_function assign_list_collations; assign_expr_collations_function assign_expr_collations; select_common_collation_function select_common_collation; preTransformWindowAgg_fn preTransformWindowAgg; finalTransformColumnRef_fn finalTransformColumnRef; ParseFuncOrColumn_function ParseFuncOrColumn; func_get_detail_function func_get_detail; make_fn_arguments_function make_fn_arguments; RewriteInterface rewrite; } ParserRoutine;相关引擎初始化代码以ParserEngine为例void InitParserEngine(void) { switch (unvdb_database_mode) { case UNVDBTX_COMPAT_MODE: parserengine GetStandardParserEngine(); break; case MYSQL_COMPAT_MODE: if ((MyProcPort ! NULL) (nodeTag(MyProcPort-protocol_handler) T_MySQLProtocol)) { parserengine GetMysParserEngine(); } else { parserengine GetStandardParserEngine(); } /* parserengine GetMysParserEngine(); */ break; default: parserengine GetStandardParserEngine(); break; } }假设我们是mysql模式unvdb模式相同在初始化函数中 GetMysParserEngine()函数会返回已经赋值了mysql相关函数的引擎因此在后续的调用中 统一采用 例如parserengine-keywordlist 方式就可以访问对应模式下的处理函数。赋值代码/* * MySQL Parser Engine */ static const ParserRoutine mys_parser_engine { .type T_ParserRoutine, .is_standard_parser false, .need_standard_parser true, .keywordlist MysScanKeywords, .keyword_tokens MysScanKeywordTokens, .keyword_categories MysScanKeywordCategories, .transformStmt mys_transformStmt, .transformSelectStmt mys_transformSelectStmt, .transformInsertStmt mys_transformInsertStmt, .transformUpdateStmt mys_transformUpdateStmt, .transformDeleteStmt mys_transformDeleteStmt, .transformCallStmt mys_transformCallStmt, .transformOptionalSelectInto mys_transformOptionalSelectInto, .transformSetOperationStmt mys_transformSetOperationStmt, .transformSetOperationTree mys_transformSetOperationTree, .analyze_requires_snapshot mys_analyze_requires_snapshot, .transformOnConflictArbiter mys_transformOnConflictArbiter, .raw_parser mys_raw_parser, .transformExpr mys_transformExpr, .transformGroupClause mys_transformGroupClause, .transformDistinctClause mys_transformDistinctClause, .transformCreateStmt mys_transformCreateStmt, .transformAlterTableStmt mys_transformAlterTableStmt, .ParseFuncOrColumn mys_ParseFuncOrColumn, .func_get_detail mys_func_get_detail, .make_fn_arguments mys_make_fn_arguments };4 引擎执行源码解析以语法解析为例当以mysql模式运行时代码正常执行进入语法解析阶段。代码如下List * raw_parser(const char *str, RawParseMode mode) { List *raw_parsetree NIL; MemoryContext oldctx CurrentMemoryContext; if (parserengine NULL) parserengine GetStandardParserEngine(); Assert(parserengine ! NULL); Assert(parserengine-raw_parser ! NULL); PG_TRY(); { raw_parsetree parserengine-raw_parser(str, mode); } PG_CATCH();当执行到raw_parsetree parserengine-raw_parser(str, mode); 片段时为进入语法解析的入口此时由于parserengine 已经被赋值为mysql的引擎所以调用的函数raw_parser成员对应的是mys_raw_parser函数。到此正式进入mysql raw_parser 解析逻辑。其他引擎略有出入但总体上实现逻辑是一样的。
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

哪个网站可以接程序项目来做wordpress 安卓教程

jQuery UI Autocomplete(自动完成)实例 Autocomplete 是 jQuery UI 中非常实用的组件,用于输入框提供智能建议列表,支持本地数据、远程 AJAX 数据、分类显示、自定义渲染等。常用于搜索框、标签输入、地址补全等场景。 官方演示…

张小明 2025/12/29 8:05:07 网站建设

网站用vps做dns上海建设网站公

Excalidraw 与 hreflang:构建多语言 Web 应用的隐形桥梁 在全球化协作日益紧密的今天,一款工具能否跨越语言和地域的障碍,往往决定了它的影响力边界。Excalidraw —— 这个以极简手绘风格风靡开发者社区的开源白板工具,早已不只是…

张小明 2025/12/29 8:02:47 网站建设

中山网站建设方案托管护肤品 网站建设策划书

FusionCompute 8.0 全套资源获取与部署实战指南 【免费下载链接】FusionCompute8.0资源下载指南分享 本仓库提供了一个详细的资源文件,内含百度网盘连接及提取码,以及详细的资源列表,方便您学习和使用FusionCompute 8.0。该资源适合搭建Fusio…

张小明 2026/1/2 13:39:47 网站建设

在哪里做网站设计住房建设建设部网站

掌握项目管理利器:全面解析相关知识与操作技巧 在项目管理领域,掌握有效的工具和方法至关重要。下面将为大家详细介绍一些项目管理中常用的概念、操作以及相关工具的使用技巧。 项目管理核心概念解析 VAC(Variance At Completion) :这是一个挣值指标,代表完成时偏差。…

张小明 2026/1/3 6:40:18 网站建设

有没有卖设计的网站站长工具域名解析

还在为如何配置claude code发愁吗?通过下面简单三步,小白也只需几分钟即可让你用上官方正版的claude code! 一、前置组件安装 1.1 git安装 下载git 建议默认安装c盘 以防报错 访问https://git-scm.com/install/windows,选择适合…

张小明 2026/1/3 6:04:22 网站建设

婚纱外贸网站网站建设合作伙伴

StarRocks索引技术终极指南:从毫秒响应到百亿数据的高效查询 【免费下载链接】starrocks StarRocks是一个开源的分布式数据分析引擎,用于处理大规模数据查询和分析。 - 功能:分布式数据分析;大规模数据查询;数据分析&a…

张小明 2025/12/31 1:04:38 网站建设