<?php // Полная загрузка сервисных книжек, создан 2025-01-05 12:44:55
global $wpdb2;
global $failure;
global $file_hist;
///// echo '<H2><b>Старт загрузки</b></H2><br>';
$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
///// echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}
$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
///// echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}
/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
///// echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
///// echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist); ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7]; ////получаем размер файла
$m_mtime_file=$masiv_data_file[9]; ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file
///// echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
///// echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
///// echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);
if ($results)
{ foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));
////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
///// echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
///// echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}
////загружаем данные
$table='vin_history'; // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация // (путь от корня web-сервера)
$delim=';'; // Разделитель полей в CSV файле
$enclosed='"'; // Кавычки для содержимого полей
$escaped='\
Основное приемущество перед аналогичными отчетами то, что свободные остатки учитываются исходя не только зарезервированных товаров, а также и товаров к передаче, если реализации по ордеру. А также есть возможность фильтра не только по реквизитам номенклатуры, но и ее свойствам.
Скачал отчет, который работает не правильно 🙁 Обидно, потратил стартмани 🙁
Отчет выводит резерв каждой характеристики как резерв по номенклатуре (см. картинку).
Скажите, как быстро сможете поправить?
(2) Доброго времени суток. Данный отчет составлялся в базе, где не ведется учет по характеристикам. Подправил отчет, теперь характеристики номенклатуры учитываются.
Доброго времени суток. Скачал отчет «Стоимостная оценка склада в ценах номенклатуры с учетом свободных остатков, товаров к передаче, резерва» в работе очень нужен. но вопрос — что можно туда добавить чтобы показывать цены во всех типах цен. Заранее спасибо
(4)
Добрый день!
Данный отчет не предусматривает этого.
Вы представляете, как он будет выглядеть, если мы добавим несколько типов цен?
Добавится колонок = Количество типов цен * 4. Или я неверно понял вопрос?
З.Ы.
Есть еще один отчет, который выводит остаток склада со всеми типами цен, включая покупную цену по регистру сведений цены номенклатуры контрагентов. Выложу его на следующей неделе.
Если отчетом поделитесь буду благодарен …а так я вроде сделал его. ноу да портянка получается красивая. Просто тут у меня вопрос другой возник, хотят чтобы показывал только последние цены. К примеру есть
…
10.01 — одна цена по одному типу цен
12.01 — другая цена по второму типу цен
12.01 — третья цена по третьему типу цен
Регистр сведений срез последних вытащит их все, а надо только те которые были самые поздние.. один из вариантов это упорядочивать по дате УБЫВ и вытаскивать через ПЕРВЫЕ…
Может есть другой вариант
(6)
https://infostart.ru/public/712553/ . Если разбираетесь в запросах, разберетесь сами.
В целом мысль Ваша верная.
Решение аналогичного вопроса лежит вот в этом моем отчете
Там как раз таки вычисляется последняя цена из всех типов цен номенклатуры контрагентов.
(7)
https://infostart.ru/public/712610/
Извиняюсь ссылку не на тот отчет выложил.
Вот правильная.
(8) этот отчет мне не подходит. у меня партионный учет упп. учет по характеристикам….а за идею спасибо
(9) Я прекрасно понимаю, что это совсем другой отчет. Привел его в пример, так как, как раз в нем есть хитрая схема вычисления последней цены из регистра сведений цены номенклатуры поставщиков. Т.е. существует множество поставщиков, у них разные типы цен. И вот как раз находим самую последнюю из всех типов на определенный момент времени.
Ясно. спасибо. ознакомлюсь