123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- <?php
- namespace modules\dataexport\library;
- use app\admin\model\routine\Dataexport;
- use think\facade\Db;
- class ExportLib
- {
- protected $row = null;
- protected $fields = [];
- protected $join = [];
- protected $where = [];
- protected $order = [];
- public function __construct(int $id)
- {
- $this->row = Dataexport::where('id', $id)->find();
- foreach ($this->row->field_config as $item) {
- $asName = $this->row->main_table . '.' . $item['name'] . ' as ' . $this->row->main_table . '_' . $item['name'];
- $item['field'] = $this->row->main_table . '_' . $item['name'];
- $this->fields[$asName] = $item;
- }
- if ($this->row->join_table) {
- foreach ($this->row->join_table as $joinTable) {
- foreach ($joinTable['fields'] as $item) {
- $joinAsName = $joinTable['asname'] ? $joinTable['asname'] : $joinTable['table'];
- $asName = $joinAsName . '.' . $item['name'] . ' as ' . $joinAsName . '_' . $item['name'];
- $item['field'] = $joinAsName . '_' . $item['name'];
- $this->fields[$asName] = $item;
- }
- $condition = vsprintf('%s.%s = %s.%s', [
- $this->row->main_table,
- $joinTable['fk'],
- $joinAsName,
- $joinTable['pk']
- ]);
- $this->join[] = [$joinTable['table'] . ' ' . $joinAsName, $condition, $joinTable['type'] ?? 'LEFT'];
- }
- }
-
- if ($this->row->where_field) {
- foreach ($this->row->where_field as $item) {
- $this->where[] = [$item['field'], $item['operator'], $item['value']];
- }
- }
-
- if ($this->row->order_field) {
- foreach ($this->row->order_field as $item) {
- $this->order[$item['field']] = $item['value'];
- }
- }
- }
- public function getSql(string $type = '', $data = [])
- {
- $res = Db::name($this->row->main_table)
- ->alias($this->row->main_table)
- ->field(implode(',', array_keys($this->fields)))
- ->where($this->where)
- ->order($this->order);
- foreach ($this->join as $item) {
- $res->join($item[0], $item[1], $item[2]);
- }
- if ($type == 'limit') {
- return $res->fetchSql()->limit($data[0], $data[1])->select();
- } elseif ($type == 'test') {
- return $res->fetchSql()->limit(10)->select();
- }
- return $res;
- }
- public function getXlsTitle(): array
- {
- $title = [];
- foreach ($this->fields as $key => $value) {
- $title[] = $value['title'] ?: $key;
- }
- return $title;
- }
- public function getFields()
- {
- return $this->fields;
- }
- public function assignment($value, $comment)
- {
- if ($comment) {
- $comment = explode(',', $comment);
- foreach ($comment as $v) {
- list($itemKey, $itemValue) = explode('=', $v);
- if ($itemKey == $value) {
- return $itemValue;
- }
- }
- }
- return $value;
- }
- public function getCount()
- {
- $sql = $this->getSql();
- return $sql->count();
- }
- }
|