2016-11-16 102 views
0

我不是MYSQL的專家,主要在tsql中開發,但我需要編寫一段動態代碼,它會根據特定的日期範圍給出每個表的記錄數。下面的代碼給了我數據庫中所有表的行數,但是我有第二個表,每個表都有一個記錄,並說明它是否有我可以查詢的create_date字段。我想要做的是改變我的代碼來查看輔助表,並使用created_date字段(如果可用的話)構建select語句。計劃是在過程的頂部傳遞一個日期,並使用該日期來計算僅在必填字段可用時的計數,如果不可用,則將顯示總記錄數。動態mysql記錄計數

希望已經有所作爲,任何指針都會非常感謝,正如我之前所說MYSQL不是我的東西,但我想學習。

由於P

SET SESSION group_concat_max_len = (1000000); 
SET GLOBAL max_allowed_packet = (50*1024*1024); 

select 
    -- Sort the tables by count 
    concat( 
    'select * from (', 
    -- Aggregate rows into a single string connected by unions 
    group_concat(
     -- Build a "select count(1) from db.tablename" per table 
     concat('select ', 
     quote(db), ' db, ', 
     quote(tablename), ' tablename, ' 
     'count(1) "rowcount" ', 
     'from ', db, '.', tablename) 
     separator ' union ') 
    , ') t ') 
into @sql 
from (
    select 
    table_schema db, 
    table_name tablename 
    from information_schema.tables 
    where table_schema not in 
    ('sampledatabase') 
) t; 

-- Execute @sql 
prepare s from @sql; execute s; deallocate prepare s; 

回答

0

的MySQL實際上有表列的列表,你可以看看那裏如果表中有一欄create_date在這種情況下添加一個where -condition:

set @mydate = '2016-01-01'; 

select 
    -- Sort the tables by count 
    concat( 
    'select * from (', 
    -- Aggregate rows into a single string connected by unions 
    group_concat(
     -- Build a "select count(1) from db.tablename" per table 
     concat('select ', 
     quote(db), ' db, ', 
     quote(tablename), ' tablename, ', 
     'count(1) rowcount, ', 
     has_createddate, ' filtered ', 
     'from `', db, '`.`', tablename,'`', 
     -- add "where" when the column is there 
     case when has_createddate = 1 then concat(' where create_date ', 
     -- your filter condition, e.g. 
     ' >= ''', @mydate, '''') 
     else '' end 
    ) 
     separator ' union ') 
    , ') t ') 
into @sql 
from (
    select 
    t.table_schema db, 
    t.table_name tablename, 
    case when not c.COLUMN_NAME is null then 1 else 0 end has_createddate 
    from information_schema.tables t 
    left join information_schema.COLUMNS c 
    on t.table_schema = c.table_schema 
    and t.table_name = c.table_name 
    and c.column_name = 'create_date' 
    where t.table_schema not in ('sampledatabase') 
) t; 

您可以用相同的邏輯使用自己的表格。如果查找表中的字段包含要過濾的列名(而不是常量create_date),則可以使用concat中的該列(例如,

... 
case when not filtercol is null then concat(' where `', filtercol, '`', ' >= ''', 
... 
+0

嗨Solarflare,這是燦爛的,正是我期待的,你每天都在學習新的東西。 – PJD