Не устанавливайте поле сортировки вручную. Используйте класс DataHandler для сортировки.
Если вы хотите сделать изменения сортировки позицию записи использовать COMAND как:
$cmd[ tablename ][ uid ][ command ] = value
Вы можете найти более подробную информацию прямо здесь:
https://docs.typo3.org/typo3cms/CoreApiReference/ApiOverview/Typo3CoreEngine/Database/Index.html
С COMAND двигаться вы можете поменять позицию записи в таблице.
Когда вы созданная в COMAND вы можете выполнить с этим кодом
$tce = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Core\\DataHandling\\DataHandler');
$tce->stripslashes_values = 0;
$tce->start(array(), $cmd);
$tce->process_cmdmap();
Это же COMAND TYPO3 использует в Backend для сортировки списка. 
Для получения дополнительной информации по DataHandler вызова смотрите здесь:
https://docs.typo3.org/typo3cms/CoreApiReference/ApiOverview/Typo3CoreEngine/UsingDataHandler/Index.html
Пример Repository:
class SortedRepository extends \TYPO3\CMS\Extbase\Persistence\Repository
{
protected $defaultOrderings = array(
'sorting' => \TYPO3\CMS\Extbase\Persistence\QueryInterface::ORDER_ASCENDING,
);
public function moveUp($entity)
{
$tce = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Core\\DataHandling\\DataHandler');
$tce->stripslashes_values = 0;
$entityTwoBefore = $this->getTwoBefore($entity);
if ($entityTwoBefore != null) {
//category is minimum 3
//can set over UID
$cmd[$this->getTableName($entity)][$entity->getUid()]['move']= 0-$entityTwoBefore->getUid();
} else {
//can only set over pid
$cmd[$this->getTableName($entity)][$entity->getUid()]['move']= Util::getStorageID();
}
$tce->start(array(), $cmd);
$tce->process_cmdmap();
}
public function moveDown($entity)
{
$tce = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Core\\DataHandling\\DataHandler');
$tce->stripslashes_values = 0;
$nextEntity = $this->getNext($entity);
if ($nextEntity != null) {
$cmd[$this->getTableName($entity)][$entity->getUid()]['move'] = 0 - $nextEntity->getUid();
}
$tce->start(array(), $cmd);
$tce->process_cmdmap();
}
private function getNext($entity)
{
$entities = $this->findAll();
$match = false;
foreach ($entities as $entityFor) {
if ($entityFor->getUid() == $entity->getUid()) {
$match = true;
continue;
}
if ($match == true) {
return $entityFor;
}
}
}
private function getBefore($entity)
{
$entities = array_reverse($this->findAll()->toArray());
$match = false;
foreach ($entities as $entityFor) {
if ($entityFor->getUid() == $entity->getUid()) {
$match = true;
continue;
}
if ($match == true) {
return $entityFor;
}
}
}
private function getTwoBefore($entity)
{
$entityTwoBefore = null;
$entityBefore = $this->getBefore($entity);
if ($entityBefore != null) {
$entityTwoBefore = $this->getBefore($entityBefore);
}
return $entityTwoBefore;
}
/**
* Return the current tablename
*
* @return string
*/
private function getTableName($entity) {
/** @var DataMapper $dataMapper */
$dataMapper = \TYPO3\CMS\Core\Utility\GeneralUtility::makeInstance('TYPO3\\CMS\\Extbase\\Persistence\\Generic\\Mapper\\DataMapper');
return $dataMapper->getDataMap(get_class($entity))->getTableName();
}
}
Если Repository расширяет SortedRepository вы можете использовать методы MoveUp() и moveDown().
Примечание: Для таблицы DB необходимо указать поле «сортировка». Вам это нужно в файле ext_tables.sql и в TCA класса модели:
ext_tables.sql:
#
# Table structure for table 'tx_extension_domain_model_subcategory'
#
CREATE TABLE tx_extension_domain_model_subcategory (
uid int(11) NOT NULL auto_increment,
pid int(11) DEFAULT '0' NOT NULL,
name varchar(255) DEFAULT '' NOT NULL,
tstamp int(11) unsigned DEFAULT '0' NOT NULL,
crdate int(11) unsigned DEFAULT '0' NOT NULL,
cruser_id int(11) unsigned DEFAULT '0' NOT NULL,
deleted tinyint(4) unsigned DEFAULT '0' NOT NULL,
hidden tinyint(4) unsigned DEFAULT '0' NOT NULL,
starttime int(11) unsigned DEFAULT '0' NOT NULL,
endtime int(11) unsigned DEFAULT '0' NOT NULL,
t3ver_oid int(11) DEFAULT '0' NOT NULL,
t3ver_id int(11) DEFAULT '0' NOT NULL,
t3ver_wsid int(11) DEFAULT '0' NOT NULL,
t3ver_label varchar(255) DEFAULT '' NOT NULL,
t3ver_state tinyint(4) DEFAULT '0' NOT NULL,
t3ver_stage int(11) DEFAULT '0' NOT NULL,
t3ver_count int(11) DEFAULT '0' NOT NULL,
t3ver_tstamp int(11) DEFAULT '0' NOT NULL,
t3ver_move_id int(11) DEFAULT '0' NOT NULL,
sorting int(11) DEFAULT '0' NOT NULL,
sys_language_uid int(11) DEFAULT '0' NOT NULL,
l10n_parent int(11) DEFAULT '0' NOT NULL,
l10n_diffsource mediumblob,
PRIMARY KEY (uid),
KEY parent (pid),
KEY t3ver_oid (t3ver_oid,t3ver_wsid),
KEY language (l10n_parent,sys_language_uid)
);
И в TCA модели:
<?php
return array(
'ctrl' => array(
'title' => 'LLL:EXT:pdvdownloadportal/Resources/Private/Language/locallang_db.xlf:tx_pdvdownloadportal_domain_model_subcategory',
'label' => 'name',
'tstamp' => 'tstamp',
'crdate' => 'crdate',
'cruser_id' => 'cruser_id',
'dividers2tabs' => TRUE,
'versioningWS' => 2,
'versioning_followPages' => TRUE,
'sortby' => 'sorting',
...
очень интересен только вы установили, что ваша сортировка зафиксирована на 8 ... Мне бы хотелось знать, как использовать некоторую собственную сортировку (drag'n drop or arrows) в представлении списка, чтобы сортировать мои объекты и заполнять сортировку поля таблицы, возможно, у вас есть ключ. .. – webMan