-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathsql_parser.rb
36 lines (23 loc) · 990 Bytes
/
sql_parser.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
class SqlParser
def initialize (sql_to_parse)
@sql_to_parse = sql_to_parse
end
attr_accessor :parsed_sql
def parse
matches = /(exec)*\s*sp_executesql\s+N'([\s\S]*)',\s*N'(@[\s\S]*?)',\s*([\s\S]*)/.match(@sql_to_parse)
@parsed_sql = @sql_to_parse
return false unless matches != nil
params = matches[3].split(',')
new_sql = "BEGIN\n"
params.each {|p| new_sql += "DECLARE #{p.strip};"}
param_values = matches[4].split(',')
new_sql += "\n"
param_values.each {|p| new_sql += "\nSET #{p.strip};"}
# Need to go here to format it :) http://sqlformat.appspot.com/
result = Net::HTTP.post_form(URI.parse("http://sqlformat.appspot.com/format/"),
{"data" => matches[2].to_s.gsub(/''/,"'"), "format" => "text", "keyword_case" => "upper", "reindent" => "true", "n_indents" => "2"})
new_sql += "\n\n" + (result.code == 200 ? body : matches[2].to_s.gsub(/''/,"'")) + "\nEND"
@parsed_sql = new_sql
true
end
end