Economic And Financial Data Sources PDF
Document Details
Uploaded by WiseZeal
UCM
Tags
Summary
This document provides an overview of different data sources related to economics and finance. Focusing mostly on Spanish data sets, and details many database tools and solutions like PowerBI.
Full Transcript
# Economic And Financial Data Sources There are multiple and relevant data sources in the Economic and Financial Space that a person can use and incorporate into their analysis and databases. ## Type Of Data Analysis All these data sources allow in general to do: - **Descriptive analysis**: to s...
# Economic And Financial Data Sources There are multiple and relevant data sources in the Economic and Financial Space that a person can use and incorporate into their analysis and databases. ## Type Of Data Analysis All these data sources allow in general to do: - **Descriptive analysis**: to summarize and describe a dataset. (Unemployment this month in Spain by Age range) - **Trend analysis during time**: to analyze how the data changed with time. (How unemployment has changed during the last year by month in Spain) - **Comparative analysis**: between regions, groups of people or between different variables. (How unemployment has changed during the last year by month in Spain in the different communities) ## INE INE offers a wide range of statistical data on various economic, demographic and social aspects of the country. It regularly updates its data and provides access through its website, where you can download reports, databases and use interactive tools to analyze the information. - Demography and population (census, births, deaths) - Economy (GDP, Consumer Price Index, Surveys) - Labor market (survey data to active population) - Companies and establishments (Central Directory of Companies, Industrial Survey of Companies, Survey on Innovation in Companies, Statistics on Commercial Companies) - Society (Education Statistics, Health Survey, Living Conditions Survey, Labor and Geographical Mobility Statistics) ## Ministry Of Economy, Trade And Enterprise Provides a wide range of financial data and statistics: - Macroeconomic data on (the evolution of the Spanish economy, on economic growth) - Public finances (Data on budget execution, statistics on deficit and public debt) - Labor market (labor market statistics, employment, unemployment, job offerings) - Financial system (information on the situation and evolution of the Spanish financial system; banks and other financial institutions) - Foreign trade (data on exports, imports and trade balance) ## Spanish Government - Madrid Stock Market - Spanish Bank (interest rate Statistics) ## Eurostat High quality statistics and data on Europe ## World Bank Free and open access to global development data ## International Monetary Fund Access to macroeconomic and financial data ## PowerBI as a Database Tool PowerBI has 2 different solutions: ### PowerBI Desktop - Installed in the computer. *It’s license free for your personal use* - For creating reports and dashboards - It has another solution embedded which is PowerQuery used to clean and transform data from multiple sources (Excel, SQL) - It allows to create relationships between tables (similar to relational databases) - It allows to visualize data with interactive dashboards - The audience is Developers and Designers ### PowerBI Service - Cloud-based platform for sharing and collaborating on Power BI reports - Offers real-time data updates and sharing with team members - It offers less functionalities than PowerBI Desktop as the audience is for business users to visualize or collaborate in reports created by developers in PowerBI Desktop ## Comparison With Traditional Sql Databases - PowerBI focuses on analysis and visualization rather than data storage - Use it to explore and connect data from databases, not as a primary storage tool ## Using AI in PowerApps To Create Databases And Apps: - Power Apps is a low-code platform to create custom applications connected to databases (like SQL or Excel) - Allows for drag-and-drop interface creation - AI tools (Copilot) can assist in quickly generating tables, forms and business logic - AI enhances productivity and accessibility for non-technical users ## Steps To Build An App In 10 Minutes: 1. Generate data: use AI to define the structure of a database (customers, rentals) 2. Create an interface: auto-generate forms and screens based on the database 3. Integrate logic: add AI-driven functionality (automated responses or workflows) ## Introduction To Databases Understanding about Databases is essential since they are under every aspect of today’s digital world facilitating efficient data management across the different industries: - E-commerce Platforms - Social Media Networks - Banking and Financial Services - Healthcare Systems - Educational Institutions - Logistics and Supply Chain Management - Customer Relationship Management (CRM) - Government Services ## Before DB Different ways to store and manage information: - Paper - Magnetic Tapes - Books and Accounting Records - Electronic Files and Directories These methods had limitations: - Difficulty in searching and retrieving - Lack of integrity and security - Inability to handle large volumes of data ## Evolution Of DB ### 1970s: ER Model - **Introduction of the Entity-Relationship model** as a standard tool for database design - **Oracle introduces the first RDBMS** ### 1980s: DBMS / SQL - **IBM creates SQL** and it becomes the standard language - More companies creating RDBMS like Sybase introducing the early Microsoft SQL Server. ### 1990s: NoSQL / Data mining - **NoSQL Databases starting to manage not structured data** (images, text, audios – other type of information) - **Data Warehousing** (DataLake: place where there are many databases to analyze data from different databases) and **Data mining** (data analytics – analysis of data) appear. ### 2000s: Big Data / Cloud - Open source databases (free version – MySQL, Postgree, Neo4j) - Database products for large volumes - DataLake concepts - Databases in the cloud and serverless solutions ## Basic Concepts Of Databases - **Database**: collection of interrelated data that is organized and stored in such a way that it can be easily accessed, managed and updated. It consists of tables, each containing rows and columns where data is stored and related to other tables through relationships. Databases can store information about people, products, orders or other things. - **Database Management System (DBMS)**: software designed to manage databases, providing functionalities to define, create, query (search & select), update and administer databases. It acts as an interface between users and the database, ensuring efficient storage, retrieval and manipulation of data while maintaining data integrity and security. Oracle Database, Microsoft SQL Server, MySQL. *It helps you organize the different tables included in the database.* - **DBM Tools and Software**: applications that help users create, manage and manipulate databases. They provide an interface to interact with the data and perform various operations like querying, updating and reporting. - Storage: large volumes in structured format - Retrieval: querying capabilities using languages like SQL - Manipulation: insert, update and delete - Integrity: accuracy and consistency through constraints, validation rules and transactions - Security: protecting data with user authentication - Back up and recovery: offering tools for data backup and recovery - Performance optimization: including features like indexing (creating a number for a field that is a text), caching (already stored in the devide), query optimization for better performance (doing it quicker) ## The 3 Architecture Levels In DB One of the main purposes of DBMS is to provide users with a simplified view of the data, hiding the complexities of how the data is stored and managed. 1. **Conceptual Design**: defining the main entities and relationships in a way that is technology-agnostic. Highest level of abstraction. 2. **Logical Level**: detailed but still abstract, specifying tables, columns and relationships, ready to be mapped to a specific DBMS. 3. **Physical Level**: describes how data is really stored. Is the lower level. - NN: not null - ese campo no puede estar vacío - PK: primary key – único, que no se puede repetir - FK: foreign key – conectar dos tablas (poner solamente el PK de una tabla en la que está el resto de la información para no repetirla entera) | Level of Abstraction | Level of Detail | Purpose | Audience | Example | |---|---|---|---|---| | Highest - Provides a high level view of the data | Defining the overall structure of the database without getting into details on how it will be implemented. | To capture the main entities and relationships in a way that is independent of any specific DBMS or technology. Typically for business stakeholders and database designers to agree on the overall structure and requirements. Example: Defining entities like "Student," "Course," and "Professor," and the relationships between them, such as "enrollment" and "teaching." | | | | More detailed than the conceptual model but still independent of physical implementation. | On defining the logical structure of the data, including tables, columns, data types, and relationships. | To provide a detailed blueprint that can be used to implement the database in a specific DBMS. For database designers and developers to plan how the database will be structured. | | | | Focuses on the actual implementation details of how data will be stored and accessed. | On the physical storage structures, indexing, partitioning, and performance optimization. | To optimize storage and access for the specific requirements and constraints of the chosen DBMS. For database administrators and developers who are implementing and tuning the database. | | | ## DB Are Important In The Economic And Financial Analysis Because - Provide a structured way to store data related to markets, transactions, financial records - Organizing the data into easily accessible formats for data analysis, reporting, prediction - Facilitating informed decision making, identifying trends and performing accurate forecasting - Maintaining accuracy and confidentiality of sensitive financial information ## Big Data "Data is absolutely key to everything we are doing. It is needed in all areas and fuels the insights that help us make better decisions in all aspects of the business”. – Kathleen Hogan (Chief People Officer at Microsoft). ### Big Data: #### Global Volume Of Data: - In 2025, it’s estimated that the world will generate 175 zettabytes (ZB) of data. * 1 ZB = 1 billion gigabytes - In 2010 it was just 2. - Every day Internet users generate around 2.500.000 GB daily - 90% of the data were generated in the last 2 years. #### The 5 Vs Of Big Data: 1. **VELOCITY**: batch, near time, real time, streams 2. **VARIETY**: structured, unstructured, semistructured, all the above 3. **VOLUME**: terabytes, records, transactions, tables, files 4. **VERACITY**: trustworthiness, authenticity, origin, reputation, accountability 5. **VALUE**: statistical, events, correlations, hypothetical ## Sources Of Data Main sources are: - Facebook - Twits (500.000 tweets per minute) - Instagram (347.222 posts per minute) - IoT (75 mil millions of connected devices generating data) - sensors ## Storage Of Generated Data Less than 20% of global data is stored in Relational Databases. Is a small percentage but important to handle Banks databases, hospitals, customers... 80% of the global data is not structured (text, images, video). This data is stored in Big Data Architectures, in the Cloud and in NoSQL Databases. ## Big Data Storage Different technologies are needed to store, process and analyze such volume of data that cannot be managed with traditional databases. ### Storage In HDFS (Hadoop Distributed File System): - This type of set up is prepared to handle large volumes of data across multiple servers. - It divides data into small blocks (typically 128 MB or 256 MB) and distributes them across different nodes (servers) - It provides high redundancy (copies of data) to ensure that data is not lost if a node fails - Ideal for storing large amounts of unstructured or semi-structured data ### Datalakes: - Centralized repository that stores flat files of all types of data (structured, semi-structured and unstructured). It is stored as raw data, as the data is generated, with no transformation. It is used when you need to store large volumes of diverse and raw data for long-term analysis or if you don't know what type of analysis you will perform later. ### NoSQL | Storage Type | Advantages | When to use it | |---|---|---| | HDFS | High redundancy, efficient for large, distributed data. | Storing large volumes of unstructured data. | | Data Lake | Flexibility to store all types of raw data. | When you’re unsure about what analysis will be done later. | | NoSQL | Flexible, fast, and good for unstructured data. | Constantly changing data, such as logs, social media, IoT. | | Relational (SQL) | High consistency, good for transactions. | Well-structured data requiring integrity. | ## NoSQL Databases ### Intro To NoSQL Databases: NoSQL (non-relational databases): designed to store, retrieve and manage non-tabular data. - Schema-less or flexible schema - Horizontally scalable - Handle a variety of data types: structured, semi-structured (JSON) and unstructured (text, images, logs) ### When Are They Used: - When scalability is necessary: easily handle large volumes of data with horizontal scaling - When flexibility is needed: dynamic schema design allows for quick iterations and changes - When performance is important: optimized for specific data models and access patterns - In Big Data and Real-Time Applications: suited for handling big data and real-time analytics ### Types Of Non-Relational Databases: - **Document Stores**: used for content management systems (store all the documents in a website) → MongoDB - Documents within the same collection can have different fields or structures. The database doesn’t enforce a strict schema, giving developers the flexibility to store varied data formats within a single collection. - Useful when you are storing products that can have different attributes depending on the category. - Use case: A news website uses MongoDB to store articles. Each article is a document containing fields like title, body, author, tags, and publication date. - MongoDB’s flexible schema allows for easy addition of new fields (e.g., multimedia content) without altering existing documents. The site can handle millions of readers by distributing the load across multiple servers. - Ex: ``` { "carlD": 101, "brand": "Toyota", "model": "Corolla", "year": 2020 } { "carID": 102, "color": "Blue", "model": "Ibiza", "year": 2019 } ``` - **Key-Value Stores**: used for caching mechanisms, session management and real-time bidding → Redis, DynamoDB - Use Case: An online shopping platform uses Redis to manage user sessions. Each user’s session is stored with a unique session ID as the key, and the session data (e.g., cart contents, authentication tokens) as the value. Redis allows for quick access and updates to session information, ensuring a seamless shopping experience even when the site experiences high traffic during events like Black Friday sales. - **Graph Databases**: it’s a graph database management system, designed to efficiently store, manage and query highly interconnected data. - *Graph data model*: data model that represents data as nodes (entities) connected by relationships (edges). This makes it particularly suitable for scenarios where relationships between data points are important. - It can be used in various domains (social networks, recommendation systems, network and IT operations, fraud detection). Its flexibility comes from its ability to model complex relationships efficiently. - Use case: A social media platform uses Neo4j to manage and analyze its social graph. Users are nodes, and relationships like friendships, messages, and likes are edges. Neo4j allows the platform to efficiently query and analyze these connections to recommend new friends, detect communities, and identify influencers. This setup also helps in detecting fraudulent behavior by analyzing unusual patterns in the connections and interactions. ## Neo4j Products - **Neo4j Database**: it’s the core product, available in both Community and Enterprise editions. This graph database management system allows users to model, store and query highly connected data efficiently. - **Neo4j Aura**: fully managed cloud service for deploying and running Neo4j databases. It provides users with the benefits of Neo4j’s graph database technology without the need to manage infrastructure, offering scalability, security and reliability in the cloud. - **Neo4j Desktop**: desktop application that provides a development environment for Neo4j. It allows developers to create and manage local Neo4j databases, develop applications using Neo4j and explore graph data visually. - **Neo4j Bloom**: graph visualization and exploration tool designed to help users uncover insights from their graph data. It provides an intuitive interface for exploring and querying graph databases using natural language search and interactive visualizations. - **Neo4j Graph Data Science Library**: collection of algorithms and tools specifically designed for analyzing and extracting insights from graph data. It includes algorithms for centrality analysis, community detection and similarity analysis, enabling advanced graph analytics. - **Neo4j AuraDB for Google Cloud**: fully managed graph database service hosted on Google Cloud Platform (GCP). ## Using Microsoft Excel As a Database ### Excel As a Flat-File Database: Excel functions as a flat-file database: - It stores data in a single table or sheet without complex relational structures like SQL databases - Flat-file databases are useful for managing small datasets where complex relationships and constraints aren’t required. - It’s a useful tool for smaller applications or quick analyses - Data Storage in Excel: each worksheet in Excel can represent a “table” with rows as records and columns as fields - Advantages and limitations: while Excel can manage tables and perform simple lookups, it lacks the integrity constraints (like enforcing referential integrity) and scalability of an RDBMS - Appropriate use cases: just used for rapid prototyping, data explorations and small to medium datasets ### Creating And Using Relationships In Excel: Excel’s Data Model allows for the creation of relationships between tables, enabling users to query and analyze data from multiple tables within the same workbook. - **Data Model Basics**: is a built-in feature allowing multiple tables to exist in a single workbook with defined relationships, making it possible to analyze related data. - **Setting up relationships**: allow to establish relationships between tables using fields that serve as foreign keys - **Relationship types**: Excel only supports one-to-one and one-to-many relationships. *Many-to-many relationships require more complex workarounds, like bridge tables.* - **Limitations of relationships in Excel**: Excel doesn’t enforce referential integrity in relationships, making manual attention to data consistency necessary. ## Data Integrity In Excel Data integrity is critical in any database to ensure that the data is accurate, consistent and reliable. Although Excel doesn’t enforce integrity constraints, best practices and certain tools within Excel can help maintain data quality. - **Unique IDs and Data consistency**: be sure to include unique IDs for each record to avoid duplicates and the use of consistent data types within each column to prevent errors. - **Validation rules**: use Excel’s Data Validation feature to restrict data input (enforcing date formats or restricting input to specific lists) - **Error checking tools**: use Conditional Formatting to highlight potential errors (duplicates or blank cells) and Text to Columns to standardize data formats (dates or currency) ## Normalization With Excel Limits Database normalization minimizes redundancy and improves data integrity by organizing data into separate tables. In Excel, basic normalization techniques can still be implemented, helping to make the data cleaner and easier to manage. - **Basic Normal Forms** - 1. 1NF: separating atomic values in different fields - 2. 2NF: separating entities in different tabs (Splitting Data into Tables) and using PK and FK - 3. 3NF: avoiding transitive dependencies - **Relational Table Design**: designing tables around entities and their relationships to minimize redundancy and ensure each piece of information only appears once. ## Excel Functions As Sql Equivalents Excel includes lookup functions like VLOOKUP, INDEX, MATCH and, more recently, which can simulate basic JOIN operations in SQL by pulling data from other tables. - **VLOOKUP (Vertical Lookup)**: it can retrieve data from a specified range based on a matching key. It has limitations needing sorted data or being limited to exact matches. - **INDEX and MATCH Combination**: INDEX and MATCH together offer more flexibility and can retrieve data from left-to-right, unlike VLOOKUP - **Limitations**: Unlike SQL joins, these functions don’t dynamically update as new data is added or existing data is changed; they require careful handling and manual updates if the data structure changes. ## Pivot Table Advanced tool for calculating, summarizing and analyzing data that allows you to see comparisons, patterns and trends in them in a simple way. ## Relational Databases Type of database that stores and provides access to data points that are related to one another. Data is organized in tables, which consist of rows and columns. Each table represents a specific entity and contains records (rows) that are composed of fields (columns). - **Table**: the fundamental structure to store data in a relational database. Each table has a unique name and contains rows (records) and columns (fields). Columns define the attributes, and rows contain the data instances. - **Relationships**: they are essential in a relational database for linking tables to enable complex queries and to ensure data integrity. Relationships are established through keys: - **PRIMARY KEYS**: column/set of columns in a table that uniquely identifies each row in that table. - **FOREIGN KEYS**: column/set of columns in one table that uniquely identifies a row of another table. It establishes a link between the data in the 2 tables. ## Why Relationships Matter? - **Data integrity**: ensures consistency and accuracy of the data. Foreign key constraints prevent invalid data from being inserted. - EX: preventing an order from referencing a non-existent customer. - **Efficient data retrieval**: allows complex queries to retrieve related data across multiple tables. - EX: joining Customers and Orders tables to find out which customer placed which order. - **Reduced data redundancy**: eliminates the need to duplicate data by storing related data in separate tables. - EX: storing customer details once in the Customers table and referencing it in the Orders table. ## Entity Relationship Diagrams - Conceptual In Relational DB: - **Entity identification**: ER diagrams assist in identifying entities, attributes of these entities and the relationships between entities. - **Relationship definition**: they define the relationships between entities. It’s essential for understanding how different entities interact with each other. It refers to the number of instances of one entity that can be associated with instances of another entity through a relationship. - **ONE TO ONE**: one person has one DNI - **ONE TO MANY**: one school has many students - **MANY TO ONE**: many employees work in one store - **MANY TO MANY**: many employees can enroll in many trainings, and many trainings can have many employees enrolled → use of intermediate table - **Normalization**: it reduces data redundancy and improves data integrity by organizing fields and table of a database. - **Implementation**: ER diagrams guide the creation of tables, specifying primary keys, foreign keys, and other constraints based on the relationships defined in the ER diagram. ## Steps For ER Model Creation: 1. Identify entities 2. Define relationships 3. Determine attributes 4. Choose keys 5. Draw the diagram → use standard ER diagram symbols: - ENTITY: represented by a rectangle - RELATIONSHIP: represented by a diamond - ATTRIBUTE: represented by an oval - PRIMARY KEY: represented by an underlined attribute - FOREIGN KEY: represented by a dashed underline or noted in the entity’s attributes ## Normalization Organize and structure the data in an efficient way to avoid redundancies and to ensure accuracy and data integrity. - Eliminate data redundancy - Use primary and foreign keys - Reduce transitive dependencies - **1ST NORMAL FORM**: each column contains only atomic values (each word/number in a single column) - **2ND NORMAL FORM**: eliminate partial dependencies. All non-key attributes are fully dependent on the primary key. - What is the primary key? Are all non-key attributes depending on the complete primary key? - **3RD NORMAL FORM**: eliminate non-key attributes depending on another non-key attribute. ## Database Design: The process of defining the structure, storage and retrieval mechanisms of data in a database system. It involves creating a detailed blueprint of how data will be stored, accessed and managed in a database. - **Scheme definition**: specifies the tables, fields, data types and relationships in the database - **Normalization**: ensures the database structure minimizes redundancy and optimizes data integrity - **Physical implementation**: determines how the logical schema will be physically stored and accessed in the database management system - **Performance optimization**: includes indexing, partitioning and query optimization to enhance database performance ## Sql And Its Importance ### Sql (Structured Query Language) - It's used for managing and manipulating relational databases. - It provides commands for creating, reading, updating and deleting data in a database. - Most relational database management systems support SQL, making it universal for database interaction. - It’s essential for data analysis allowing users to perform queries to extract meaningful insights from datasets. - It’s designed to handle large volumes of data in an efficient manner - It’s easy to learn and use even with no deep technical knowledge ## Real World Applications: - Business Intelligence: companies use SQL to generate reports and analyze business performance - Finance: banks and financial institutions use SQL for transaction processing and risk management - Healthcare: medical records and patient data management - E-commerce: inventory management, customer data and sales tracking ## Main Data Types | Data Type | Description | Example | |---|---|---| | INT | Whole numbers | 42 | | FLOAT | Floating-point numbers (approximate) | 3.14 | | DOUBLE | Double-precision floating-point | 2.7182818284 59 | | DECIMAL (p,s) | Fixed-point numbers with precision and scale | 123.45 (DECIMAL(5.2)) | | VARCHAR (n) | Variable-length text up to n chars | `'John Doe'` (VARCHAR(100 )) | | CHAR (n) | Fixed-length text of n chars | `'A'` (CHAR (1)) | | TEXT | Large amount of text | `'This is a long text'` | | DATE | Date value (YYYY-MM-DD) | `'2024-07-09'` | | TIME | Time value (HH:MM) | `'14:30:00'` | | DATETIME | Date and time value | `'2024-07-09 14:30:00'` | | TIMESTAMP | Date and time, auto-updated | `'2024-07-09 14:30:00'` | | BLOB | Binary Large Object | `[binary data]` | | BOOLEAN | True/False values | TRUE or FALSE | ## Main Structures ### Creating Tables Table consist of columns (define the type of data) and rows (contain the actual data) Basic syntax of CREATE TABLE: ```sql CREATE TABLE TableName ( Column1 DataType1, Column2 DataType2, ... ); ``` ### Selecting Records Retrieving data from a table Basic syntax of SELECT query: ```sql SELECT column1, column2, ... FROM table1 ``` ## Joining Tables ```sql JOIN table2 ON table1.common_column = table2.common_column WHERE condition; ``` ### Inserting Records Insert data into a table. Basic syntax of INSERT query: ```sql INSERT INTO table name (column1, column2, ...) VALUES (value1, value2, ...); ``` ### Updating Records Updating data into a table. Basic syntax of UPDATE query: ```sql UPDATE table_name SET column1 = value1, column2 = value2, ... WHERE condition; ``` ### Deleting Records Delete data from a table. Basic syntax of DELETE query: ```sql DELETE FROM table name WHERE condition; ``` ### Altering A Table Add columns to a table. Basic syntax of ALTER query: ```sql ALTER TABLE table_name ADD column_name datatype; ``` ### Dropping Table Delete a table entirely. Basic syntax of DROP query: ```sql DROP TABLE table_name; ``` ## Understanding Joins In SQL JOINS are used in SQL to combine rows from 2 or more tables based on a related column between them. ### Types Of Joins: - **Inner join**: it returns only the rows that have matching values in both tables. ```sql SELECT columns FROM table1 INNER JOIN table2 ON table1.common_column=table2.common_column; ``` - **Left Outer Join**: it returns all rows from the left table, and the matched rows from the right table. If no match is found, NULL values are returned for columns from the right table. ```sql SELECT columns FROM table1 LEFT JOIN table2 ON table1.common_column=table2.common_column; ``` - **Right Outer Join**: it returns all rows from the right table, and the matched rows from the left table. If no match is found, NULL values are returned for columns from the left table. ```sql SELECT columns FROM table1 RIGHT JOIN table2 ON table1.common_column=table2.common_column; ``` ## Using Simple Queries For Data Analysis These queries cover basic tasks: - Retrieving data - Performing aggregations - Filtering results - Using simple joins ```sql SELECT column1, column2, ... FROM table_name; SELECT * FROM table_name; SELECT Top X FROM table_name; ``` ## Using Aggregations For Deeper Analysis **AGGREGATIONS**: used for summarizing data, deriving insights and performing calculations on datasets. ```sql SELECT count(*) FROM table_name; SELECT sum,max,avg,min,.... (column) FROM table_name; ``` ## Filtering Conditions ```sql SELECT column1, column2 FROM table_name WHERE condition (); ``` | Filter | Sample / Operator | |---|---| | By Conditions with Numeric | salary > 50000 ; >;= | | By Text Values | department = 'Sales' // NOT department = 'Sales'; | | Using AND/OR | department = 'Sales' AND/OR salary > 50000 | | Using IN | department IN ('Sales', 'Marketing', 'HR'); | | Using BETWEEN | salary BETWEEN 40000 AND 60000; | | Using Like with sequence or individual char | first_name LIKE 'A%'; first_name LIKE 'A_' | | With NULL values | department IS NULL | | Combining conditions | | ## Using Operators Operators: essential tools for manipulating and retrieving data. They enable to perform various operations on the data (arithmetic calculations, comparisons, logical evaluations and combining multiple conditions in a query). - Types: - Arithmetic: +, -, *, / → SELECT carid, daily_rate, dailyrate- 5 AS discounted_rate FROM cars; - Comparison: <, >, =, <>, !=, LIKE → SELECT * FROM cars WHERE dailyrate > 50; - LIKE: used for pattern matching in strings. It’s often used in WHERE clauses to search for a specified pattern in a column. Particularly useful when you need to find records that match a certain pattern rather than an exact match. It’s used with Wildcards like “%” (represents zero, one or multiple characters) and “-” (represents a single character) → SELECT * FROM cars where carmodel like 'Cam%' - Logical operators: AND, OR, NOT → SELECT * FROM rentals WHERE NOT (returndate IS NULL); ## Using String Functions **STRING FUNCTIONS**: essential tools for manipulating and transforming text data. They allow you to perform various operations on strings (concatenation, extraction, formatting and searching for specific patterns). 1. Concat: Select concat (CustomerName,' ', CustomerPhone) as FullContact from Customers 2. Substring: SELECT SUBSTRING (customerphone, 1, 3) AS area_code FROM customers; 3. Length: SELECT LENGTH (carmodel) AS model_length FROM cars; 4. Upper and Lower: SELECT UPPER (carmodel) AS model_length FROM cars; 5. Trim, Ltrim, Rtrim: SELECT TRIM (customer_name) AS name FROM customer; 6. Replace: SELECT replace (customer_name,”S”,”s”) AS name FROM customer; 7. Left and Right: Select right (customer_name,2) from customer; ## Using Subqueries **SUBQUERIES**: queries within another SQL query. They are enclosed in parentheses and can be used in various clauses (SELECT, FROM, WHERE, HAVING). They are powerful tools for breaking down complex queries into simpler parts, making it easier to understand and maintain SQL code. - Subqueries returning 1 row: retrieve the name of the customer who has rented the most expensive car ```sql SELECT CustomerName FROM customers WHERE customerid = (SELECT customerid FROM rentals ORDER BY totalcost DESC LIMIT 1 ); ``` - Subqueries returning multiple row: retrieve the details of cars that have been rented by customers who have rented more than 2 times → ```sql SELECT * FROM cars WHERE carid IN (SELECT carid FROM rentals WHERE customerid IN (SELECT customerid FROM rentals GROUP BY customerid HAVING COUNT(*) > 1) ); ``` - In select → ```sql SELECT customer_name, (SELECT SUM(total_amount) FROM Orders WHERE Orders.customer_id = Customers.customer_id) AS total_spent FROM Customers; ``` - In where → ```sql SELECT first_name, last_name, salary FROM Employees WHERE salary > (SELECT AVG(salary) FROM Employees); ``` - Correlated subquery ```sql SELECT first_name, salary FROM Employees el WHERE salary > (SELECT AVG(salary) FROM Employees e2 WHERE e2.department = e1.department); ``` - With in → ```sql SELECT product_name FROM Products WHERE product_id IN (SELECT product_id FROM Orders); ```