| 11:10:43.912 | trace | yii\base\Application::bootstrap | Bootstrap with yii\log\Dispatcher |
| 11:10:43.912 | trace | yii\base\Module::getModule | Loading module: debug |
| 11:10:43.913 | trace | yii\base\Application::bootstrap | Bootstrap with yii\debug\Module::bootstrap() |
| 11:10:43.914 | trace | yii\redis\Connection::open | Opening redis DB connection: redis.server.local:6379, database=1 |
| 11:10:43.914 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: SELECT |
| 11:10:43.914 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.915 | info | time tracing start | 1782789043915366912 |
| 11:10:43.915 | trace | yii\web\UrlManager::parseRequest | No matching URL rules. Using default URL parsing logic. |
| 11:10:43.915 | trace | yii\web\Application::handleRequest | Route requested: 'vue/erp-analysis/sales-product-component-histogram' |
| 11:10:43.915 | trace | yii\base\Module::getModule | Loading module: vue |
| 11:10:43.917 | info | yii\web\Session::open | Session started |
| 11:10:43.919 | info | yii\db\Command::query | SELECT * FROM "global"."vw_user_login" WHERE "id"=1001 |
| 11:10:43.919 | info | yii\db\Connection::open | Opening DB connection: pgsql:host=postgresql.server.local;port=5432;dbname=beta |
| 11:10:43.921 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.921 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: MGET |
| 11:10:43.922 | info | yii\db\Command::query | SELECT * FROM "global"."vw_user_login" WHERE "id"=1001 |
| 11:10:43.923 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.924 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: MGET |
| 11:10:43.924 | info | yii\db\Command::query | SELECT * FROM "a57be577deb434"."tbl_users" WHERE "id"=1001 |
| 11:10:43.925 | trace | yii\base\Controller::runAction | Route to run: vue/erp-analysis/sales-product-component-histogram |
| 11:10:43.925 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.927 | trace | uranus\rbac\DbManager::checkAccessFromCache | Checking role: Admin |
| 11:10:43.927 | trace | yii\base\InlineAction::runWithParams | Running action: app\modules\vue\controllers\ErpAnalysisController::actionSalesProductComponentHistogram() |
| 11:10:43.928 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.929 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.931 | info | yii\db\Command::query | SELECT
ex.id,
ex.name,
sum(sub.amount) as budget,
sum(sub.amount - sub.cost) as profits,
sum(sub.number) as number,
CASE WHEN sum(sub.amount) != 0 THEN (sum(sub.amount) - sum(sub.cost)) / sum(sub.amount) * 100 ELSE 0 END as profit_pct
FROM "a57be577deb434"."tbl_product_components" "ex" RIGHT JOIN (SELECT
p.product_component,
sum(sub.amount) as amount,
sum(sub.cost) as cost,
sum(sub.number) as number
FROM "a57be577deb434"."tbl_products" "p" LEFT JOIN (SELECT esosps.product_id, sum(eipss.total_amount) as amount, sum(eipss.actual_total_amount) as cost, COALESCE(sum(esosps.number)) as number FROM "a57be577deb434"."tbl_erp_sales_outbound_spent_products" "esosps" LEFT JOIN "a57be577deb434"."tbl_erp_sales_outbounds" "t" ON esosps.erp_sales_outbound_id = t.id LEFT JOIN "a57be577deb434"."tbl_projects" "project" ON project.id = t.project_id LEFT JOIN "a57be577deb434"."tbl_erp_inventory_product_spents" "eipss" ON eipss.erp_sales_outbound_spent_product_id = esosps.id WHERE ("t"."status"=2) AND ("project"."created_by" IN (1001, 5049, 5500, 5301, 5499, 5022, 5209, 5026, 5293, 5309, 5356, 5329, 5299, 5303, 5302, 5332, 5047, 1026, 5096, 5070, 5448, 5420, 1029, 5037, 5087, 1008, 5048, 5043, 5045, 5230, 5031, 5088, 5208, 1003, 5467, 5294, 5357, 5044, 1030, 5076, 5300, 5027, 5089, 5311, 5066, 5069, 5364, 1009, 5295, 1013, 5128, 5203, 1025, 5032, 5075, 5476, 1004, 5072, 5033, 5359, 5412, 5409, 5229, 1005, 5304, 5449, 5358, 1006, 5093)) AND ("project"."bargain_date" >= '2026-01-01 00:00:00') AND ("project"."bargain_date" <= '2026-12-31 23:59:59') AND (((project.budget > project.collected) AND ("project"."project_status" IN ('3', '-1'))) OR ((project.budget <= project.collected) AND ("project"."project_status"=3))) GROUP BY "esosps"."product_id") "sub" ON sub.product_id = p.id WHERE ("p"."product_type"='4') AND ("p"."product_brand"='4') GROUP BY "p"."product_component") "sub" ON sub.product_component = ex.id GROUP BY "ex"."id", "sub"."product_component" HAVING sum(sub.amount) != 0 |
| 11:10:43.954 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:43.959 | info | yii\db\Command::query | SELECT
d.nspname AS table_schema,
c.relname AS table_name,
a.attname AS column_name,
t.typname AS data_type,
a.attlen AS character_maximum_length,
pg_catalog.col_description(c.oid, a.attnum) AS column_comment,
a.atttypmod AS modifier,
a.attnotnull = false AS is_nullable,
CAST(pg_get_expr(ad.adbin, ad.adrelid) AS varchar) AS column_default,
coalesce(pg_get_expr(ad.adbin, ad.adrelid) ~ 'nextval',false) AS is_autoinc,
array_to_string((select array_agg(enumlabel) from pg_enum where enumtypid=a.atttypid)::varchar[],',') as enum_values,
CASE atttypid
WHEN 21 /*int2*/ THEN 16
WHEN 23 /*int4*/ THEN 32
WHEN 20 /*int8*/ THEN 64
WHEN 1700 /*numeric*/ THEN
CASE WHEN atttypmod = -1
THEN null
ELSE ((atttypmod - 4) >> 16) & 65535
END
WHEN 700 /*float4*/ THEN 24 /*FLT_MANT_DIG*/
WHEN 701 /*float8*/ THEN 53 /*DBL_MANT_DIG*/
ELSE null
END AS numeric_precision,
CASE
WHEN atttypid IN (21, 23, 20) THEN 0
WHEN atttypid IN (1700) THEN
CASE
WHEN atttypmod = -1 THEN null
ELSE (atttypmod - 4) & 65535
END
ELSE null
END AS numeric_scale,
CAST(
information_schema._pg_char_max_length(information_schema._pg_truetypid(a, t), information_schema._pg_truetypmod(a, t))
AS numeric
) AS size,
a.attnum = any (ct.conkey) as is_pkey
FROM
pg_class c
LEFT JOIN pg_attribute a ON a.attrelid = c.oid
LEFT JOIN pg_attrdef ad ON a.attrelid = ad.adrelid AND a.attnum = ad.adnum
LEFT JOIN pg_type t ON a.atttypid = t.oid
LEFT JOIN pg_namespace d ON d.oid = c.relnamespace
LEFT join pg_constraint ct on ct.conrelid=c.oid and ct.contype='p'
WHERE
a.attnum > 0 and t.typname != ''
and c.relname = 'tbl_product_components'
and d.nspname = 'a57be577deb434'
ORDER BY
a.attnum; |
| 11:10:43.975 | info | yii\db\Command::query | select
ct.conname as constraint_name,
a.attname as column_name,
fc.relname as foreign_table_name,
fns.nspname as foreign_table_schema,
fa.attname as foreign_column_name
from
(SELECT ct.conname, ct.conrelid, ct.confrelid, ct.conkey, ct.contype, ct.confkey, generate_subscripts(ct.conkey, 1) AS s
FROM pg_constraint ct
) AS ct
inner join pg_class c on c.oid=ct.conrelid
inner join pg_namespace ns on c.relnamespace=ns.oid
inner join pg_attribute a on a.attrelid=ct.conrelid and a.attnum = ct.conkey[ct.s]
left join pg_class fc on fc.oid=ct.confrelid
left join pg_namespace fns on fc.relnamespace=fns.oid
left join pg_attribute fa on fa.attrelid=ct.confrelid and fa.attnum = ct.confkey[ct.s]
where
ct.contype='f'
and c.relname='tbl_product_components'
and ns.nspname='a57be577deb434'
order by
fns.nspname, fc.relname, a.attnum |
| 11:10:43.999 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: MGET |
| 11:10:44.004 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: SET |
| 11:10:44.010 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:44.014 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: MGET |
| 11:10:44.016 | info | yii\db\Command::query | INSERT INTO "global"."tbl_api_log" ("code", "schema", "user_id", "device_type", "url", "request", "response", "php_error", "time", "duration") VALUES (200, 'a57be577deb434', 1001, 5, 'vue/erp-analysis/sales-product-component-histogram', '{"product_brand":"4","product_type":"4","produect":"product_brand","series":"seriesBudget","project_status":["3","-1"],"period":"currentfascalyear","web_access_token":"x0LWxNxY1IWpHbWh_3nnhDQVjp8ngz97"}', '{"code":2000,"result":{"category":{"budgetCategory":["\u534f\u4f5c"],"profitsCategory":["\u534f\u4f5c"],"profitsPctCategory":["\u534f\u4f5c"]},"seriesBudget":[{"key":52,"name":"\u534f\u4f5c","number":"15","y":"1271.25"}],"seriesProfits":[{"key":52,"name":"\u534f\u4f5c","number":"15","y":"1269.87"}],"seriesProfitsPct":[{"key":52,"name":"\u534f\u4f5c","number":"15","y":"99.89"}],"totalCount":{"totalBudget":1271.25,"totalProfits":1269.87,"pct":0.9989}},"status":1,"msg":[{"name":"success","success":"\u6210\u529f\u83b7\u53d6\u6570\u636e","error":""}],"mod":0,"ip":"39.156.194.178","ua":"Mozilla\/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit\/537.36 (KHTML, like Gecko) Chrome\/147.0.0.0 Safari\/537.36"}', FALSE, '2026-06-30 11:10:44', 101211136) RETURNING "id" |
| 11:10:44.035 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: GET |
| 11:10:44.036 | trace | yii\redis\Connection::executeCommand | Executing Redis Command: SET |