--- a/src/main/scala/RDB2RDFMain.scala Sun Dec 06 01:56:35 2009 -0500
+++ b/src/main/scala/RDB2RDFMain.scala Wed Dec 09 17:25:36 2009 -0500
@@ -6,7 +6,7 @@
object MyParsers extends RegexParsers {
val uri = """[a-zA-Z0-9:/#\.]+""".r
-
+ val name = """[a-zA-Z_][a-zA-Z0-9_]*""".r
}
import MyParsers._
@@ -65,6 +65,49 @@
}
+case class Select(attributelist:AttributeList, tablelist:TableList, expression:Expression)
+
+case class AttributeList(attributes:List[NamedAttribute])
+case class NamedAttribute(fqattribute:FQAttribute, attribute:Attribute)
+case class FQAttribute(relation:Relation, attribute:Attribute)
+case class Attribute(n:Name)
+case class Relation(n:Name)
+case class TableList(tablealias:TableAlias, joins:List[Join])
+case class Join(tablealias:TableAlias, expression:Expression)
+case class TableAlias(rel:Relation, as:Relation)
+case class Expression(conjuncts:List[PrimaryExpression])
+sealed abstract class PrimaryExpression
+case class PrimaryExpressionEq(l:FQAttribute, r:RValue)
+case class PrimaryExpressionLt(l:FQAttribute, r:RValue)
+case class PrimaryExpressionNotNull(l:FQAttribute)
+sealed abstract class RValue
+case class RValueAttr(fqattribute:FQAttribute)
+case class RValueInt(i:Name)
+case class RValueString(i:Name)
+
+case class Name(s:String)
+
+
+case class Sql() extends JavaTokenParsers {
+
+ def select = "SELECT" ~ attributelist ~ "FROM" ~ tablelist ~ opt("WHERE" ~ expression)
+ def attributelist = repsep(namedattribute, ",")
+ def namedattribute = fqattribute ~ "AS" ~ attribute
+ def fqattribute = relation ~ "." ~ attribute
+ def attribute = """[a-zA-Z_]\w*""".r
+ def relation = """[a-zA-Z_]\w*""".r
+ def tablelist = tablealias ~ rep("INNER" ~ "JOIN" ~ tablealias ~ "ON" ~ expression)
+ def tablealias = relation ~ "AS" ~ relation
+ def expression = repsep(primaryexpression, "AND")
+ def primaryexpression = ( fqattribute ~ "=" ~ rvalue
+ | fqattribute ~ "<" ~ rvalue
+ | fqattribute ~ "IS" ~ "NOT" ~ "NULL" )
+ def rvalue = ( fqattribute
+ | """[0-9]+""".r
+ | "\"[^\"]*\"".r )
+
+}
+
object Sparql {
def parsePredicateURI(x:String):PUri = {
--- a/src/test/scala/RDB2RDFTest.scala Sun Dec 06 01:56:35 2009 -0500
+++ b/src/test/scala/RDB2RDFTest.scala Wed Dec 09 17:25:36 2009 -0500
@@ -38,4 +38,54 @@
Attr("lastName")))
}
+ test("SQLbgp") {
+ val a = Sql()
+ val e = """
+SELECT emp.lastName AS empName, manager.lastName AS managName
+ FROM Employee AS emp
+ INNER JOIN Employee AS manager ON manager.id=emp.manager
+ WHERE emp.lastName IS NOT NULL AND manager.lastName IS NOT NULL
+"""
+ println(a.parseAll(a.select, e))
+ }
+
+ test("tup1") {
+ val a = Sql()
+ val e = """
+SELECT emp.lastName AS empName
+ FROM Employee AS emp
+ WHERE emp.manager=18 AND emp.lastName IS NOT NULL
+"""
+ println(a.parseAll(a.select, e))
+ }
+
+ test("litConst1") {
+ val a = Sql()
+ val e = """
+SELECT emp.lastName AS empName
+ FROM Employee AS emp
+ INNER JOIN Employee AS manager ON emp.manager=manager.id
+ AND manager.lastName="Johnson"
+WHERE emp.lastName IS NOT NULL
+"""
+ println(a.parseAll(a.select, e))
+ }
+
+ test("filter1") {
+ val a = Sql()
+ val e = """
+SELECT emp.lastName AS empName, grandManager.lastName AS grandManagName
+ FROM Employee AS emp
+ INNER JOIN Manage AS lower ON lower.manages=emp.id
+ INNER JOIN Employee AS manager ON manager.id=lower.manager
+ AND manager.birthday < emp.birthday
+ INNER JOIN Manage AS upper ON upper.manages=manager.id
+ INNER JOIN Employee AS grandManager ON grandManager.id=upper.manager
+ AND grandManager.birthday < manager.birthday
+ WHERE emp.lastName IS NOT NULL AND grandManager.lastName IS NOT NULL
+"""
+ println(a.parseAll(a.select, e))
+ }
+
+
}