When you first create a table in an SQL database, you must define its overall structure by listing out each column you want the table to hold and what kind of data those tables will store. Then, when you add data to the table, the values you insert must align with the data types you defined for each respective column. By forcing you to enter values that align with the table’s predefined structure, an SQL database can help you ensure that you don’t enter any values incorrectly. However, this rigid structure can make things difficult when you’re trying to compare two values that have different data types or when you’re trying to combine values from multiple columns into a single resulting value.
In this tutorial, you’ll learn how to manipulate data with CAST
functions to change the data type of a value or set of values into another, and use the concatenation expression to string character and numerical data values together. You’ll also practice running the CAST
function and concatenation expression in the same query to result in a complete statement.
To complete this tutorial, you will need:
sudo
administrative privileges and firewall enabled. Follow our Initial Server Setup with Ubuntu 20.04 to get started.Note: Please note that many relational database management systems use their own unique implementations of SQL. Although the commands outlined in this tutorial will work on most RDBMSs, the exact syntax or output may differ if you test them on a system other than MySQL.
To practice using CAST
functions and concatenation expressions in this tutorial, you’ll need a database and table loaded with sample data. If you do not have one ready to insert, you can read the following Connecting to MySQL and Setting up a Sample Database section to learn how to create a database and table. This tutorial will refer to this sample database and table throughout.
If your SQL database runs on a remote server, SSH into your server from your local machine:
- ssh sammy@your_server_ip
Next, open the MySQL prompt, replacing sammy
with your MySQL user account information:
- mysql -u sammy -p
Create a database named castconDB
:
- CREATE DATABASE castconDB;
If the database was created successfully, you’ll receive the following output:
OutputQuery OK, 1 row affected (0.01 sec)
To select the castconDB
database run the following USE
statement:
- USE castconDB;
OutputDatabase changed
After selecting the database, create a table within it. For this tutorial’s example, we’ll create a table that holds the grades for Mr. Frank’s sixth-grade fall semester class. This table will hold the following 15 columns:
student_id
: displays the values of the int
data type and will serve as the table’s primary key, meaning each value in this column will function as a unique identifier for its respective row.first_name
: uses the varchar
data type with a maximum of 20 characters to hold the first names of the students.last_name
: holds the last names of the students with the varchar
data type, again at a maximum of 20 characters.email_address
: uses the varchar
data type with a maximum of 30 characters to store each student’s email.participation_grade
: shows each student’s total participation grade with the int
data type.attendance_grade
: uses the int
data type to display each student’s attendance grades.midterm_deadline
: uses the TIMESTAMP
data type to represent the deadline each student must submit their midterm exams by. This data type combines both date and time in one string and uses the following format: (YYYY-MM-DD HH:MM:SS
).midterm_submitted
: records the exact day and time students submitted their midterm exam with the TIMESTAMP
data type.midterm_grade
: uses the decimal
data type to specify each student’s grade for their midterm exam. This column declaration specifies a precision of four with a scale of one, which means values in this column can have four digits, with one of those digits being to the right of the decimal point.essay_deadline
: displays the time and date students must submit their essays using the TIMESTAMP
data type.essay_submitted
: uses the TIMESTAMP
data type to track when students submitted their essay assignment.essay_grade
: holds each student’s essay grade with the decimal
data type and a precision of four and a scale of one, with the latter being to the right of the decimal point.finalexam_deadline
: stores the deadline information for the final exam using the TIMESTAMP
data type.finalexam_submitted
: uses the TIMESTAMP
data type to record students’ actual time and date submissions for their final exam.finalexam_grade
: contains each student’s grade for their final exam with the decimal
data type that has a precision of four stored digits and a scale of one digit to the right of the decimal point.Create a table named fall_grades
that has each of these columns by running the following CREATE TABLE
command:
- CREATE TABLE fall_grades (
- student_id int,
- first_name varchar(20),
- last_name varchar(20),
- email_address varchar(30),
- participation_grade int,
- attendance_grade int,
- midterm_deadline TIMESTAMP,
- midterm_submitted TIMESTAMP,
- midterm_grade decimal(4,1),
- essay_deadline TIMESTAMP,
- essay_submitted TIMESTAMP,
- essay_grade decimal(4,1),
- finalexam_deadline TIMESTAMP,
- finalexam_submitted TIMESTAMP,
- finalexam_grade decimal(4,1),
- PRIMARY KEY (student_id)
- );
Next insert some sample data into the empty table:
- INSERT INTO fall_grades
- (student_id, first_name, last_name, email_address, participation_grade, attendance_grade, midterm_deadline, midterm_submitted, midterm_grade, essay_deadline, essay_submitted, essay_grade, finalexam_deadline, finalexam_submitted, finalexam_grade)
- VALUES
- (1, 'Arnold', 'Shortman', 'ashortman@ps118.com', 98, 90, '2022-10-16 12:00:00', '2022-10-16 06:30:00', 85.8, '2022-11-20 12:00:00', '2022-11-20 03:00:00', 90.1, '2022-12-11 12:00:00', '2022-12-11 03:00:00', 82.5),
- (2, 'Helga', 'Pataki', 'hpataki@ps118.com', 85, 100, '2022-10-16 12:00:00', '2022-10-16 10:00:00', 88.4, '2022-11-20 12:00:00', '2022-11-21 03:15:00', 72.5, '2022-12-11 12:00:00', '2022-12-11 05:00:00', 90.0),
- (3, 'Gerald', 'Johanssen', 'gjohanssen@ps118.com', 100, 95, '2022-10-16 12:00:00', '2022-10-16 02:00:00', 94.2, '2022-11-20 12:00:00', '2022-11-20 02:45:00', 95.8, '2022-12-11 12:00:00', '2022-12-11 11:00:00', 88.1),
- (4, 'Phoebe', 'Heyerdahl', 'pheyerdahl@ps118.com', 100, 100, '2022-10-16 12:00:00', '2022-10-16 11:00:00', 98.8, '2022-11-20 12:00:00', '2022-11-20 11:15:00', 90.4, '2022-12-11 12:00:00', '2022-12-11 11:40:00', 100.0),
- (5, 'Harold', 'Berman', 'hberman@ps118.com', 100, 75, '2022-10-16 12:00:00', '2022-10-16 08:00:00', 75.7, '2022-11-20 12:00:00', '2022-11-22 09:15:00', 67.5, '2022-12-11 12:00:00', '2022-12-11 09:15:00', 90.9),
- (6, 'Eugene', 'Horowitz', 'ehorowitz@ps118.com', 100, 100, '2022-10-16 12:00:00', '2022-10-16 01:00:00', 100.0, '2022-11-20 12:00:00', '2022-11-20 01:22:00', 89.9, '2022-12-11 12:00:00', '2022-12-11 07:55:00', 98.2),
- (7, 'Rhonda', 'Lloyd', 'rlloyd@ps118.com', 100, 80, '2022-10-16 12:00:00', '2022-10-16 06:00:00', 90.4, '2022-11-20 12:00:00', '2022-11-20 06:09:00',81.3, '2022-12-11 12:00:00', '2022-12-11 06:45:00', 95.5),
- (8, 'Stinky', 'Peterson', 'speterson@ps118.com', 100, 85, '2022-10-16 12:00:00', '2022-10-16 03:00:00', 70.6, '2022-11-20 12:00:00', '2022-11-20 05:55:00', 93.1, '2022-12-11 12:00:00', '2022-12-11 10:11:00', 73.2);
OutputQuery OK, 8 rows affected (0.01 sec)
Records: 8 Duplicates: 0 Warnings: 0
Once you’ve inserted the data, you’re ready to start learning how to use CAST
functions and concatenation expressions in SQL.
The CAST
function allows you to convert a literal value or the values held within a column into a specific data type. Using CAST
functions can be helpful for ensuring that the data types for values in a given expression are compatible.
To use the CAST
command, you must specify the column(s) holding existing data values that you want to convert and then write your preferred data values and or length in the expression. Here’s an example of the syntax:
. . .CAST(existing data value AS desired data value) . . .
It’s important to note, however, that CAST
functions adhere to certain rules in order to run correctly. For instance, it’s important to ensure that the data type you want to convert is compatible with the one you want to convert it to. Referring to the sample data, you wouldn’t be able to convert the values in the finalexam_grade
from a numerical data value (in this case the decimal
data type) directly into a string value such as a letter grade using the CAST
function. Similarly, you cannot convert data types that have a maximum length (such as the example columns which hold varchar(30)
values) to a longer length (for instance, varchar(35)
).
It’s also important to note that different SQL implementations will behave differently when running queries that use CAST
functions to convert data types. Running a query with a CAST
function in MySQL could produce different results than running the same query in PostgreSQL, for example.
To better understand how you can use CAST
functions, imagine the following scenario based on the sample data you inserted in the previous step. Mr. Frank, a sixth-grade teacher at PS 118, is getting ready to submit his grades for the fall semester. He’s been diligently tracking each student’s progress and is especially concerned about their grades for the midterm exam, essay, and final exam. Let’s say you’re helping out Mr. Frank as a teaching assistant, and he’s asked you to provide him with the information for those graded assignments.
You’ll retrieve this data by querying the fall_grades
table to retrieve the relevant information, such as the student’s first_name
, last_name
, and their grades for each assignment:
- SELECT first_name, last_name, midterm_grade, essay_grade, finalexam_grade FROM fall_grades;
Output+------------+-----------+---------------+-------------+-----------------+
| first_name | last_name | midterm_grade | essay_grade | finalexam_grade |
+------------+-----------+---------------+-------------+-----------------+
| Arnold | Shortman | 85.8 | 90.1 | 82.5 |
| Helga | Pataki | 88.4 | 72.5 | 90.0 |
| Gerald | Johanssen | 94.2 | 95.8 | 88.1 |
| Phoebe | Heyerdahl | 98.8 | 90.4 | 100.0 |
| Harold | Berman | 75.7 | 67.5 | 90.9 |
| Eugene | Horowitz | 100.0 | 89.9 | 98.2 |
| Rhonda | Lloyd | 90.4 | 81.3 | 95.5 |
| Stinky | Peterson | 70.6 | 93.1 | 73.2 |
+------------+-----------+---------------+-------------+-----------------+
8 rows in set (0.00 sec)
After bringing this result set to Mr. Frank, he explains that the system he’s using only allows him to input grades as whole numbers and needs these decimal data values to be converted. You decide to use a CAST
function to convert the number of character values specified (in this case the four in the decimal
data type), into two character values instead.
For this query, use the syntax from the previous example but include a CAST
function to convert the decimal
data type to two characters for each of the graded assignments. You’ll implement a CAST
function in three different expressions (for midterm_grade
, essay_grade
, and finalexam_grade
) to convert them to only 2 character data values:
- SELECT first_name, last_name,
- CAST(midterm_grade AS char(2)) AS midterm,
- CAST(essay_grade AS char(2)) AS essay,
- CAST(finalexam_grade AS char(2)) AS finalexam
- FROM fall_grades;
Output+------------+-----------+---------+-------+-----------+
| first_name | last_name | midterm | essay | finalexam |
+------------+-----------+---------+-------+-----------+
| Arnold | Shortman | 85 | 90 | 82 |
| Helga | Pataki | 88 | 72 | 90 |
| Gerald | Johanssen | 94 | 95 | 88 |
| Phoebe | Heyerdahl | 98 | 90 | 10 |
| Harold | Berman | 75 | 67 | 90 |
| Eugene | Horowitz | 10 | 89 | 98 |
| Rhonda | Lloyd | 90 | 81 | 95 |
| Stinky | Peterson | 70 | 93 | 73 |
+------------+-----------+---------+-------+-----------+
8 rows in set, 24 warnings (0.00 sec)
After reviewing each student’s grades, Mr. Frank asks if you can pull information about the exact dates and times each student submitted their assignments.
To retrieve this data, run the following SELECT
statement:
- SELECT first_name, last_name, midterm_deadline, essay_deadline, finalexam_deadline FROM fall_grades;
Output+------------+-----------+---------------------+---------------------+---------------------+
| first_name | last_name | midterm_deadline | essay_deadline | finalexam_deadline |
+------------+-----------+---------------------+---------------------+---------------------+
| Arnold | Shortman | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Helga | Pataki | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Gerald | Johanssen | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Phoebe | Heyerdahl | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Harold | Berman | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Eugene | Horowitz | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Rhonda | Lloyd | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
| Stinky | Peterson | 2022-10-16 12:00:00 | 2022-11-20 12:00:00 | 2022-12-11 12:00:00 |
+------------+-----------+---------------------+---------------------+---------------------+
8 rows in set (0.00 sec)
After reviewing this output, Mr. Frank sighs and tells you this information is too difficult to parse through. These columns are all set to store TIMESTAMP
values, which is why they’re extremely long. You decide to use the CAST
function to convert the output into something more digestible and also to break up the query into two: one for the dates and one for the times.
To query only for the time students submitted their assignments, run CAST
and specify that you want data values from that particular column to be converted into time
values:
- SELECT first_name, last_name,
- CAST(midterm_submitted AS time) AS midterm,
- CAST(essay_submitted AS time) AS essay,
- CAST(finalexam_submitted AS time) AS finalexam
- FROM fall_grades;
Output+------------+-----------+----------+----------+-----------+
| first_name | last_name | midterm | essay | finalexam |
+------------+-----------+----------+----------+-----------+
| Arnold | Shortman | 06:30:00 | 03:00:00 | 03:00:00 |
| Helga | Pataki | 10:00:00 | 03:15:00 | 05:00:00 |
| Gerald | Johanssen | 02:00:00 | 02:45:00 | 11:00:00 |
| Phoebe | Heyerdahl | 11:00:00 | 11:15:00 | 11:40:00 |
| Harold | Berman | 08:00:00 | 09:15:00 | 09:15:00 |
| Eugene | Horowitz | 01:00:00 | 01:22:00 | 07:55:00 |
| Rhonda | Lloyd | 06:00:00 | 06:09:00 | 06:45:00 |
| Stinky | Peterson | 03:00:00 | 05:55:00 | 10:11:00 |
+------------+-----------+----------+----------+-----------+
8 rows in set (0.00 sec)
This output provides an overview of the time frames each student finished their assignments. You recall that every assignment is due on a Sunday at midnight. Several students were consistent with their timing, while others finished earlier, or finished slightly before the midnight deadline.
However, this is only half of the information Mr. Frank asked for, so let’s work on the next query which will use the CAST
function to convert those same TIMESTAMP
values to date
values. You’ll run the same query as before, but this time, replace time
with date
:
- SELECT first_name, last_name,
- CAST(midterm_submitted AS date) AS midterm,
- CAST(essay_submitted AS date) AS essay,
- CAST(finalexam_submitted AS date) AS finalexam
- FROM fall_grades;
Output+------------+-----------+------------+------------+------------+
| first_name | last_name | midterm | essay | finalexam |
+------------+-----------+------------+------------+------------+
| Arnold | Shortman | 2022-10-16 | 2022-11-20 | 2022-12-11 |
| Helga | Pataki | 2022-10-16 | 2022-11-21 | 2022-12-11 |
| Gerald | Johanssen | 2022-10-16 | 2022-11-20 | 2022-12-11 |
| Phoebe | Heyerdahl | 2022-10-16 | 2022-11-20 | 2022-12-11 |
| Harold | Berman | 2022-10-16 | 2022-11-22 | 2022-12-11 |
| Eugene | Horowitz | 2022-10-16 | 2022-11-20 | 2022-12-11 |
| Rhonda | Lloyd | 2022-10-16 | 2022-11-20 | 2022-12-11 |
| Stinky | Peterson | 2022-10-16 | 2022-11-20 | 2022-12-11 |
+------------+-----------+------------+------------+------------+
8 rows in set (0.00 sec)
Based on this output, you can identify which students turned in their assignments after the deadline and why their grades may have been impacted due to fewer points given for tardiness. For example, Helga turned in her assignment a day late (2022-11-21
) and Harold turned in his assignment two days late (2022-11-22
) after the 2022-11-20
deadline for the essay assignment.
Although Mr. Frank is pleased with these cleaned-up results, he needs a bit more help articulating the data further for his grades report. In the next section, you’ll practice using concatenation expressions that can combine multiple literal values or column values into a single string value, helping to make the information clearer to interpret as a complete statement or sentence.
With the concatenation expression, CONCAT
, you can manipulate data by bringing character or numerical values together from different columns into a single result.
Generally, SQL databases return the data values in result sets separately in their respective columns. For example, if you were to query for the first_name
and last_name
of the PS 118 students, your output would display as the following:
- SELECT first_name, last_name FROM fall_grades;
Output+------------+-----------+
| first_name | last_name |
+------------+-----------+
| Arnold | Shortman |
| Helga | Pataki |
| Gerald | Johanssen |
| Phoebe | Heyerdahl |
| Harold | Berman |
| Eugene | Horowitz |
| Rhonda | Lloyd |
| Stinky | Peterson |
+------------+-----------+
8 rows in set (0.00 sec)
However, this information isn’t formatted in the way Mr. Frank prefers for the report. Let’s execute another query using concatenation to combine the first and last names of the students into a single string. The following query does this using the CONCAT
keyword and also provides the resulting column with the alias full_names
:
- SELECT CONCAT(first_name, last_name) AS full_names FROM fall_grades;
Output+-----------------+
| full_names |
+-----------------+
| ArnoldShortman |
| HelgaPataki |
| GeraldJohanssen |
| PhoebeHeyerdahl |
| HaroldBerman |
| EugeneHorowitz |
| RhondaLloyd |
| StinkyPeterson |
+-----------------+
8 rows in set (0.00 sec)
Concatenation expressions generally work on all data types, but if you don’t specify details such as spacing between data values, the output will appear as a run-on in a single string as evidenced by this output. To fix this, you can add a pair of single quotes with a space between them (' '
) in between the two first_name
and last_name
columns so that the values will output as a single string, but this time with a space between them to make it more readable:
- SELECT CONCAT(first_name, ' ', last_name) AS full_name FROM fall_grades;
Output+------------------+
| full_name |
+------------------+
| Arnold Shortman |
| Helga Pataki |
| Gerald Johanssen |
| Phoebe Heyerdahl |
| Harold Berman |
| Eugene Horowitz |
| Rhonda Lloyd |
| Stinky Peterson |
+------------------+
8 rows in set (0.00 sec)
By including a space between the single quotes in the query, the output now shows the students’ names clearly as two separate words, rather than one combined word.
Note: Most modern relational DBMSs use the syntax outlined in this section for concatenating values. However, this syntax (the CONCAT
keyword) is not the traditional syntax defined by the SQL standard.
The traditional way to concatenate values in SQL is to place a pair of vertical bars between the data values you want to concatenate. MySQL doesn’t allow you to use this syntax at all, but some DBMSs, like PostgreSQL, allow you to use either method. The following example query (run on a PostgreSQL database) produces the same result as the previous query, but this time using vertical bars:
- SELECT first_name || ' ' || last_name AS full_name
- FROM fall_grades;
Output full_name
------------------
Arnold Shortman
Helga Pataki
Gerald Johanssen
Phoebe Heyerdahl
Harold Berman
Eugene Horowitz
Rhonda Lloyd
Stinky Peterson
(8 rows)
Now let’s try another example where we’ll retrieve more information about each student. This time, we want to concatenate the first_name
, last_name
, e-mail_address
, finalexam_grade
, and finalexam_submitted
data values into a single column using CONCAT
. Don’t forget to add single quotes between each column you want to add a space between as in the following example:
- SELECT CONCAT(first_name, ' ', last_name, ' ',
- email_address, ' ', finalexam_grade, ' ', finalexam_submitted)
- AS student_info FROM fall_grades;
Output+-----------------------------------------------------------------+
| student_info |
+-----------------------------------------------------------------+
| Arnold Shortman ashortman@ps118.com 82.5 2022-12-11 03:00:00 |
| Helga Pataki hpataki@ps118.com 90.0 2022-12-11 05:00:00 |
| Gerald Johanssen gjohanssen@ps118.com 88.1 2022-12-11 11:00:00 |
| Phoebe Heyerdahl pheyerdahl@ps118.com 100.0 2022-12-11 11:40:00 |
| Harold Berman hberman@ps118.com 90.9 2022-12-11 09:15:00 |
| Eugene Horowitz ehorowitz@ps118.com 98.2 2022-12-11 07:55:00 |
| Rhonda Lloyd rlloyd@ps118.com 95.5 2022-12-11 06:45:00 |
| Stinky Peterson speterson@ps118.com 73.2 2022-12-11 10:11:00 |
+-----------------------------------------------------------------+
8 rows in set (0.00 sec)
Mr. Frank is pleased with these results but would like to make it even more concise for his grades report by converting some of the data values. In this scenario, you’ll use the CAST
function to convert the finalexam_grade
data type into a whole number and the finalexam_submitted
, which uses the TIMESTAMP
data type, into a date
value as in the following:
- SELECT CONCAT(first_name, ' ', last_name, ' ', email_address, ' ',
- CAST(finalexam_grade AS char(2)), ' ',
- CAST(finalexam_submitted AS date))
- AS student_info FROM fall_grades;
Output+-----------------------------------------------------+
| student_info |
+-----------------------------------------------------+
| Arnold Shortman ashortman@ps118.com 82 2022-12-11 |
| Helga Pataki hpataki@ps118.com 90 2022-12-11 |
| Gerald Johanssen gjohanssen@ps118.com 88 2022-12-11 |
| Phoebe Heyerdahl pheyerdahl@ps118.com 10 2022-12-11 |
| Harold Berman hberman@ps118.com 90 2022-12-11 |
| Eugene Horowitz ehorowitz@ps118.com 98 2022-12-11 |
| Rhonda Lloyd rlloyd@ps118.com 95 2022-12-11 |
| Stinky Peterson speterson@ps118.com 73 2022-12-11 |
+-----------------------------------------------------+
8 rows in set, 8 warnings (0.00 sec)
Let’s take it a step further and write a query that uses the CAST
function and the concatenation expression to output full sentences. You can do this by writing a short statement between the single quotes. Be sure to maintain a space between each column by adding one space before and after the end of the written statement(s):
- SELECT CONCAT(first_name, ' ', last_name, ' can be contacted at ', email_address,
- ' and received a grade of ',
- CAST(finalexam_grade AS char(2)),
- ' after submitting the final exam on ',
- CAST(finalexam_submitted AS date))
- AS student_info FROM fall_grades;
Output+------------------------------------------------------------------------------------------------------------------------------------+
| student_info |
+------------------------------------------------------------------------------------------------------------------------------------+
| Arnold Shortman can be contacted at ashortman@ps118.com and received a grade of 82 after submitting the final exam on 2022-12-11 |
| Helga Pataki can be contacted at hpataki@ps118.com and received a grade of 90 after submitting the final exam on 2022-12-11 |
| Gerald Johanssen can be contacted at gjohanssen@ps118.com and received a grade of 88 after submitting the final exam on 2022-12-11 |
| Phoebe Heyerdahl can be contacted at pheyerdahl@ps118.com and received a grade of 10 after submitting the final exam on 2022-12-11 |
| Harold Berman can be contacted at hberman@ps118.com and received a grade of 90 after submitting the final exam on 2022-12-11 |
| Eugene Horowitz can be contacted at ehorowitz@ps118.com and received a grade of 98 after submitting the final exam on 2022-12-11 |
| Rhonda Lloyd can be contacted at rlloyd@ps118.com and received a grade of 95 after submitting the final exam on 2022-12-11 |
| Stinky Peterson can be contacted at speterson@ps118.com and received a grade of 73 after submitting the final exam on 2022-12-11 |
+------------------------------------------------------------------------------------------------------------------------------------+
8 rows in set, 8 warnings (0.00 sec)
This output results in full sentences about each student in Mr. Frank’s class. These minor additions in between the single quotes make a big difference in making it clear who this information is about and their respective data. This is because of the specific columns you retrieved data from in your query. Mr. Frank cannot thank you enough for your incredible work. He’s extremely pleased that you’ve even saved him time by writing out full sentences that he can quickly input into his report.
This guide explained various use-cases for manipulating data with the CAST
function and concatenation expression. With the CAST
function, you practiced converting a column of one data type to another. Additionally, you learned how to use concatenation expressions to bring different data values together, both character and numerical, in a single string. You also performed the CAST
function and the concatenation expression in the same query to generate complete sentences that provide more context about the data values. This can streamline the process of writing them out separately, and instead, gives you the ability to efficiently copy and paste the information as-is. To learn more about other functions in SQL, check out our series on How To Use SQL.
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
Structured Query Language — commonly known as SQL — is a language used to define, control, manipulate, and query data held in a relational database. SQL has been widely adopted since it was first developed in the 1970s, and today it’s the predominant language used to manage relational database management systems.
Ideal for managing structured data (data that can fit neatly into an existing data model), SQL is an essential tool for developers and system administrators in a wide variety of contexts. Also, because of its maturity and prevalence, candidates with SQL experience are highly sought after for jobs across a number of industries.
This series is intended to help you get started with using SQL. It includes a mix of conceptual articles and tutorials which provide introductions to various SQL concepts and practices. You can also use the entries in this series for reference while you continue to hone your skills with SQL.
Note: Please be aware that the tutorials in this series use MySQL in examples, but many RDBMSs use their own unique implementations of SQL. Although the commands outlined in this tutorial will work on most RDBMSs, the exact syntax or output may differ if you test them on a system other than MySQL.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
Sign up for Infrastructure as a Newsletter.
Working on improving health and education, reducing inequality, and spurring economic growth? We'd like to help.
Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.