Wednesday, September 25, 2024

CST363 - Week 4

Briefly summarize 5 things what you have learned in the course so far.

Prior to this class, I had minimal knowledge about databases, aside from a little from the previous Java class. So far, the basics of databases and writing queries is the first thing that comes to mind. We’ve also learned about the importance of data integrity through the use of primary keys, foreign keys, and constraints. Additionally, we covered how to use different join operations to combine data from various tables, as well as data normalization to further organize information and eliminate redundancy. Finally, we explored indexing and how it can improve the performance.


List at least 3 questions you still have about databases.

I’d be interested to know more about the differences between SQL and NoSQL, but this is something I will likely research on my own. I’m also curious whether SQL supports error handling similar to Java or other programming languages. I briefly searched this topic last week, and from what I found, it seems that error handling in SQL relies on conditionals rather than things like try-catch blocks. Lastly, I would like to gain a deeper understanding of how massive databases are maintained, as it seems quite daunting.

Wednesday, September 18, 2024

CST363 Week - 3

What is an SQL view. How is it similar to a table? In what ways is it different (think about primary keys, insert, update, delete operations) ?

An SQL view is a virtual table created based on the result of a query. Views do not store data physically; instead, they provide access to data from the underlying tables. This is especially helpful for sensitive data you don't want everyone to access. Both views and tables have rows and columns, and you can use SELECT statements on both. However, views do not have primary keys and are not typically used with INSERT, UPDATE, and DELETE statements.


We have completed our study of SQL for this course. This is not to imply that we have studied everything in the language. There are many specialized features such as calculating rolling averages, query of spatial data (data with latitude and longitude) coordinates, and more. But take a minute to think about how SQL compares to other programming languages such as Java. What features are similar , and which are present in one language but not in the other? For example, Java has conditional if statements which are similar to SQL WHERE predicates, the SELECT clause is similar to a RETURN statement in that it specifies what data or expression values are to be returned in the query result (although it is strange that a statement should specify the RETURN as the first part of a SELECT.

Honestly, I haven't thought about this too much. The first thing that comes to mind is statements like INSERT, UPDATE, and DELETE. In Java, we don't manage data in that way. Another aspect that comes to my mind is error handling, which is quite robust in Java. I'm not sure how in-depth SQL's error-handling capabilities are when it comes to exceptions.

Wednesday, September 11, 2024

CST363 - Week 2

This week we were tasked to answer the following questions

SQL has the flexibility to join tables on any column(s) using any predicate (=, >, < ). Most of the time the join will use equality between a primary and foreign key. Think of example where joining on something other than keys would be needed. Write the query both as an English sentence and in SQL. If you can't think of your own example, search the textbook or internet for an example.

I think one way to look at this in English would be sales in a store. For example, we want a list of the total stock of a product along with the total number of that product the store has sold.

In SQL, I think it would look like this:

SELECT p.product_name
    SUM(p.quantity) AS current_stock
    SUM(s.quantity AS total_sold
FROM products AS p
LEFT JOIN sales AS s ON  p.product_name = s.product_name
WHERE p.product_name = 'apples'
GROUP BY p.product_name;


What is your opinion of SQL as a language? Do you think it is easy to learn and use? When translating from an English question to SQL, what kinds of questions do you find most challenging?

Aside from the basic SELECT SQL problems, I find SQL fairly difficult to understand compared to languages like Java or Python for some reason. I particularly struggle with JOIN problems and often have to refer to documentation. There are other aspects that I constantly get mixed up, and it just doesn't come as easily to me for whatever reason.

Tuesday, September 3, 2024

CST363 - Week 1

Relational database tables and spreadsheets look similar, as both have rows and columns. What are some important differences between the two?

In relational databases, data is organized into tables with defined keys (such as foreign keys), whereas spreadsheets organize data in rows and columns without utilizing any keys.


Installing and configuring a database and learning how to use it is more complicated than simply reading and writing data to a file. What are some important reasons that make a database a useful investment of time?

Using constraints (like primary and foreign keys) allows for consistent and accurate data. Spreadsheets do not have this feature, which can lead to errors. Databases can also handle large amounts of data and facilitate easier scaling in the future.


What do you want to learn in this course that you think will be useful in your future career?

Databases are incredibly useful, and although I don't have much experience now or a clear idea of how I will use them going forward, I always enjoy learning and expanding my knowledge.

CST462S - Service Learning Experience

With the first half of my Summer semester now coming to a close, I am submitting my final assignments and preparing for the upcoming class i...