@@ -2084,6 +2084,11 @@ fn parse_mssql_go_keyword() {
20842084 assert_eq ! ( stmts. len( ) , 2 ) ;
20852085 assert_eq ! ( stmts[ 1 ] , Statement :: Go ( GoStatement { count: Some ( 5 ) } ) ) ;
20862086
2087+ let go_statement_delimiter = "SELECT 1\n GO" ;
2088+ let stmts = ms ( ) . parse_sql_statements ( go_statement_delimiter) . unwrap ( ) ;
2089+ assert_eq ! ( stmts. len( ) , 2 ) ;
2090+ assert_eq ! ( stmts[ 1 ] , Statement :: Go ( GoStatement { count: None } ) ) ;
2091+
20872092 let bare_go = "GO" ;
20882093 let stmts = ms ( ) . parse_sql_statements ( bare_go) . unwrap ( ) ;
20892094 assert_eq ! ( stmts. len( ) , 1 ) ;
@@ -2117,15 +2122,22 @@ fn parse_mssql_go_keyword() {
21172122 assert_eq ! ( stmts. len( ) , 2 ) ;
21182123 assert_eq ! ( stmts[ 1 ] , Statement :: Go ( GoStatement { count: None } ) ) ;
21192124
2120- let actually_column_alias = "SELECT NULL AS GO" ;
2121- let stmt = ms ( ) . verified_only_select ( actually_column_alias) ;
2122- assert_eq ! (
2123- only( stmt. projection) ,
2124- SelectItem :: ExprWithAlias {
2125- expr: Expr :: Value ( Value :: Null . with_empty_span( ) ) ,
2126- alias: Ident :: new( "GO" ) ,
2125+ let actually_column_alias = "SELECT NULL GO" ;
2126+ let stmts = ms ( ) . parse_sql_statements ( actually_column_alias) . unwrap ( ) ;
2127+ assert_eq ! ( stmts. len( ) , 1 ) ;
2128+ match & stmts[ 0 ] {
2129+ Statement :: Query ( query) => {
2130+ let select = query. body . as_select ( ) . unwrap ( ) ;
2131+ assert_eq ! (
2132+ only( select. clone( ) . projection) ,
2133+ SelectItem :: ExprWithAlias {
2134+ expr: Expr :: Value ( Value :: Null . with_empty_span( ) ) ,
2135+ alias: Ident :: new( "GO" ) ,
2136+ }
2137+ ) ;
21272138 }
2128- ) ;
2139+ _ => panic ! ( "Expected Query statement" ) ,
2140+ }
21292141
21302142 let invalid_go_position = "SELECT 1; GO" ;
21312143 let err = ms ( ) . parse_sql_statements ( invalid_go_position) ;
@@ -2138,7 +2150,7 @@ fn parse_mssql_go_keyword() {
21382150 let err = ms ( ) . parse_sql_statements ( invalid_go_count) ;
21392151 assert_eq ! (
21402152 err. unwrap_err( ) . to_string( ) ,
2141- "sql parser error: Expected: end of statement , found: x"
2153+ "sql parser error: Expected: literal int or newline , found: x"
21422154 ) ;
21432155}
21442156
0 commit comments