首页 php教程 PHP源码 SQL语句解析函数

SQL语句解析函数

May 25, 2016 pm 05:14 PM

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

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

function SQL语句解析函数($sql)                {

    global $db,$MetaTables;

    //判断自定义表是否存在,如果不存在直接返回

 

    //判断是否是联合全操作,是否有子查询,是否用left

    //如果有,则表示为手写SQL代码,不是系统生成,则直接返回,不进行过滤

    $sql        = trim($sql);

    $sqllower   = strtolower($sqllower);

    if(substr($sqllower,0,strlen("create table"))=="create table")      {

        return $sql;

    }

    if(substr($sqllower,0,strlen("drop table"))=="drop table")          {

        return $sql;

    }

    if(substr($sqllower,0,strlen("check table"))=="check table")        {

        return $sql;

    }

    if(substr($sqllower,0,strlen("optimize table"))=="optimize table")  {

        return $sql;

    }

    if(substr($sqllower,0,strlen("repair table"))=="repair table")      {

        return $sql;

    }

    if(substr($sqllower,0,strlen("analyze table"))=="analyze table")    {

        return $sql;

    }

     

    //进行关键字过滤

    $sql = eregi_replace(" From "," from ",$sql);

    $sql = eregi_replace(" FROM "," from ",$sql);

 

    $sql = eregi_replace(" Where "," where ",$sql);

    $sql = eregi_replace(" WHERE "," where ",$sql);

 

    $sql = eregi_replace(" Select "," select ",$sql);

    $sql = eregi_replace(" SELECT "," select ",$sql);

 

    $sql = eregi_replace(" Order By "," order by ",$sql);

    $sql = eregi_replace(" ORDER BY "," order by ",$sql);

 

    $sql = eregi_replace(" Update "," update ",$sql);

    $sql = eregi_replace(" UPDATE "," update ",$sql);

 

    $sql = eregi_replace(" Delete "," delete ",$sql);

    $sql = eregi_replace(" DELETE "," delete ",$sql);

 

    $sql = eregi_replace(" Limit "," limit ",$sql);

    $sql = eregi_replace(" LIMITE "," limit ",$sql);

 

    $sql = eregi_replace(" Left "," left ",$sql);

    $sql = eregi_replace(" LEFT "," left ",$sql);

 

    //处理SELECT

    if(substr($sql,0,strlen("select "))=="select ")     {

        $FromArray = explode(" from ",$sql);

        //分析旧的SQL

        if($FromArray[1]!="")                 {

            $FromSelectArray        = explode("select ",$FromArray[0]);

            $SQLArray['SelectText'] = $FromSelectArray[1];

            $FromWhereArray         = explode(" where ",$FromArray[1]);

            $SQLArray['FromText']   = $FromWhereArray[0];

            //如果是两个表,直接返回,不做处理

            $FromTablesArray        = explode(",",$SQLArray['FromText']);

            if($FromTablesArray[1]!='')         {

                print "两个表";

                return $sql;

            }

            //拆分数据库和表

            $FromDBArray            = explode(".",$SQLArray['FromText']);

            if($FromDBArray[1]!="")                   {

                $SQLArray['FromText']   = $FromDBArray[1];

                $SQLArray['DBText']     = $FromDBArray[0];

            }

            $SQLArray['WhereText']  = $FromWhereArray[1];

            $FromOrderByArray       = explode(" order by ",$SQLArray['WhereText']);

            if($FromOrderByArray[1]!="")                  {

                $SQLArray['WhereText']  = $FromOrderByArray[0];

                $SQLArray['OrderByText']= $FromOrderByArray[1];

            }

        }

        //处理新的SQL,之前要进行判断表自定义表是否存在

        $TABLENAME = $SQLArray['FromText'];

        $TABLENAME2 = "view_".$TABLENAME;

        if(in_array($TABLENAME2,$MetaTables))                   {

            //自定义表存在

            $MetaColumnNames    = $db->MetaColumnNames($TABLENAME);

            $MetaColumnNames    = array_keys($MetaColumnNames);

            $原表主键   = $MetaColumnNames[0];

            $MetaColumnNames2   = $db->MetaColumnNames($TABLENAME2);

            $MetaColumnNames2   = array_keys($MetaColumnNames2);

            $新表主键   = $MetaColumnNames2[0];

            array_shift($MetaColumnNames2);

            $自定义表字段列表 = join(',',$MetaColumnNames2);

            $SQLArray['SelectText'] .= ",".$自定义表字段列表;

            $SQLArray['FromText']   .= ",".$TABLENAME2;

            if($SQLArray['WhereText']!="")        {

                $SQLArray['WhereText'] .= " and ".$TABLENAME.".".$原表主键."=".$TABLENAME2.".".$新表主键."";

            }

            else    {

                $SQLArray['WhereText']  = " ".$TABLENAME.".".$原表主键."=".$TABLENAME2.".".$新表主键."";

            }

        }

        else    {

            //不存在,直接返回

            return $sql;

        }

        //形成新的SQL文件

        $NEWTEXTSQL = "select ".$SQLArray['SelectText']." from ".$SQLArray['FromText']."";

        if(TRIM($SQLArray['WhereText'])!="")      {

            $NEWTEXTSQL .=" where ".$SQLArray['WhereText'];

        }

        if(TRIM($SQLArray['OrderByText'])!="")        {

            $NEWTEXTSQL .=" order by ".$SQLArray['WhereText'];

        }

        //形成后返回

        return $NEWTEXTSQL;

        //SELECT  部分结束

    }

     

    //UPDATE

 

    //DELETE

 

    //INSERT INTO

 

 

     

    print_R($NEWTEXTSQL);

    print_R($SQLArray);

     

 

}

登录后复制

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)