|
|
Questions about database (MySql) i come across during my interviews
- What is DDL, DML and DCL?
- - If you look at the large variety of SQL commands, they can be divided into three large subgroups. Data Definition Language deals with database schemas and descriptions of how the data should reside in the database, therefore language statements like CREATE TABLE or ALTER TABLE belong to DDL. DML deals with data manipulation, and therefore includes most common SQL statements such SELECT, INSERT, etc. Data Control Language includes commands such as GRANT, and mostly concerns with rights, permissions and other controls of the database system.
- How do you get the number of rows affected by query? -
- SELECT COUNT (name) FROM users would only return the number of names
- If the value in the column is repeatable, how do you find out the unique values? -
- To get unique records we can use DISTINCT in query, such as SELECT DISTINCT name FROM users.
- To count distinct records you can use SELECT COUNT (DISTINCT name) FROM users.
- How do you return the a x books starting from yth?
- SELECT book_title FROM books LIMIT y, x. The first number in LIMIT is the offset, the second is the number.
- How would you write a query to select all teams that won either 2, 4, 6 or 8 games?
- SELECT team_name FROM teams WHERE team_won IN (2, 4, 6, 8)
- How would you select all the users, whose phone number is null?
- SELECT user_name FROM users WHERE ISNULL(user_phonenumber);
- What does this query mean: SELECT name, isps.id FROM users LEFT JOIN isps USING (id)
- It’s equivalent to saying SELECT user_name, user_isp FROM users LEFT JOIN isps WHERE users.id=isps.id
- How to find last insert_id?
- SELECT LAST_INSERT_ID() will return the last value assigned by the auto_increment function. Note that you don’t have to specify the table name.
- When would you use ORDER BY in DELETE statement?
- When you’re not deleting by row ID. Such as in DELETE FROM techinterviews_com_questions ORDER BY timestamp LIMIT 1. This will delete the most recently posted question in the table techinterviews_com_questions.
- How can you see all indexes defined for a table?
- SHOW INDEX FROM techinterviews_questions;
- How would you change a column from VARCHAR(10) to VARCHAR(50)?
- ALTER TABLE techinterviews_questions CHANGE techinterviews_content techinterviews_CONTENT VARCHAR(50).
- How would you delete a column?
- ALTER TABLE techinterviews_answers DROP answer_user_id.
- When you create a table, and then run SHOW CREATE TABLE on it, you occasionally get different results than what you typed in. What does MySQL modify in your newly created tables?
- VARCHARs with length less than 4 become CHARs
- CHARs with length more than 3 become VARCHARs.
- NOT NULL gets added to the columns declared as PRIMARY KEYs
- Default values such as NULL are specified for each column
- How do I find out all databases starting with ‘tech’ to which I have access to?
- SHOW DATABASES LIKE ‘tech%’;
- How do you concatenate strings in MySQL?
- CONCAT (string1, string2, string3)
- How do you get a portion of a string?
- SELECT SUBSTR(title, 1, 10) from techinterviews_questions;
- What’s the difference between CHAR_LENGTH and LENGTH?
- The first is, naturally, the character count. The second is byte count. For the Latin characters the numbers are the same, but they’re not the same for Unicode and other encodings.
- How do you convert a string to UTF-8?
- SELECT (techinterviews_question USING utf8);
- What does + mean in REGEXP?
- It will match previous character at least once
- How do you get the year from a timestamp?
- SELECT YEAR(timestamp) from users;
- How do you offload the time/date handling to MySQL?
- SELECT DATE_FORMAT(timestamp, ‘%Y-%m-%d’) from questions;
- A similar TIME_FORMAT function formats time.
- What’s the difference between Unix timestamps and MySQL timestamps?
- Internally Unix timestamps are stored as 32-bit integers, while MySQL timestamps are stored in a similar manner, but represented in readable YYYY-MM-DD HH:MM:SS format.
- How do you convert between Unix timestamps and MySQL timestamps?
- UNIX_TIMESTAMP converts from MySQL timestamp to Unix timestamp,
- FROM_UNIXTIME converts from Unix timestamp to MySQL timestamp.
- What are ENUMs used for in MySQL?
- It limits the allowed values for the field
|