nastra commented on code in PR #9675:
URL: https://github.com/apache/iceberg/pull/9675#discussion_r1501376695


##########
spark/v3.5/spark-extensions/src/main/scala/org/apache/spark/sql/catalyst/analysis/RewriteViewCommands.scala:
##########
@@ -102,20 +113,23 @@ case class RewriteViewCommands(spark: SparkSession) 
extends Rule[LogicalPlan] wi
   private def verifyTemporaryObjectsDontExist(
     name: Identifier,
     child: LogicalPlan): Unit = {
-    import org.apache.spark.sql.connector.catalog.CatalogV2Implicits._
-
     val tempViews = collectTemporaryViews(child)
-    tempViews.foreach { nameParts =>
-      throw new AnalysisException(
-        errorClass = "INVALID_TEMP_OBJ_REFERENCE",
-        messageParameters = Map(
-          "obj" -> "VIEW",
-          "objName" -> name.name(),
-          "tempObj" -> "VIEW",
-          "tempObjName" -> nameParts.quoted))
+    if (tempViews.nonEmpty) {
+      throw invalidRefToTempObject(name, tempViews.map(v => 
v.quoted).mkString("[", ", ", "]"), "VIEW")
     }
 
-    // TODO: check for temp function names
+    val tempFunctions = collectTemporaryFunctions(child)
+    if (tempFunctions.nonEmpty) {
+      throw invalidRefToTempObject(name, tempFunctions.mkString("[", ", ", 
"]"), "FUNCTION")

Review Comment:
   Based on the below example it seems functions don't belong to any catalog:
   ```
   spark-sql ()> use sandbox;
   Time taken: 0.013 seconds
   spark-sql ()> CREATE TEMPORARY FUNCTION temp_function AS 
'org.apache.hadoop.hive.ql.udf.generic.GenericUDAFAverage';
   Time taken: 0.012 seconds
   spark-sql ()> show user functions;
   sandbox.bucket
   sandbox.days
   sandbox.hours
   sandbox.iceberg_version
   sandbox.months
   sandbox.truncate
   sandbox.years
   temp_function
   Time taken: 0.028 seconds, Fetched 9 row(s)
   spark-sql ()> use spark_catalog;
   Time taken: 0.015 seconds
   spark-sql (default)> show user functions;
   temp_function
   Time taken: 0.045 seconds, Fetched 3 row(s)
   ```



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: issues-unsubscr...@iceberg.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: issues-unsubscr...@iceberg.apache.org
For additional commands, e-mail: issues-h...@iceberg.apache.org

Reply via email to