29 MySQL interview questions

  1. How do you start and stop MySQL on Windows? - net start MySQL, net stop MySQL
  2. How do you start MySQL on Linux? - /etc/init.d/mysql start
  3. Explain the difference between mysql and mysqli interfaces in PHP? - mysqli is the object-oriented version of mysql library functions.
  4. What’s the default port for MySQL Server? - 3306
  5. What does tee command do in MySQL? - tee followed by a filename turns on MySQL logging to a specified file. It can be stopped by command notee.
  6. Can you save your connection settings to a conf file? - Yes, and name it ~/.my.conf. You might want to change the permissions on the file to 600, so that it’s not readable by others.
  7. How do you change a password for an existing user via mysqladmin? - mysqladmin -u root -p password "newpassword"
  8. Use mysqldump to create a copy of the database? - mysqldump -h mysqlhost -u username -p mydatabasename > dbdump.sql
  9. Have you ever used MySQL Administrator and MySQL Query Browser? Describe the tasks you accomplished with these tools.
  10. What are some good ideas regarding user security in MySQL? - There is no user without a password. There is no user without a user name. There is no user whose Host column contains % (which here indicates that the user can log in from anywhere in the network or the Internet). There are as few users as possible (in the ideal case only root) who have unrestricted access.
  11. Explain the difference between MyISAM Static and MyISAM Dynamic. - In MyISAM static all the fields have fixed width. The Dynamic MyISAM table would include fields such as TEXT, BLOB, etc. to accommodate the data types with various lengths. MyISAM Static would be easier to restore in case of corruption, since even though you might lose some data, you know exactly where to look for the beginning of the next record.
  12. What does myisamchk do? - It compressed the MyISAM tables, which reduces their disk usage.
  13. Explain advantages of InnoDB over MyISAM? - Row-level locking, transactions, foreign key constraints and crash recovery.
  14. Explain advantages of MyISAM over InnoDB? - Much more conservative approach to disk space management - each MyISAM table is stored in a separate file, which could be compressed then with myisamchk if needed. With InnoDB the tables are stored in tablespace, and not much further optimization is possible. All data except for TEXT and BLOB can occupy 8,000 bytes at most. No full text indexing is available for InnoDB. TRhe COUNT(*)s execute slower than in MyISAM due to tablespace complexity.
  15. What are HEAP tables in MySQL? - HEAP tables are in-memory. They are usually used for high-speed temporary storage. No TEXT or BLOB fields are allowed within HEAP tables. You can only use the comparison operators = and <=>. HEAP tables do not support AUTO_INCREMENT. Indexes must be NOT NULL.
  16. How do you control the max size of a HEAP table? - MySQL config variable max_heap_table_size.
  17. What are CSV tables? - Those are the special tables, data for which is saved into comma-separated values files. They cannot be indexed.
  18. Explain federated tables. - Introduced in MySQL 5.0, federated tables allow access to the tables located on other databases on other servers.
  19. What is SERIAL data type in MySQL? - BIGINT NOT NULL PRIMARY KEY AUTO_INCREMENT
  20. What happens when the column is set to AUTO INCREMENT and you reach the maximum value for that table? - It stops incrementing. It does not overflow to 0 to prevent data losses, but further inserts are going to produce an error, since the key has been used already.
  21. Explain the difference between BOOL, TINYINT and BIT. - Prior to MySQL 5.0.3: those are all synonyms. After MySQL 5.0.3: BIT data type can store 8 bytes of data and should be used for binary data.
  22. Explain the difference between FLOAT, DOUBLE and REAL. - FLOATs store floating point numbers with 8 place accuracy and take up 4 bytes. DOUBLEs store floating point numbers with 16 place accuracy and take up 8 bytes. REAL is a synonym of FLOAT for now.
  23. If you specify the data type as DECIMAL (5,2), what’s the range of values that can go in this table? - 999.99 to -99.99. Note that with the negative number the minus sign is considered one of the digits.
  24. What happens if a table has one column defined as TIMESTAMP? - That field gets the current timestamp whenever the row gets altered.
  25. But what if you really want to store the timestamp data, such as the publication date of the article? - Create two columns of type TIMESTAMP and use the second one for your real data.
  26. Explain data type TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP - The column exhibits the same behavior as a single timestamp column in a table with no other timestamp columns.
  27. What does TIMESTAMP ON UPDATE CURRENT_TIMESTAMP data type do? - On initialization places a zero in that column, on future updates puts the current value of the timestamp in.
  28. Explain TIMESTAMP DEFAULT ‘2006:09:02 17:38:44′ ON UPDATE CURRENT_TIMESTAMP. - A default value is used on initialization, a current timestamp is inserted on update of the row.
  29. If I created a column with data type VARCHAR(3), what would I expect to see in MySQL table? - CHAR(3), since MySQL automatically adjusted the data type.
This entry was posted in Database. Bookmark the permalink. Post a comment or leave a trackback: Trackback URL.

6 Comments on 29 MySQL interview questions

  1. Posted 10/13/2006 at 1:54 am | Permalink

    hi,
    i want to know how to enable or disable a row of a table using MySQL in struts?

  2. arvind
    Posted 12/7/2006 at 4:17 am | Permalink

    tell me how to enter data from one column of one table to one column to another table using foreign key?

  3. Gerry
    Posted 5/20/2007 at 6:10 am | Permalink

    If an interviewer asked me these questions I would laugh at them. 90% of these questions are ones that you would look up when you needed them and then instantly forget it (on purpose because you don’t need you head being filled with crap). It would be clear that anybody asking these questions has no understanding of what makes a good database guru / application developer.

    If you want to evaluate a tech, then you need a tech who knows their shit. If you find a tech who does well on these questions then you have found somebody who spends a lot of time memorizing useless crap and not enough time learning how to develop smart apps. You really don’t want to hire that person.

  4. rajendra
    Posted 7/23/2007 at 1:21 pm | Permalink

    i have a doubt for the query ,the query must be like this there is a table with the fields name,email,phone number i want to restrict repeated entries of name and mobile number entries ,one more thing the mobile number must start with a speciefic number and exists.

  5. Posted 9/20/2008 at 5:30 pm | Permalink

    Gerry, I couldnt agree with you more. I am tired of these kind of questions people ask in interviews.

    Honestly the truth is people who ask these questions want to show others that “they know all these shit”. They spent little time in analyzing the person’s problem solving skills, analytical skills and more than anything “attitude”. For that matter, people asking these kinds of above questions itself are having the wrong attitude.

    Realize the truth guys.. This is GOOGLE world.

    Thanks
    -Mahesh

  6. Bala
    Posted 1/27/2009 at 4:46 am | Permalink

    Gerry,Mahesh,

    I agree with your comments about the questions listed above.

    However, when a person walks in for a role requiring knowledge of MySQL, how does one assess if he/she has worked on/used MySQL (especially web site applications)?

    Regards-Bala

Post a Comment

Your email is never published nor shared. Required fields are marked *

*
*