当前位置: 首页 > news >正文

网站案例模版高端网站开发注意事项

网站案例模版,高端网站开发注意事项,wordpress加速之gzip,做网站建设一条龙全包pg_query 这个 Ruby 扩展使用实际的 PostgreSQL 服务器源来解析 SQL 查询并返回内部 PostgreSQL 解析树。 此外,该扩展允许您规范化查询(用 $n 替换常量值)并将这些规范化的查询再次解析为解析树。 当您构建此扩展时,它会构建 …

pg_query

这个 Ruby 扩展使用实际的 PostgreSQL 服务器源来解析 SQL 查询并返回内部 PostgreSQL 解析树。

此外,该扩展允许您规范化查询(用 $n 替换常量值)并将这些规范化的查询再次解析为解析树。

当您构建此扩展时,它会构建 PostgreSQL 服务器源的部分(参见libpg_query),然后将其静态链接到此扩展中。

这看起来很复杂,但这是解析所有有效 PostgreSQL 查询的唯一可靠方法。

您可以在此处找到更多示例和更长的理由:https ://pganalyze.com/blog/parse-postgresql-queries-in-ruby.html

安装

gem install pg_query

由于编译 PostgreSQL 的部分内容,在较慢的系统
上安装可能需要一段时间。预计最多需要 5 分钟。

用法

解析查询

PgQuery.parse("SELECT 1")=> #<PgQuery::ParserResult:0x000000012ec4e9e0@query="SELECT 1",@tree=<PgQuery::ParseResult:version: 160001,stmts: [<PgQuery::RawStmt:stmt: <PgQuery::Node:select_stmt: <PgQuery::SelectStmt:distinct_clause: [],target_list: [<PgQuery::Node:res_target: <PgQuery::ResTarget:name: "",indirection: [],val: <PgQuery::Node:a_const: <PgQuery::A_Const:ival: <PgQuery::Integer: ival: 1>,isnull: false,location: 7>>,location: 7>>],from_clause: [],group_clause: [],group_distinct: false,window_clause: [],values_lists: [],sort_clause: [],limit_option: :LIMIT_OPTION_DEFAULT,locking_clause: [],op: :SETOP_NONE,all: false>>,stmt_location: 0,stmt_len: 0>]>,@warnings=[],@tables=nil,@aliases=nil,@cte_names=nil,@functions=nil
>

修改已解析的查询并将其再次转换为 SQL

这是一个简单的例子deparse,对于更复杂的修改,请使用walk!。

parsed_query = PgQuery.parse("SELECT * FROM users")# Modify the parse tree in some way
parsed_query.tree.stmts[0].stmt.select_stmt.from_clause[0].range_var.relname = 'other_users'# Turn it into SQL again
parsed_query.deparse
=> "SELECT * FROM other_users"

解析规范化查询

# Normalizing a query (like pg_stat_statements in Postgres 10+)
PgQuery.normalize("SELECT 1 FROM x WHERE y = 'foo'")=> "SELECT $1 FROM x WHERE y = $2"

从查询中提取表

PgQuery.parse("SELECT $1 FROM x JOIN y USING (id) WHERE z = $2").tables=> ["x", "y"]

从查询中提取列

PgQuery.parse("SELECT $1 FROM x WHERE x.y = $2 AND z = $3").filter_columns=> [["x", "y"], [nil, "z"]]

指纹查询

PgQuery.parse("SELECT 1").fingerprint=> "50fde20626009aba"PgQuery.parse("SELECT 2; --- comment").fingerprint=> "50fde20626009aba"# Faster fingerprint method that is implemented inside the native C library
PgQuery.fingerprint("SELECT $1")=> "50fde20626009aba"

将查询扫描成标记

PgQuery.scan('SELECT 1 --comment')=> [<PgQuery::ScanResult: version: 160001, tokens: [
<PgQuery::ScanToken: start: 0, end: 6, token: :SELECT, keyword_kind: :RESERVED_KEYWORD>,
<PgQuery::ScanToken: start: 7, end: 8, token: :ICONST, keyword_kind: :NO_KEYWORD>,
<PgQuery::ScanToken: start: 9, end: 18, token: :SQL_COMMENT, keyword_kind: :NO_KEYWORD>]>,[]]

遍历解析树

对于通用用途,PgQuery 提供了walk!一种以递归方式处理已解析查询的方法。

这可用于创建定制的漂亮打印机:

parsed_query = PgQuery.parse "SELECT * FROM tbl"
parsed_query.walk! { |node, k, v, location| puts k }

更有用的是,这可用于重写查询。例如:

parsed_query.walk! do |node, k, v, location|next unless k.eql?(:range_var) || k.eql?(:relation)next if v.relname.nil?v.relname = "X_" + v.relname
endparsed_query.deparse

这个例子中有一些注意事项和限制。

首先,部分树节点被冻结。您可以替换它们,但无法就地修改。

其次,表重写比此示例更微妙。虽然这将重写表名,但它不会正确处理所有 CTE,也不会重写具有明确表名的列。

支持的 Ruby 版本

目前已测试并正式支持的 Ruby 版本:

  • CRuby 2.7
  • CRuby 3.0
  • CRuby 3.1
  • CRuby 3.2
  • CRuby 3.3
    不支持:
  • JRuby:pg_query依赖于 C 扩展,不鼓励使用/不支持 JRuby
  • TruffleRuby:GraalVM不支持 sigjmp,它由 Postgres 错误处理代码使用(pg_query使用
    Postgres 解析器和错误处理代码的副本)
    #PG证书#PG考试#PostgreSQL培训#PostgreSQL考试#PostgreSQL认证

原作者:卢卡斯·菲特尔
原文链接:https://github.com/pganalyze/pg_query

http://www.yayakq.cn/news/290146/

相关文章:

  • 成都网站建设优选推来客厂房建设招标网站
  • 模板网站不可以做seo优化吗企业网站seo诊断
  • 建论坛网站西安公司网页制作
  • 郑州做网站企起有哪些小程序免费模板平台
  • 营销型网站建设极速建站抚州市建设局官方网站
  • 名师工作室建设名师网站找别人做网站要注意什么
  • js网站一键变灰帮别人做网站赚钱6
  • 哪些网站做推广比较有效果网站怎样做推广计划
  • 贸易公司网站模板潍坊市城市建设官网站
  • 公司怎么建立自己网站免费发布信息不收费的网站
  • 浙江省住建厅网站网站建设主题有哪些注意事项
  • 厦门网络建站公司wordpress仿淘宝页面
  • 做的怎样 英文网站做网站赚取广告费
  • 石龙镇仿做网站郑州互联网seo
  • 域名访问网站应该怎么做响应式html5网页模板
  • 淄博网站建设 招聘网站制作软件排行榜
  • 网站备案每年一次dw网页制作作业
  • qq空间怎么做网站微网站后台怎么注册
  • 网站开发与设计的实训场地深圳工业设计师工资一般多少
  • 百度seo网站排名网站规划文字说明
  • 做网站如何赚广费php网站微信支付怎么做
  • 微信个人商城网站模板免费下载哈尔滨 建设网站 科技
  • 建立网站流程页面设计的软件
  • 陇南市响应式网站建设免费微商城平台
  • 做的网站如何更换网站模板wordpress投票
  • 基于用户体验的网站设计网站开发要注意哪些细节
  • 有后台的网站怎么做门户网站手机版
  • 免费网站建设作业总结公司做的网站费用如何做账
  • 可信赖的网站建设推广网站开发案例详解光盘下载
  • 网页设计与网站开发pdf正版海外自媒体服务器官网