steampipe plugin install shopify

Table: shopify_order - Query Shopify Orders using SQL

Shopify is a widely-used, e-commerce platform that allows businesses to set up an online store and sell their products. It provides an array of features such as product inventory management, order management, and customer relationship management. An Order in Shopify is a record of a sale made through your store, it contains information about the products, customer details, and shipping.

Table Usage Guide

The shopify_order table provides insights into orders made within a Shopify store. As a store manager or a business analyst, explore order-specific details through this table, including customer information, product details, and shipping details. Utilize it to analyze sales performance, understand customer purchasing habits, and manage inventory effectively.

Examples

Basic info

Discover the segments that include customer details and their associated shipping and billing addresses. This can help to gain insights into customer location data for potential marketing strategies or logistical planning.

select
id,
name,
email,
customer,
billing_address,
shipping_address
from
shopify_order;
select
id,
name,
email,
customer,
billing_address,
shipping_address
from
shopify_order;

List all fulfilled orders shipped to a specific postal code

Discover the segments that have successfully completed orders delivered to a specific area. This can be useful in understanding customer distribution and analyzing sales performance in targeted locations.

select
id,
name,
email,
shipping_address ->> 'zip' as zip_code,
fulfillment_status
from
shopify_order
where
fulfillment_status = 'fulfilled'
and shipping_address ->> 'zip' = '712136';
select
id,
name,
email,
json_extract(shipping_address, '$.zip') as zip_code,
fulfillment_status
from
shopify_order
where
fulfillment_status = 'fulfilled'
and json_extract(shipping_address, '$.zip') = '712136';

List the total price of each order where at least one item has a price greater than $100

Assess the total costs of orders containing items priced over $100 to gain insights into high-value transactions. This can aid in identifying potential revenue streams and understanding customer purchasing habits.

select
id,
name,
email,
total_price
from
shopify_order,
jsonb_array_elements(line_items) as item
where
(item ->> 'price') :: numeric > 100;
select
id,
name,
email,
total_price
from
shopify_order,
json_each(line_items) as item
where
CAST(json_extract(item.value, '$.price') AS REAL) > 100;

List number of items in each order

Analyze the settings to understand the quantity of products in each customer order. This is useful for inventory management and understanding customer purchasing behavior.

select
id,
name,
email,
jsonb_array_length(line_items) as number_of_items
from
shopify_order;
select
id,
name,
email,
json_array_length(line_items) as number_of_items
from
shopify_order;

List all orders where the customer's email belong to the domain "gmail.com"

Explore which orders were made by customers using a Gmail account. This is useful for understanding customer demographics and tailoring marketing efforts towards specific email service users.

select
id,
name,
email,
(
(customer ->> 'first_name') || ' ' || (customer ->> 'last_name')
) as customer_name
from
shopify_order
where
customer ->> 'email' like '%@gmail.com';
select
id,
name,
email,
(
json_extract(customer, '$.first_name') || ' ' || json_extract(customer, '$.last_name')
) as customer_name
from
shopify_order
where
json_extract(customer, '$.email') like '%@gmail.com';

List the orders cancelled within last 30 days

Discover the instances of order cancellations in the past month. This helps in analyzing the reasons for cancellation and aids in making informed decisions to reduce such instances in the future.

select
id,
name,
email,
cancel_reason,
cancelled_at
from
shopify_order
where
cancelled_at >= now() - interval '30' day
order by
cancelled_at;
select
id,
name,
email,
cancel_reason,
cancelled_at
from
shopify_order
where
cancelled_at >= datetime('now', '-30 day')
order by
cancelled_at;

List pending or partially paid orders

Determine the status of your online store's orders to identify those that are pending or partially paid. This could be useful for tracking incomplete transactions and improving your revenue collection process.

select
id,
name,
email,
financial_status
from
shopify_order
where
financial_status in ('pending', 'partially_paid');
select
id,
name,
email,
financial_status
from
shopify_order
where
financial_status in ('pending', 'partially_paid');

Get the order details of refunded orders

Explore which orders have been refunded, including the status of each refund and the total amount refunded. This can be useful for gaining insights into refund patterns and tracking customer satisfaction.

