Tuesday, February 19, 2019

Week 22 CST 363 Intro to Database Systems


·      Know what are ACID features of a database and why are they important
o  Atomicity
§  Transactions are all or nothing
o  Consistency
§  Only valid data is saved
o  Isolation
§  Transactions do not affect each other
§  locks
o  Durability
§  Written data will not be lost
·      Know that locks, versioning and optimistic locking are used to achieve ACID properties of concurrent transactions
o  Concurrency is the ability of the system to support two or more transactions working with the same data at the same time. Concurrency problems are prevented using locks which stop other transactions from executing if another is already running.
·      Know how to begin and terminate transactions in application code and SQL scripts 
o  Use START TRANSACTION to turn off autocommit mode
o  Use COMMIT to commit the changes
o  Use ROLLBACK to roll back the changes
·      Use the correct ANSI standard isolation level to make trade-off between concurrency and ACID properties
o  
o  The simplest way to prevent concurrency problems is to change the default locking by SET TRANSACTION ISOLATION LEVEL
·      Use SESSION for the session
·      USE GLOBAL for all sessions
§  Use SERIALIZABLE isolation level to isolate it from every other transaction and restrict concurrency, every resource is locked and transactions cannot access it
·      it requires more overhead to manage the locks
§  Use READ UNCOMMITTED isolation level by just using SELECT queries and not setting any locks
§  Use READ COMMITTED to prevent transactions from seeing data that has been changed by other transactions but  not committed
§  Use REPEATBLE READ to be read consistently in the same transaction
·      Know how rollback and forward recovery work in a database
o  Use SAVEPOINT to create a savepoint with a specific name
o  USE ROLLBACK TO SAVEPOINT to roll back to a specified save point




·      MySQL supports and uses both locks and MVCC
·      MVCC is used so that reader will not be blocked by a writer holding a lock on a row
o  row locking is used so that multiple writers must serialize when updating the same row
·      A transaction that reads a row with the intention of later updating the row should issue  SELECT ... WITH UPDATE  to acquire a lock on a row when the row is read.  This prevents another transaction from modifying the row between the time of select and time of update
·      InnoDB Transaction Model       
o  combines the best of multi-versioning database with two-phase locking at the row level and run queries

o  The lock info is stores so lock escalation is not needed

Tuesday, February 12, 2019

Week 21 CST 363 Intro to Database Systems

This week, I learned how to properly import from github to pycharm using this video. I initially downloaded the file from github then unzipped it into my dropbox like I usually do. Here, the import statements were not accessing the other files. I changed them from it's previous version to the import version and that did not fix it. I looked at the forums and another classmate mentioned that we need to append the folder name to the from statements to access the other files. Fortunately, that worked after I setup git on my desktop and then logged into github on pycharm and downloaded the source code that way following the video.  This is a cleaner way of accessing files and I plan on using it in the future.

Tuesday, February 5, 2019

Week 20: CST 363 Intro to Database Systems

This week, I learned about the importance of time management and getting assignments in on time especially if they are Exams. This exam will be late, but I hope I can still turn it in. Some parts took longer than others. I reviewed OLAP and OLTP tables this week, learning the differences between the two which were written into my notebook and was not typed. I also learned about star schemas, which was my main part in the group project.

cst 499 week 8

This week, we finished writing the paper in order to do the best job possible even if it was a little bit late. Now that everything is done,...