You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

CaseWhen.java 1.8KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /*
  2. * Copyright 2004-2011 H2 Group.
  3. * Copyright 2011 James Moger.
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. package com.iciql.bytecode;
  18. import com.iciql.Query;
  19. import com.iciql.SQLStatement;
  20. import com.iciql.Token;
  21. /**
  22. * A conditional expression.
  23. */
  24. public class CaseWhen implements Token {
  25. private final Token condition, ifTrue, ifFalse;
  26. private CaseWhen(Token condition, Token ifTrue, Token ifFalse) {
  27. this.condition = condition;
  28. this.ifTrue = ifTrue;
  29. this.ifFalse = ifFalse;
  30. }
  31. static Token get(Token condition, Token ifTrue, Token ifFalse) {
  32. if ("0".equals(ifTrue.toString()) && "1".equals(ifFalse.toString())) {
  33. return Not.get(condition);
  34. } else if ("1".equals(ifTrue.toString()) && "0".equals(ifFalse.toString())) {
  35. return condition;
  36. } else if ("0".equals(ifTrue.toString())) {
  37. return And.get(Not.get(condition), ifFalse);
  38. }
  39. return new CaseWhen(condition, ifTrue, ifFalse);
  40. }
  41. public String toString() {
  42. return "CASEWHEN(" + condition + ", " + ifTrue + ", " + ifFalse + ")";
  43. }
  44. public <T> void appendSQL(SQLStatement stat, Query<T> query) {
  45. stat.appendSQL("CASEWHEN ");
  46. condition.appendSQL(stat, query);
  47. stat.appendSQL(" THEN ");
  48. ifTrue.appendSQL(stat, query);
  49. stat.appendSQL(" ELSE ");
  50. ifFalse.appendSQL(stat, query);
  51. stat.appendSQL(" END");
  52. }
  53. }