select
id,
name,
email,
jsonb_array_elements(refund -> 'transactions') ->> 'status' as refund_status,
jsonb_array_elements(refund -> 'transactions') ->> 'amount' as refund_amount,
coalesce(
jsonb_array_length(refund -> 'refund_line_items'),
0
) as number_of_products_refunded
from
shopify_order,
jsonb_array_elements(refunds) as refund;
select
shop.id,
shop.name,
shop.email,
json_extract(ref.value, '$.status') as refund_status,
json_extract(ref.value, '$.amount') as refund_amount,
coalesce(
json_array_length(json_extract(shop.refunds, '$.refund_line_items')),
0
) as number_of_products_refunded
from
shopify_order shop,
json_each(shop.refunds) as ref;

Get the orders processed on a particular date

Discover the segments that had their orders processed on a specific date. This is useful for tracking business performance and customer activity on a day-to-day basis.

select
id,
name,
email,
cancel_reason,
processed_at
from
shopify_order
where
processed_at :: date = '2023-04-25';
select
id,
name,
email,
cancel_reason,
processed_at
from
shopify_order
where
date(processed_at) = '2023-04-25';

List the orders which are fulfilled but receipts are not send

Identify instances where orders have been fulfilled but the corresponding receipts have not been sent. This is useful for ensuring all customers receive their receipts and for maintaining accurate records.

select
id,
name,
email,
fulfillment_status,
send_fulfillment_receipt
from
shopify_order
where
fulfillment_status = 'fulfilled'
and not send_fulfillment_receipt;
select
id,
name,
email,
fulfillment_status,
send_fulfillment_receipt
from
shopify_order
where
fulfillment_status = 'fulfilled'
and not send_fulfillment_receipt;

Count number of orders paid manually

Explore the volume of orders that have been manually paid for. This can help in identifying the extent of manual interventions in the payment process and potentially streamline operations.

select
count(*) as orders_paid_manually
from
shopify_order
where
gateway = 'manual';
select
count(*) as orders_paid_manually
from
shopify_order
where
gateway = 'manual';

Get the tax details of the products ordered

Determine the tax details associated with each product order to understand the different tax types and rates applied. This can help in analyzing the tax structure for various products, facilitating better financial planning and management.

select
id as order_id,
name as order_name,
email,
item ->> 'product_id' as product_id,
item ->> 'price' as product_price,
jsonb_array_elements(item -> 'tax_lines') ->> 'rate' as tax_rate,
jsonb_array_elements(item -> 'tax_lines') ->> 'title' as tax_type,
jsonb_array_elements(item -> 'tax_lines') ->> 'price' as tax_price
from
shopify_order,
jsonb_array_elements(line_items) as item;
select
id as order_id,
name as order_name,
email,
json_extract(item.value, '$.product_id') as product_id,
json_extract(item.value, '$.price') as product_price,
json_extract(tax.value, '$.rate') as tax_rate,
json_extract(tax.value, '$.title') as tax_type,
json_extract(tax.value, '$.price') as tax_price
from
shopify_order,
json_each(line_items) as item,
json_each(json_extract(item.value, '$.tax_lines')) as tax;

List the orders with discounts

Discover the segments that have been granted discounts on their orders. This is useful for analyzing the effectiveness of discount strategies and identifying popular discount trends among customers.

select
id,
name,
email,
total_discounts
from
shopify_order
where
total_discounts > 0;
select
id,
name,
email,
total_discounts
from
shopify_order
where
total_discounts > 0;

Get the most ordered product of the last month

Determine the most popular product sold in the last month to identify customer preferences and guide inventory decisions. This query is useful for businesses seeking to optimize their product offering based on recent sales trends.

select
p.id,
p.title,
p.product_type,
p.created_at,
p.vendor,
q.c as sales_count
from
shopify_product as p
join (
select
item ->> 'product_id' as id,
count(*) as c,
min(created_at) AS order_date
from
shopify_order,
jsonb_array_elements(line_items) as item
where
created_at >= (CURRENT_DATE - interval '30' day)
group by
item ->> 'product_id'
order by
c desc,
order_date
limit
1
) as q on p.id = q.id :: bigint;
select
p.id,
p.title,
p.product_type,
p.created_at,
p.vendor,
q.c as sales_count
from
shopify_product as p
join (
select
json_extract(item.value, '$.product_id') as id,
count(*) as c,
min(created_at) AS order_date
from
shopify_order,
json_each(line_items) as item
where
created_at >= date('now', '-30 day')
group by
json_extract(item.value, '$.product_id')
order by
c desc,
order_date
limit
1
) as q on p.id = q.id;

