{"id":"https://openalex.org/W2157815165","doi":"https://doi.org/10.1145/1289971.1289976","title":"Simple and safe SQL queries with c++ templates","display_name":"Simple and safe SQL queries with c++ templates","publication_year":2007,"publication_date":"2007-10-01","ids":{"openalex":"https://openalex.org/W2157815165","doi":"https://doi.org/10.1145/1289971.1289976","mag":"2157815165"},"language":"en","primary_location":{"id":"doi:10.1145/1289971.1289976","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1289971.1289976","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 6th international conference on Generative programming and component engineering","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5110126527","display_name":"Joseph Gil","orcid":null},"institutions":[{"id":"https://openalex.org/I174306211","display_name":"Technion \u2013 Israel Institute of Technology","ror":"https://ror.org/03qryx823","country_code":"IL","type":"education","lineage":["https://openalex.org/I174306211"]}],"countries":["IL"],"is_corresponding":true,"raw_author_name":"Joseph (Yossi) Gil","raw_affiliation_strings":["Technion - Israel Institute of Technology, Haifa, Israel"],"affiliations":[{"raw_affiliation_string":"Technion - Israel Institute of Technology, Haifa, Israel","institution_ids":["https://openalex.org/I174306211"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5070071538","display_name":"Keren Lenz","orcid":null},"institutions":[{"id":"https://openalex.org/I174306211","display_name":"Technion \u2013 Israel Institute of Technology","ror":"https://ror.org/03qryx823","country_code":"IL","type":"education","lineage":["https://openalex.org/I174306211"]}],"countries":["IL"],"is_corresponding":false,"raw_author_name":"Keren Lenz","raw_affiliation_strings":["Technion - Israel Institute of Technology, Haifa, Israel"],"affiliations":[{"raw_affiliation_string":"Technion - Israel Institute of Technology, Haifa, Israel","institution_ids":["https://openalex.org/I174306211"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5110126527"],"corresponding_institution_ids":["https://openalex.org/I174306211"],"apc_list":null,"apc_paid":null,"fwci":5.5388,"has_fulltext":false,"cited_by_count":18,"citation_normalized_percentile":{"value":0.95810462,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":96},"biblio":{"volume":null,"issue":null,"first_page":"13","last_page":"24"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T12479","display_name":"Web Application Security Vulnerabilities","score":0.9998000264167786,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T12479","display_name":"Web Application Security Vulnerabilities","score":0.9998000264167786,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9847999811172485,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T11424","display_name":"Security and Verification in Computing","score":0.9846000075340271,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8700395822525024},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6835108995437622},{"id":"https://openalex.org/keywords/sql","display_name":"SQL","score":0.5440343022346497},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.48581862449645996},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.4827386736869812},{"id":"https://openalex.org/keywords/database","display_name":"Database","score":0.4721783697605133},{"id":"https://openalex.org/keywords/compile-time","display_name":"Compile time","score":0.46556687355041504},{"id":"https://openalex.org/keywords/stored-procedure","display_name":"Stored procedure","score":0.45934706926345825},{"id":"https://openalex.org/keywords/relational-database","display_name":"Relational database","score":0.44836682081222534},{"id":"https://openalex.org/keywords/query-by-example","display_name":"Query by Example","score":0.40777599811553955},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3366270065307617},{"id":"https://openalex.org/keywords/information-retrieval","display_name":"Information retrieval","score":0.1895657777786255}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8700395822525024},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6835108995437622},{"id":"https://openalex.org/C510870499","wikidata":"https://www.wikidata.org/wiki/Q47607","display_name":"SQL","level":2,"score":0.5440343022346497},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.48581862449645996},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.4827386736869812},{"id":"https://openalex.org/C77088390","wikidata":"https://www.wikidata.org/wiki/Q8513","display_name":"Database","level":1,"score":0.4721783697605133},{"id":"https://openalex.org/C200833197","wikidata":"https://www.wikidata.org/wiki/Q333707","display_name":"Compile time","level":3,"score":0.46556687355041504},{"id":"https://openalex.org/C154420247","wikidata":"https://www.wikidata.org/wiki/Q846619","display_name":"Stored procedure","level":5,"score":0.45934706926345825},{"id":"https://openalex.org/C5655090","wikidata":"https://www.wikidata.org/wiki/Q192588","display_name":"Relational database","level":2,"score":0.44836682081222534},{"id":"https://openalex.org/C194222762","wikidata":"https://www.wikidata.org/wiki/Q114486","display_name":"Query by Example","level":4,"score":0.40777599811553955},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3366270065307617},{"id":"https://openalex.org/C23123220","wikidata":"https://www.wikidata.org/wiki/Q816826","display_name":"Information retrieval","level":1,"score":0.1895657777786255},{"id":"https://openalex.org/C97854310","wikidata":"https://www.wikidata.org/wiki/Q19541","display_name":"Search engine","level":2,"score":0.0},{"id":"https://openalex.org/C164120249","wikidata":"https://www.wikidata.org/wiki/Q995982","display_name":"Web search query","level":3,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/1289971.1289976","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1289971.1289976","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 6th international conference on Generative programming and component engineering","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.599.9081","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.599.9081","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.cs.technion.ac.il/ssdl/research/ararat/GPCE.pdf","raw_type":"text"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.646.3861","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.646.3861","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://aszt.inf.elte.hu/~gsd/s/cikkek/gener/submission_29.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/16","score":0.699999988079071,"display_name":"Peace, Justice and strong institutions"}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":66,"referenced_works":["https://openalex.org/W32759632","https://openalex.org/W39754414","https://openalex.org/W53500718","https://openalex.org/W70764853","https://openalex.org/W73833125","https://openalex.org/W181162433","https://openalex.org/W203413558","https://openalex.org/W207286245","https://openalex.org/W1480385994","https://openalex.org/W1480892195","https://openalex.org/W1486064919","https://openalex.org/W1499611278","https://openalex.org/W1500250067","https://openalex.org/W1511154797","https://openalex.org/W1533109738","https://openalex.org/W1536203724","https://openalex.org/W1544695794","https://openalex.org/W1557561422","https://openalex.org/W1587166076","https://openalex.org/W1598339794","https://openalex.org/W1598340254","https://openalex.org/W1600084987","https://openalex.org/W1600215619","https://openalex.org/W1606614601","https://openalex.org/W1809751277","https://openalex.org/W1958582444","https://openalex.org/W1977101058","https://openalex.org/W1988633486","https://openalex.org/W1992847198","https://openalex.org/W2001693166","https://openalex.org/W2003751975","https://openalex.org/W2005318605","https://openalex.org/W2021229780","https://openalex.org/W2032852944","https://openalex.org/W2040846915","https://openalex.org/W2046078527","https://openalex.org/W2065883028","https://openalex.org/W2068860959","https://openalex.org/W2079404512","https://openalex.org/W2081048703","https://openalex.org/W2088675571","https://openalex.org/W2108340478","https://openalex.org/W2110338707","https://openalex.org/W2117174233","https://openalex.org/W2133625592","https://openalex.org/W2143378629","https://openalex.org/W2145287505","https://openalex.org/W2150866946","https://openalex.org/W2156508954","https://openalex.org/W2162883867","https://openalex.org/W2170830071","https://openalex.org/W2185907055","https://openalex.org/W2477074359","https://openalex.org/W2488377087","https://openalex.org/W2490529631","https://openalex.org/W2611598995","https://openalex.org/W2741365688","https://openalex.org/W2792939069","https://openalex.org/W2913602891","https://openalex.org/W2985731159","https://openalex.org/W2987803397","https://openalex.org/W2988119170","https://openalex.org/W2998952999","https://openalex.org/W3141603496","https://openalex.org/W4285719527","https://openalex.org/W4298433207"],"related_works":["https://openalex.org/W1488984669","https://openalex.org/W151494989","https://openalex.org/W2614112517","https://openalex.org/W2108932068","https://openalex.org/W1980548249","https://openalex.org/W2340883001","https://openalex.org/W2512678083","https://openalex.org/W2787219882","https://openalex.org/W2038123353","https://openalex.org/W4388053677"],"abstract_inverted_index":{"Most":[0],"software":[1],"applications":[2],"use":[3],"a":[4,15,53,76,109,171,175],"relational":[5,115],"database":[6,16,38],"for":[7,34,48,55,78,157,190],"data":[8],"man-agement":[9],"and":[10,62,65,174],"storage.":[11],"Interaction":[12],"with":[13,26,80,108],"such":[14,59],"is":[17,52],"often":[18],"done":[19,125],"by":[20,83,126,144,166],"letting":[21],"the":[22,37,85,91,95,127,133,136,145,180,188],"program":[23],"construct":[24],"strings":[25],"valid":[27],"SQL":[28,138,141],"statements,":[29],"which":[30],"are":[31,45,147,164],"then":[32],"sent":[33],"execution":[35],"to":[36,67,89,149,169],"engine.":[39],"The":[40,70],"fact":[41],"that":[42],"these":[43,81],"statements":[44,142],"only":[46],"checked":[47],"correctness":[49,134],"at":[50,131],"runtime":[51],"source":[54],"many":[56],"potential":[57],"problems":[58],"as":[60,124],"type":[61,172],"syntax":[63],"errors":[64],"vulnerability":[66],"injection":[68,150],"attacks.":[69,151],"ARARAT":[71],"system":[72,146,168,173],"presented":[73],"here":[74],"offers":[75],"method":[77],"dealing":[79],"predicaments,":[82],"coercing":[84],"host":[86],"C++":[87,107],"compiler":[88],"do":[90],"necessary":[92],"checks":[93],"of":[94,100,120,135,161,179],"generated":[96,137],"strings.":[97,139],"A":[98],"library":[99],"templates":[101],"(and":[102],"preprocessor":[103],"directives)":[104],"effectively":[105],"extends":[106],"little":[110],"language":[111,122],"representing":[112],"an":[113],"augmented":[114],"algebra":[116],"formalism.":[117],"Type":[118],"checking":[119],"this":[121],"extension,":[123],"template":[128],"library,":[129],"assures,":[130],"compile-time,":[132],"All":[140],"constructed":[143],"immune":[148],"Standard":[152],"techniques":[153],"(e.g.,":[154],"\u201cexpression":[155],"templates\u201d)":[156],"compile":[158],"time":[159],"representation":[160],"symbolic":[162,181],"structures,":[163],"enhanced":[165],"our":[167],"support":[170],"symbol":[176],"table":[177],"lookup":[178],"structure.":[182],"Our":[183],"work":[184],"may":[185],"also":[186],"open":[187],"way":[189],"embed-ding":[191],"other":[192],"domain":[193],"specific":[194],"languages":[195],"in":[196],"C++.":[197],"1.":[198]},"counts_by_year":[{"year":2019,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":1},{"year":2014,"cited_by_count":1},{"year":2013,"cited_by_count":2},{"year":2012,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
