{"id":197,"date":"2010-05-30T21:58:54","date_gmt":"2010-05-31T02:58:54","guid":{"rendered":"http:\/\/www.dpriver.com\/blog\/?p=197"},"modified":"2011-09-26T21:40:12","modified_gmt":"2011-09-27T02:40:12","slug":"general-sql-parser-java-v0-4-release","status":"publish","type":"post","link":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/","title":{"rendered":"General SQL Parser Java v0.4 release"},"content":{"rendered":"<p>In this version, we can easily fetch table and column from stored procedures(packages) of Oracle and SQL Server.<\/p>\n<p>Let&#8217;s take this  create trigger statement(Oracle) for example:<\/p>\n<p><span style=\"font-family: Courier New;font-size: small\"><br \/>\n<span style=\"color: blue\">CREATE<\/span> <span style=\"color: blue\">TRIGGER<\/span> <span style=\"color: maroon\">hr<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">emp_permit_changes<\/span><br \/>\n<span style=\"color: maroon\">BEFORE<\/span> <span style=\"color: blue\">DELETE<\/span> <span style=\"color: blue\">OR<\/span> <span style=\"color: blue\">INSERT<\/span> <span style=\"color: blue\">OR<\/span> <span style=\"color: blue\">UPDATE<\/span> <span style=\"color: blue\">ON<\/span> <span style=\"color: maroon\">hr<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">employees<\/span><br \/>\n<span style=\"color: blue\">BEGIN<\/span><br \/>\n<span style=\"color: blue\">INSERT<\/span> <span style=\"color: blue\">INTO<\/span> <span style=\"color: maroon\">customers<\/span><br \/>\n<span style=\"color: maroon\">(<\/span><span style=\"color: maroon\">customer_id<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">cust_last_name<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">cust_first_name<\/span><span style=\"color: maroon\">)<\/span><br \/>\n<span style=\"color: blue\">VALUES<\/span> <span style=\"color: maroon\">(<\/span> <span style=\"color: maroon\">:new<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">customer_id<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">:new<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">cust_last_name<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">:new<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">cust_first_name<\/span><span style=\"color: maroon\">)<\/span><span style=\"color: silver\">;<\/span><\/span><\/p>\n<p><span style=\"font-family: Courier New;font-size: small\"> <span style=\"color: blue\">INSERT<\/span> <span style=\"color: blue\">INTO<\/span> <span style=\"color: maroon\">orders<\/span><br \/>\n<span style=\"color: maroon\">(<\/span><span style=\"color: maroon\">order_id<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">order_date<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">customer_id<\/span><span style=\"color: maroon\">)<\/span><br \/>\n<span style=\"color: blue\">VALUES<\/span> <span style=\"color: maroon\">(<\/span> <span style=\"color: maroon\">:new<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">order_id<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">:new<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">order_date<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">:new<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">customer_id<\/span><span style=\"color: maroon\">)<\/span><span style=\"color: silver\">;<\/span><br \/>\n<span style=\"color: blue\">EXCEPTION<\/span><br \/>\n<span style=\"color: blue\">WHEN<\/span> <span style=\"color: maroon\">duplicate_info<\/span> <span style=\"color: blue\">THEN<\/span><br \/>\n<span style=\"color: #ff0080\"><strong>Raise_application_error<\/strong><\/span> <span style=\"color: maroon\">(<\/span><span style=\"color: maroon\">num<\/span> <span style=\"color: silver\">=&gt;<\/span> <span style=\"color: silver\">&#8211;<\/span><span style=\"color: black\">20107<\/span><span style=\"color: silver\">,<\/span> <span style=\"color: maroon\">msg<\/span> <span style=\"color: silver\">=&gt;<\/span> <span style=\"color: red\">&#8216;Duplicate\u00a0customer\u00a0or\u00a0order\u00a0ID&#8217;<\/span><span style=\"color: maroon\">)<\/span><span style=\"color: silver\">;<\/span><br \/>\n<span style=\"color: blue\">END<\/span><span style=\"color: silver\">;<\/span><\/span><\/p>\n<p><span style=\"font-family: Courier New;font-size: small\"><span style=\"color: silver\">\/<\/span><\/span><\/p>\n<p>Here are\u00a0 table and column in above SQL Statement fetched by demo gettablecolumns shipped together with this component:<\/p>\n<p>Tables:<br \/>\ncustomers<br \/>\nhr.employees<br \/>\norders<\/p>\n<p>Fields:<br \/>\ncustomers.cust_first_name<br \/>\ncustomers.cust_last_name<br \/>\ncustomers.customer_id<br \/>\nhr.employees.cust_first_name<br \/>\nhr.employees.cust_last_name<br \/>\nhr.employees.customer_id<br \/>\nhr.employees.order_date<br \/>\nhr.employees.order_id<br \/>\norders.customer_id<br \/>\norders.order_date<br \/>\norders.order_id<\/p>\n<p>Below is another create procedure SQL sample of SQL Server:<\/p>\n<div><span style=\"font-family: Courier New;font-size: 10pt\"><br \/>\n<span style=\"color: blue\">CREATE<\/span> <span style=\"color: blue\">PROCEDURE<\/span> <span style=\"color: maroon\">Purchasing<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">uspVendorAllInfo<\/span><br \/>\n<span style=\"color: blue\">WITH<\/span> <span style=\"color: blue\">EXECUTE<\/span> <span style=\"color: blue\">AS<\/span> <span style=\"color: maroon\">CALLER<\/span><br \/>\n<span style=\"color: blue\">AS<\/span><br \/>\n<span style=\"color: blue\">SET<\/span> <span style=\"color: maroon\">NOCOUNT<\/span> <span style=\"color: blue\">ON<\/span><span style=\"color: silver\">;<\/span><br \/>\n<span style=\"color: blue\">SELECT<\/span> <span style=\"color: maroon\">v<\/span><span style=\"color: silver\">.<\/span><span style=\"color: blue\">Name<\/span> <span style=\"color: blue\">AS<\/span> <span style=\"color: maroon\">Vendor<\/span><span style=\"color: silver\">,<\/span> <span style=\"color: maroon\">p<\/span><span style=\"color: silver\">.<\/span><span style=\"color: blue\">Name<\/span> <span style=\"color: blue\">AS<\/span> <span style=\"color: red\">&#8216;Product\u00a0name&#8217;<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">v<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">CreditRating<\/span> <span style=\"color: blue\">AS<\/span> <span style=\"color: red\">&#8216;Credit\u00a0Rating&#8217;<\/span><span style=\"color: silver\">,<\/span><br \/>\n<span style=\"color: maroon\">v<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">ActiveFlag<\/span> <span style=\"color: blue\">AS<\/span> <span style=\"color: maroon\">Availability<\/span><br \/>\n<span style=\"color: blue\">FROM<\/span> <span style=\"color: maroon\">Purchasing<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">Vendor<\/span> <span style=\"color: maroon\">v<\/span><br \/>\n<span style=\"color: maroon\">INNER<\/span> <span style=\"color: maroon\">JOIN<\/span> <span style=\"color: maroon\">Purchasing<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">ProductVendor<\/span> <span style=\"color: maroon\">pv<\/span><br \/>\n<span style=\"color: blue\">ON<\/span> <span style=\"color: maroon\">v<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">VendorID<\/span> <span style=\"color: silver\">=<\/span> <span style=\"color: maroon\">pv<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">VendorID<\/span><br \/>\n<span style=\"color: maroon\">INNER<\/span> <span style=\"color: maroon\">JOIN<\/span> <span style=\"color: maroon\">Production<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">Product<\/span> <span style=\"color: maroon\">p<\/span><br \/>\n<span style=\"color: blue\">ON<\/span> <span style=\"color: maroon\">pv<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">ProductID<\/span> <span style=\"color: silver\">=<\/span> <span style=\"color: maroon\">p<\/span><span style=\"color: silver\">.<\/span><span style=\"color: maroon\">ProductID<\/span><br \/>\n<span style=\"color: blue\">ORDER<\/span> <span style=\"color: blue\">BY<\/span> <span style=\"color: maroon\">v<\/span><span style=\"color: silver\">.<\/span><span style=\"color: blue\">Name<\/span> <span style=\"color: blue\">ASC<\/span><span style=\"color: silver\">;<\/span><br \/>\n<span style=\"color: maroon\">GO<\/span><\/span><\/div>\n<div><span style=\"font-family: Courier New;font-size: 10pt\"><span style=\"color: maroon\"><br \/>\n<\/span><\/span><\/div>\n<p>Here are table and column in above SQL Statement fetched by demo gettablecolumns shipped together with this component:<\/p>\n<p>Tables:<br \/>\nproduction.product<br \/>\npurchasing.productvendor<br \/>\npurchasing.vendor<\/p>\n<p>Fields:<br \/>\nproduction.product.name<br \/>\nproduction.product.productid<br \/>\npurchasing.productvendor.productid<br \/>\npurchasing.productvendor.vendorid<br \/>\npurchasing.vendor.activeflag<br \/>\npurchasing.vendor.creditrating<br \/>\npurchasing.vendor.name<br \/>\npurchasing.vendor.vendorid<\/p>\n<p>You can download General SQL Parser Java version here:<br \/>\n<a title=\"General SQL Parser Java version\" href=\"http:\/\/www.sqlparser.com\/download.php\">http:\/\/www.sqlparser.com\/download.php<\/a><br \/>\nIf you have any questions or comments about this SQL Parser, feel free to contact me:\u00a0 info@sqlparser.com<\/p>\n","protected":false},"excerpt":{"rendered":"<p>In this version, we can easily fetch table and column from stored procedures(packages) of Oracle and SQL Server. Let&#8217;s take this create trigger statement(Oracle) for example: CREATE TRIGGER hr.emp_permit_changes BEFORE DELETE OR INSERT OR UPDATE ON hr.employees BEGIN INSERT INTO customers (customer_id, cust_last_name, cust_first_name) VALUES ( :new.customer_id, :new.cust_last_name, :new.cust_first_name); INSERT INTO orders (order_id, order_date, customer_id) VALUES ( :new.order_id, :new.order_date, :new.customer_id); EXCEPTION WHEN duplicate_info THEN Raise_application_error (num =&gt; &#8211;20107, msg =&gt; &#8216;Duplicate\u00a0customer\u00a0or\u00a0order\u00a0ID&#8217;); END; \/ Here are\u00a0 table and column in above SQL Statement fetched by demo gettablecolumns shipped together with this component: Tables: customers hr.employees orders Fields: customers.cust_first_name customers.cust_last_name customers.customer_id hr.employees.cust_first_name\u2026<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[14,15],"tags":[],"blocksy_meta":{"styles_descriptor":{"styles":{"desktop":"","tablet":"","mobile":""},"google_fonts":[],"version":5}},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v19.4 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>General SQL Parser Java v0.4 release<\/title>\n<meta name=\"description\" content=\"General SQL Parser Java v0.4 release\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"General SQL Parser Java v0.4 release\" \/>\n<meta property=\"og:description\" content=\"General SQL Parser Java v0.4 release\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\" \/>\n<meta property=\"og:site_name\" content=\"SQL and Data Blog\" \/>\n<meta property=\"article:published_time\" content=\"2010-05-31T02:58:54+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2011-09-27T02:40:12+00:00\" \/>\n<meta name=\"author\" content=\"James\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"James\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Organization\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/#organization\",\"name\":\"SQL and Data Blog\",\"url\":\"https:\/\/www.dpriver.com\/blog\/\",\"sameAs\":[],\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/www.dpriver.com\/blog\/wp-content\/uploads\/2022\/07\/sqlpp-character.png\",\"contentUrl\":\"https:\/\/www.dpriver.com\/blog\/wp-content\/uploads\/2022\/07\/sqlpp-character.png\",\"width\":251,\"height\":72,\"caption\":\"SQL and Data Blog\"},\"image\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/#\/schema\/logo\/image\/\"}},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/#website\",\"url\":\"https:\/\/www.dpriver.com\/blog\/\",\"name\":\"SQL and Data Blog\",\"description\":\"SQL related blog for database professional\",\"publisher\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.dpriver.com\/blog\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"en-US\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\",\"url\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\",\"name\":\"General SQL Parser Java v0.4 release\",\"isPartOf\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/#website\"},\"datePublished\":\"2010-05-31T02:58:54+00:00\",\"dateModified\":\"2011-09-27T02:40:12+00:00\",\"description\":\"General SQL Parser Java v0.4 release\",\"breadcrumb\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/www.dpriver.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"General SQL Parser Java v0.4 release\"}]},{\"@type\":\"Article\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\"},\"author\":{\"name\":\"James\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/#\/schema\/person\/7bbdbb6e79c5dd9747d08c59d5992b04\"},\"headline\":\"General SQL Parser Java v0.4 release\",\"datePublished\":\"2010-05-31T02:58:54+00:00\",\"dateModified\":\"2011-09-27T02:40:12+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/\"},\"wordCount\":332,\"publisher\":{\"@id\":\"https:\/\/www.dpriver.com\/blog\/#organization\"},\"articleSection\":[\"gsp\",\"release\"],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/#\/schema\/person\/7bbdbb6e79c5dd9747d08c59d5992b04\",\"name\":\"James\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.dpriver.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/eeddf4ca7bdafa37ab025068efdc7302?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/eeddf4ca7bdafa37ab025068efdc7302?s=96&d=mm&r=g\",\"caption\":\"James\"},\"sameAs\":[\"http:\/\/www.dpriver.com\"],\"url\":\"https:\/\/www.dpriver.com\/blog\/author\/james\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"General SQL Parser Java v0.4 release","description":"General SQL Parser Java v0.4 release","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/","og_locale":"en_US","og_type":"article","og_title":"General SQL Parser Java v0.4 release","og_description":"General SQL Parser Java v0.4 release","og_url":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/","og_site_name":"SQL and Data Blog","article_published_time":"2010-05-31T02:58:54+00:00","article_modified_time":"2011-09-27T02:40:12+00:00","author":"James","twitter_card":"summary_large_image","twitter_misc":{"Written by":"James","Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Organization","@id":"https:\/\/www.dpriver.com\/blog\/#organization","name":"SQL and Data Blog","url":"https:\/\/www.dpriver.com\/blog\/","sameAs":[],"logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.dpriver.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/www.dpriver.com\/blog\/wp-content\/uploads\/2022\/07\/sqlpp-character.png","contentUrl":"https:\/\/www.dpriver.com\/blog\/wp-content\/uploads\/2022\/07\/sqlpp-character.png","width":251,"height":72,"caption":"SQL and Data Blog"},"image":{"@id":"https:\/\/www.dpriver.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"WebSite","@id":"https:\/\/www.dpriver.com\/blog\/#website","url":"https:\/\/www.dpriver.com\/blog\/","name":"SQL and Data Blog","description":"SQL related blog for database professional","publisher":{"@id":"https:\/\/www.dpriver.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.dpriver.com\/blog\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/","url":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/","name":"General SQL Parser Java v0.4 release","isPartOf":{"@id":"https:\/\/www.dpriver.com\/blog\/#website"},"datePublished":"2010-05-31T02:58:54+00:00","dateModified":"2011-09-27T02:40:12+00:00","description":"General SQL Parser Java v0.4 release","breadcrumb":{"@id":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.dpriver.com\/blog\/"},{"@type":"ListItem","position":2,"name":"General SQL Parser Java v0.4 release"}]},{"@type":"Article","@id":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/#article","isPartOf":{"@id":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/"},"author":{"name":"James","@id":"https:\/\/www.dpriver.com\/blog\/#\/schema\/person\/7bbdbb6e79c5dd9747d08c59d5992b04"},"headline":"General SQL Parser Java v0.4 release","datePublished":"2010-05-31T02:58:54+00:00","dateModified":"2011-09-27T02:40:12+00:00","mainEntityOfPage":{"@id":"https:\/\/www.dpriver.com\/blog\/2010\/05\/general-sql-parser-java-v0-4-release\/"},"wordCount":332,"publisher":{"@id":"https:\/\/www.dpriver.com\/blog\/#organization"},"articleSection":["gsp","release"],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.dpriver.com\/blog\/#\/schema\/person\/7bbdbb6e79c5dd9747d08c59d5992b04","name":"James","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.dpriver.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/eeddf4ca7bdafa37ab025068efdc7302?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/eeddf4ca7bdafa37ab025068efdc7302?s=96&d=mm&r=g","caption":"James"},"sameAs":["http:\/\/www.dpriver.com"],"url":"https:\/\/www.dpriver.com\/blog\/author\/james\/"}]}},"_links":{"self":[{"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/posts\/197"}],"collection":[{"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/comments?post=197"}],"version-history":[{"count":17,"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/posts\/197\/revisions"}],"predecessor-version":[{"id":1005,"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/posts\/197\/revisions\/1005"}],"wp:attachment":[{"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/media?parent=197"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/categories?post=197"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.dpriver.com\/blog\/wp-json\/wp\/v2\/tags?post=197"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}