SQL Tips & Tricks

It is strongly advised that these statements should only be executed with the necessary expertise.
The information provided here was tested at the time of publication of this article - it may have changed in the meantime. The execution of this tutorial is at your own risk

Before you start, make a backup so that you can restore it if you run into trouble. Please note that these are adjustments of shopware and therefore the content of this tutorial is not officially supported!

Catalogues

Delete all products

With the following query you can delete all created products and empty the product overview completely:

DELETE FROM product;

Delete all properties

With the following query you can remove all properties:

DELETE FROM property_group;

Delete all customer data

You can apply the following SQL queries before you go live with your store. However, make sure that you never use them in your live store. Orders with receipts or receipts should never be deleted.

With the following query you can remove all customer data:

DELETE FROM customer;

Delete all orders

You can apply the following SQL queries before you go live with your store. However, make sure that you never use them in your live store. Orders with receipts or receipts should never be deleted.

With the following query you can delete all orders.

TRUNCATE `order`;
TRUNCATE `order_address`;
TRUNCATE `order_customer`;
TRUNCATE `order_delivery`;
TRUNCATE `order_delivery_position`;
TRUNCATE `order_line_item`;
TRUNCATE `order_tag`;
TRUNCATE `order_transaction`;

Enable inheritance for all variants

After a migration, inheritance is disabled in all variant products. To enable inheritance, only the respective property must have NULL as a value in the database.

With the following query all properties and additionally also the inheritance for the properties are activated:

UPDATE product SET 
    active = NULL,
    tax_id = NULL,
    product_manufacturer_id = NULL, 
    delivery_time_id = NULL,
    deliveryTime = NULL, 
    product_media_id = NULL,
    manufacturer_number = NULL, 
    ean = NULL,
    restock_time = NULL,
    is_closeout = NULL,
    purchase_steps = NULL, 
    max_purchase = NULL, 
    min_purchase = NULL, 
    purchase_unit = NULL,
    reference_unit = NULL, 
    shipping_free = NULL,
    mark_as_topseller = NULL,
    weight = NULL, 
    width = NULL, 
    height = NULL, 
    length = NULL,
    release_date = NULL,
    tag_ids = NULL,
    tags = NULL
WHERE parent_id IS NOT NULL;

DELETE FROM product_translation WHERE product_id IN (SELECT id FROM product WHERE parent_id IS NOT NULL);
DELETE FROM product_tag WHERE product_id IN (SELECT id FROM product WHERE parent_id IS NOT NULL);
DELETE FROM product_media WHERE product_id IN (SELECT id FROM product WHERE parent_id IS NOT NULL);
DELETE FROM product_visibility WHERE product_id IN (SELECT id FROM product WHERE parent_id IS NOT NULL);
DELETE FROM product_property WHERE product_id IN (SELECT id FROM product WHERE parent_id IS NOT NULL);


System / Settings

Disable non-standard extensions

With the following queries you can deactivate the extensions that are not already present when installing Shopware. This is especially useful for debugging errors, as you can quickly eliminate the influence of extensions.

If you use your own theme that is integrated via a plug-in, you should make sure in advance that the theme is not assigned to a sales channel. Alternatively, you may encounter problems when calling the appropriate sales channels.

First we create a temporary backup table. The current status of the extensions is saved in this table.

CREATE TABLE plugin_tmp LIKE plugin;
INSERT INTO `plugin_tmp` SELECT * FROM `plugin`;

From version 6.5, extensions and Themes are also entered as an app and must therefore be deactivated separately. A temporary backup of the app table should therefore also be created.

CREATE TABLE app_tmp LIKE app;
INSERT INTO `app_tmp` SELECT * FROM `app`;

Then you can deactivate the extensions

UPDATE `plugin` SET `active`= 0 WHERE (author <> 'shopware AG' AND author <> 'Shopware') OR (author IS NULL);

You can deactivate the apps using the following command

UPDATE `app` SET `active` = 0;

The original state of the extensions can be restored later as follows

UPDATE plugin AS p JOIN plugin_tmp AS pt ON p.id = pt.id SET p.active = pt.active;

To restore the apps to their original state, use the following command

UPDATE app AS a JOIN app_tmp AS at ON a.id = at.id SET a.active = at.active;

Finally, you can delete the temporary backup tables

DROP TABLE plugin_tmp;
DROP TABLE app_tmp;

Customise database collation

By default Showpare uses "utf8mb4_unicode_ci" as collation for the tables.
However, it can happen that the collation for individual tables is not (no longer) set correctly.

This can cause errors when comparing strings of incompatible collations or when trying to select data from columns with different collations.
In the log files this can be recognised by the following entry (possibly slightly modified):

SQLSTATE[HY000]: General error: 1267 Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8_general_ci,COERCIBLE)

With the following query you can check if a wrong collation is used in a table.
To do this, insert the table and database name into the query at the marked positions.

SELECT table_schema, table_name, column_name, character_set_name, collation_name
 FROM information_schema.columns
 WHERE (collation_name = 'utf8mb4_unicode_ci' or collation_name = 'utf8_general_ci ') 
 and table_name = '' --Tabellenname einsetzen 
 and table_schema = '' --Datenbanknamen einsetzen
 ORDER BY table_schema, table_name,ordinal_position;

You can update the collation with one of the following two queries.

We recommend that you always make a full backup before making changes to the database.

Update of the entire database

ALTER DATABASE --Datenbanknamen einsetzen CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci

Update a single table

ALTER TABLE --Tabellenname einsetzen CONVERT TO CHARACTER SET utf8mb4 COLLATE 'utf8mb4_unicode_ci';

Restore default customer group

This restores the "default customer group" without a translation. The translations must be maintained manually in the admin.

Query to restore the default customer group:
 

INSERT INTO `customer_group` (`id`, `display_gross`, `registration_active`, `created_at`, `updated_at`) VALUES
(UNHEX('CFBD5018D38D41D8ADCA10D94FC8BDD6'), 1, 0, '2021-01-01 00:00:00.00', NULL);

Was this article helpful?