Schema for shopify_order

NameTypeOperatorsDescription
_ctxjsonbSteampipe context in JSON form.
app_idbigintThe ID of the app that created the order.
billing_addressjsonbThe billing address of the customer who placed the order.
browser_iptextThe browser ip of the order.
buyer_accepts_marketingbooleanWhether the buyer accepts email marketing or not.
cancel_reasontextThe reason for the order cancellation.
cancelled_attimestamp with time zoneThe time when the order was cancelled.
cart_tokentextThe cart token of the order.
checkout_idbigintThe ID of the checkout associated with the order.
checkout_tokentextThe token for the checkout process.
client_detailsjsonbThe details of the client who placed the order.
closed_attimestamp with time zoneThe time when the order was closed.
confirmedbooleanWhether the order has been confirmed.
contact_emailtextThe email address associated with the order.
created_attimestamp with time zoneThe time when the order was placed.
currencytextThe currency used for a particular order.
current_total_pricedouble precisionThe current total price of the order.
customerjsonbThe details of the customer who placed the order.
customer_localetextThe locale associated with the customer.
device_idbigintThe ID of the device used to place the order.
discount_codesjsonbAny discount codes applied to the order.
emailtextEmail id of the customer who placed the order.
financial_statustextThe financial status of the order.
fulfillment_statustextThe fulfillment status of the order.
fulfillmentsjsonbThe fulfillments of the order.
gatewaytextThe payment gateway used for the orders.
idbigint=The order ID.
landing_sitetextThe landing site of the order.
landing_site_reftextThe reference number for the landing site of the order.
line_itemsjsonbThe line items of the order.
location_idbigintThe location id of the order.
nametextThe order name.
notetextThe order note.
note_attributesjsonbAny notes associated with the order.
numberbigintThe number of orders.
order_numberbigintThe order number.
order_status_urltextThe URL to check the status of the order.
payment_gateway_namesjsonbThe payment gateway names associated with the order.
phonetextThe phone number associated with the order.
processed_attimestamp with time zoneThe time when the order was processed.
processing_methodtextThe processing method used for the order.
referencetextThe reference number for the order.
referring_sitetextThe referring site of the order.
refundsjsonbThe refunds associated with the order.
send_fulfillment_receiptbooleanWhether or not a fulfillment receipt was sent for the order.
send_receiptbooleanWhether or not a receipt was sent for the order.
shipping_addressjsonbThe shipping address of the customer who placed the order.
shipping_linesjsonbThe shipping lines of the order.
shop_nametext=, !=, ~~, ~~*, !~~, !~~*The name of the shop.
source_identifiertextThe source identifier of the order.
source_nametextThe source name of the order.
source_urltextThe source URL of the order.
sp_connection_nametext=, !=, ~~, ~~*, !~~, !~~*Steampipe connection name.
sp_ctxjsonbSteampipe context in JSON form.
subtotal_pricedouble precisionThe subtotal price of the order.
tagstextThe order tags.
tax_linesjsonbThe tax lines in the order.
taxes_includedbooleanThe taxes are included in the order or not.
testtextThe test of the order.
titletextTitle of the resource.
tokentextThe order token.
total_discountsdouble precisionThe total discounts on the order.
total_line_items_pricedouble precisionThe total line items price on the order.
total_pricedouble precisionThe total price of the order.
total_price_usdjsonbThe total price of the order in USD.
total_taxdouble precisionThe total tax in the order.
total_weightbigintThe total weight of the order placed.
transactionsjsonbThe transactions in the order.
updated_attimestamp with time zoneThe time when the order was updated.
user_idbigintThe user id of the users who placed the order.

Export

This table is available as a standalone Exporter CLI. Steampipe exporters are stand-alone binaries that allow you to extract data using Steampipe plugins without a database.

You can download the tarball for your platform from the Releases page, but it is simplest to install them with the steampipe_export_installer.sh script:

/bin/sh -c "$(curl -fsSL https://steampipe.io/install/export.sh)" -- shopify

You can pass the configuration to the command with the --config argument:

steampipe_export_shopify --config '<your_config>' shopify_order