wanglizhong
2025-05-05 9b8a7157bb9c401de973a4107f74ff3e723ec156
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
<?php
class LtDbSqlAdapterPgsql implements LtDbSqlAdapter
{
    public function setCharset($charset)
    {
        return "SET client_encoding TO '$charset'";
    }
    public function setSchema($schema)
    {
        return "SET search_path TO $schema";
    }
 
    public function beginTransaction()
    {
        return "";
    }
    public function commit()
    {
        return "";
    }
    public function rollBack()
    {
        return "";
    }
 
    public function showSchemas($database)
    {
 
    }
    public function showTables($schema)
    {
        return "SELECT case when n.nspname='public' then c.relname else n.nspname||'.'||c.relname end as relname 
                FROM pg_class c join pg_namespace n on (c.relnamespace=n.oid)
                WHERE c.relkind = 'r'
                    AND n.nspname NOT IN ('information_schema','pg_catalog')
                    AND n.nspname NOT LIKE 'pg_temp%'
                    AND n.nspname NOT LIKE 'pg_toast%'
                ORDER BY relname";
    }
    public function showFields($table)
    {
        return "SELECT a.attnum, a.attname AS field, t.typname AS type, 
                format_type(a.atttypid, a.atttypmod) AS complete_type, 
                a.attnotnull AS isnotnull, 
                ( SELECT 't' FROM pg_index 
                WHERE c.oid = pg_index.indrelid 
                AND pg_index.indkey[0] = a.attnum 
                AND pg_index.indisprimary = 't') AS pri, 
                (SELECT pg_attrdef.adsrc FROM pg_attrdef 
                WHERE c.oid = pg_attrdef.adrelid 
                AND pg_attrdef.adnum=a.attnum) AS default 
                FROM pg_attribute a, pg_class c, pg_type t 
                WHERE c.relname = '$table' 
                AND a.attnum > 0 
                AND a.attrelid = c.oid 
                AND a.atttypid = t.oid 
                ORDER BY a.attnum";
    }
 
    public function limit($limit, $offset)
    {
        return " LIMIT $limit OFFSET $offset";
    }
 
    public function getSchemas($queryResult)
    {
        
    }
    public function getTables($queryResult)
    {
        
    }
    public function getFields($queryResult)
    {
        
    }
    public function detectQueryType($sql)
    {
        
    }
}