Sunday 19 August 2012

Unix interview and xml queries

Linux application programming questions

  1. Explain the difference between a static library and a dynamic library? - Static library is linked into the executable, while a dynamic library (or shared object) is loaded while the executable has started.
  2. How do you create a static library? - If you have a collection of object (.o) files, you can do it by running ar command. Generally a static library has a .a extension, and you can link it into an executable by providing -l libraryname to gcc.
  3. Where should the developed libraries be installed on the system? - GNU recommends /usr/local/bin for binaries and /usr/local/lib for libraries.
  4. What’s LD_LIBRARY_PATH? - It’s an environment variable that lists all the directories which should be searches for libraries before the standard directories are searched.
  5. How do you create a shared library? - Create the object file with -fPIC for position-independent code, then run gcc with -shared option.
  6. How do you install a shared library? - Run ldconfig in the standard directory that it’s installed in.
  7. What does ldd do? - It shows a list of installed shared libraries.
  8. How do you dynamically load a library in your app? - Use dlopen()
  9. What does nm command do? - It reports the list of symbols in a given library.

Basic shell scripting questions

  1. How do you find out what’s your shell? - echo $SHELL
  2. What’s the command to find out today’s date? - date
  3. What’s the command to find out users on the system? - who
  4. How do you find out the current directory you’re in? - pwd
  5. How do you remove a file? - rm
  6. How do you remove a - rm -rf
  7. How do you find out your own username? - whoami
  8. How do you send a mail message to somebody? - mail somebody@techinterviews.com -s ‘Your subject’ -c ‘cc@techinterviews.com
  9. How do you count words, lines and characters in a file? - wc
  10. How do you search for a string inside a given file? - grep string filename
  11. How do you search for a string inside a directory? - grep string *
  12. How do you search for a string in a directory with the subdirectories recursed? - grep -r string *
  13. What are PIDs? - They are process IDs given to processes. A PID can vary from 0 to 65535.
  14. How do you list currently running process? - ps
  15. How do you stop a process? - kill pid
  16. How do you find out about all running processes? - ps -ag
  17. How do you stop all the processes, except the shell window? - kill 0
  18. How do you fire a process in the background? - ./process-name &
  19. How do you refer to the arguments passed to a shell script? - $1, $2 and so on. $0 is your script name.
  20. What’s the conditional statement in shell scripting? - if {condition} then … fi
  21. How do you do number comparison in shell scripts? - -eq, -ne, -lt, -le, -gt, -ge
  22. How do you test for file properties in shell scripts? - -s filename tells you if the file is not empty, -f filename tells you whether the argument is a file, and not a directory, -d filename tests if the argument is a directory, and not a file, -w filename tests for writeability, -r filename tests for readability, -x filename tests for executability
  23. How do you do Boolean logic operators in shell scripting? - ! tests for logical not, -a tests for logical and, and -o tests for logical or.
  24. How do you find out the number of arguments passed to the shell script? - $#
  25. What’s a way to do multilevel if-else’s in shell scripting? - if {condition} then {statement} elif {condition} {statement} fi
  26. How do you write a for loop in shell? - for {variable name} in {list} do {statement} done
  27. How do you write a while loop in shell? - while {condition} do {statement} done
  28. How does a case statement look in shell scripts? - case {variable} in {possible-value-1}) {statement};; {possible-value-2}) {statement};; esac
  29. How do you read keyboard input in shell scripts? - read {variable-name}
  30. How do you define a function in a shell script? - function-name() { #some code here return }
  31. How does getopts command work? - The parameters to your script can be passed as -n 15 -x 20. Inside the script, you can iterate through the getopts array as while getopts n:x option, and the variable $option contains the value of the entered option.

General UNIX interview questions
  1. What are the main differences between Apache 1.x and 2.x?
  2. What does the “route” command do?
  3. What are the read/write/execute bits on a directory mean?
  4. What does iostat do?

  5. what does vmstat do?
  6. What does netstat do?
  7. What is the most graceful way to bring a system into single user mode?
  8. How do you determine disk usage?
  9. What is AWK?
  10. What is SED?
  11. What is the difference between binaries in /bin, and /usr/bin?
  12. What is a dynamically linked file?
  13. What is a statically linked file?

Oracle on Linux/Unix questions

How many memory layers are in the shared pool?
  1. How do you find out from the RMAN catalog if a particular archive log has been backed-up?
  2. How can you tell how much space is left on a given file system and how much space each of the file system’s subdirectories take-up?
  3. Define the SGA and how you would configure SGA for a mid-sized OLTP environment? What is involved in tuning the SGA?
  4. What is the cache hit ratio, what impact does it have on performance of an Oracle database and what is involved in tuning it?
  5. Other than making use of the statspack utility, what would you check when you are monitoring or running a health check on an Oracle 8i or 9i database?
  6. How do you tell what your machine name is and what is its IP address?

  7. How would you go about verifying the network name that the local_listener is currently using?
  8. You have 4 instances running on the same UNIX box. How can you determine which shared memory and semaphores are associated with which instance?
  9. What view(s) do you use to associate a user’s SQLPLUS session with his o/s process?
  10. What is the recommended interval at which to run statspack snapshots, and why?
  11. What spfile/init.ora file parameter exists to force the CBO to make the execution path of a given statement use an index, even if the index scan may appear to be calculated as more costly?
  12. Assuming today is Monday, how would you use the DBMS_JOB package to schedule the execution of a given procedure owned by SCOTT to start Wednesday at 9AM and to run subsequently every other day at 2AM.
  13. How would you edit your CRONTAB to schedule the running of /test/test.sh to run every other day at 2PM?
  14. What do the 9i dbms_standard.sql_txt() and dbms_standard.sql_text() procedures do?
  15. In which dictionary table or view would you look to determine at which time a snapshot or MVIEW last successfully refreshed?
  16. How would you best determine why your MVIEW couldn’t FAST REFRESH?
  17. How does propagation differ between Advanced Replication and Snapshot Replication (read-only)?
  18. Which dictionary view(s) would you first look at to understand or get a high-level idea of a given Advanced Replication environment?
  19. How would you begin to troubleshoot an ORA-3113 error?
  20. Which dictionary tables and/or views would you look at to diagnose a locking issue?
  21. An automatic job running via DBMS_JOB has failed. Knowing only that “it’s failed”, how do you approach troubleshooting this issue?
  22. How would you extract DDL of a table without using a GUI tool?
  23. You’re getting high “busy buffer waits” - how can you find what’s causing it?
  24. What query tells you how much space a tablespace named “test” is taking up, and how much space is remaining?
  25. Database is hung. Old and new user connections alike hang on impact. What do you do? Your SYS SQLPLUS session IS able to connect.
  26. Database crashes. Corruption is found scattered among the file system neither of your doing nor of Oracle’s. What database recovery options are available? Database is in archive log mode.
  27. Illustrate how to determine the amount of physical CPUs a Unix Box possesses (LINUX and/or Solaris).
  28. How do you increase the OS limitation for open files (LINUX and/or Solaris)?
  29. Provide an example of a shell script which logs into SQLPLUS as SYS, determines the current date, changes the date format to include minutes & seconds, issues a drop table command, displays the date again, and finally exits.
  30. Explain how you would restore a database using RMAN to Point in Time?
  31. How does Oracle guarantee data integrity of data changes?
  32. Which environment variables are absolutely critical in order to run the OUI?
  33. What SQL query from v$session can you run to show how many sessions are logged in as a particular user account?
  34. Why does Oracle not permit the use of PCTUSED with indexes?
  35. What would you use to improve performance on an insert statement that places millions of rows into that table?
  36. What would you do with an “in-doubt” distributed transaction?
  37. What are the commands you’d issue to show the explain plan for “select * from dual”?
  38. In what script is “snap$” created? In what script is the “scott/tiger” schema created?
  39. If you’re unsure in which script a sys or system-owned object is created, but you know it’s in a script from a specific directory, what UNIX command from that directory structure can you run to find your answer?
  40. How would you configure your networking files to connect to a database by the name of DSS which resides in domain icallinc.com?
  41. You create a private database link and upon connection, fails with: ORA-2085: connects to . What is the problem? How would you go about resolving this error?
  42. I have my backup RMAN script called “backup_rman.sh”. I am on the target database. My catalog username/password is rman/rman. My catalog db is called rman. How would you run this shell script from the O/S such that it would run as a background process?
  43. Explain the concept of the DUAL table.
  44. What are the ways tablespaces can be managed and how do they differ?
  45. From the database level, how can you tell under which time zone a database is operating?
  46. What’s the benefit of “dbms_stats” over “analyze”?
  47. Typically, where is the conventional directory structure chosen for Oracle binaries to reside?
  48. You have found corruption in a tablespace that contains static tables that are part of a database that is in NOARCHIVE log mode. How would you restore the tablespace without losing new data in the other tablespaces?
  49. How do you recover a datafile that has not been physically been backed up since its creation and has been deleted. Provide syntax example.


SQL/XML Queries


This chapter describes the syntax of Connect for SQL/XML queries. The following conventions are used to document the query syntax:
  • Bold type indicates keywords and tokens that must be entered as part of the query.
  • Italic type indicates variables.
  • Square brackets [ ] surround optional items.
  • A vertical rule | indicates an OR separator to delineate items.
  • Curly brackets { } surround items that can repeat zero or more times.
The following SQL/XML query syntax shows the high-level components of a Connect for SQL/XML query.
sqlxml_query ::= select 

SQL_value_expression | XML_value_expression 

{, SQL_value_expression | XML_value_expression} 

rest_of_sql_select 

The following sections define each of the high-level components of a Connect for SQL/XML query:

High-level Component
See...
SQL_value_expression
XML_value_expression
rest_of_sql_select

SQL_value_expression

SQL_value_expression is all level 1 alternatives for a value expression, including the optional AS clause, as defined in the document ISO/IEC 9075-2.

XML_value_expression

The syntax for XML_value_expression is:
XML_value_expression ::= value_expression_primary | 

XML_value_function 

where:
value_expression_primary is a primitive value expression, such as a column reference, a variable reference, a parameter reference, and a literal. The complete definition can be found in the document ISO/IEC 9075-2. Also, value_expression_primary can be the SQL/XML operator XMLAGG. This operator is described in the following section.
XML_value_function is one of the following SQL/XML operators: XMLCONCAT, XMLELEMENT, or XMLFOREST. These operators are described next.

XMLAGG

XMLAGG produces a forest of XML elements from a collection of XML elements. XMLAGG accepts a single XML value expression as its argument, and produces a forest of elements by collecting the XML values that are returned from multiple rows and concatenating the values to make one value. XMLAGG concatenates the values returned from one column of multiple rows, unlike XMLCONCAT, which concatenates the values returned from multiple columns in the same row.
If a returned value is NULL, it is ignored in the result. If all the returned values are NULL, the result is NULL.
Subqueries in SQL/XML are allowed to return only one row; therefore, to return more than one row of values in a SQL/XML subquery, you must use XMLAGG.
Syntax
XMLAGG ::= XMLAGG (XML_value_expression [ORDER BY sort_list] ) 

where:
See "XML_value_expression" for a definition of XML_value_expression.
sort_list is all alternatives for a sort list as defined in the document ISO/IEC 9075-2.
Example 1
The following example produces a list of all employees in the company by producing an element for each employee, ordering the list by the last name, and concatenating the result. The result set will have one column and one row.
SELECT 

 XMLAGG (XMLELEMENT (Name "emp", e.LastName) 

   ORDER BY e.LastName) AS "Employee List"  

FROM Employees e 

Result Set:

Employee List
<emp>Allen</emp><emp>Ayers</emp><emp>Cover</emp> 

... 

<emp>Westbrook</emp><emp>Williams</emp> 

Example 2
The following example demonstrates using XMLAGG in a subquery.
SELECT 

  XMLELEMENT(NAME "emp", e.LastName, 

    XMLELEMENT(Name "projects", 

      (SELECT 

        XMLAGG(XMLELEMENT(NAME "project, p.ProjID)) 

      FROM Projects p 

      WHERE EXISTS ( 

        SELECT * FROM Assignments a 

          WHERE a.EmpId=e.EmpId and a.ProjId=p.ProjId)))) 

          AS "Employees" 

FROM Employees e 

Result Set:

Employees
<emp>Ayers 

  <projects> 

    <project>3</project> 

    <project>6</project> 

</emp> 

... 

<emp>Marshall 

  <projects> 

    <project>1</project> 

    <project>5</project> 

</emp> 

... 

Example 3
The following example uses a Group By clause to group all tasks assigned to each employee and employee project.
SELECT 

  XMLELEMENT (NAME "Employee_Tasks_by_Project", 

    XMLATTRIBUTES (a.EmpId, a.ProjId AS "Project"), 

    XMLAGG (XMLELEMENT (NAME "Task", a.Task) ) )

  AS "Employee Task List"  

FROM Assignments a GROUP BY a.EmpId, a.ProjId 

Result Set:

Employee Task List
<Employee_Tasks_by_Project EmpId="1" Project="1" 

  <Task>Analysis</Task> 

  <Task>Documentation</Task> 

  <Task>Planning</Task> 

  <Task>Testing</Task> 

</Employee_Tasks_by_Project> 

<Employee_Tasks_by_Project EmpId="1" Project="5" 

  <Task>Analysis</Task> 

  <Task>Documentation</Task> 

</Employee_Tasks_by_Project> 

<Employee_Tasks_by_Project EmpId="2" Project="3" 

  <Task>Analysis</Task> 

  <Task>Development</Task> 

</Employee_Tasks_by_Project> 

XMLCONCAT

XMLCONCAT produces a forest of elements by concatenating a list of XML values. XMLCONCAT accepts a list of XML value expressions as its arguments, and produces a forest of elements by concatenating the XML values that are returned from the same row to make one value. XMLCONCAT performs a similar operation as XMLFOREST, except that XMLCONCAT expressions must evaluate to type XML.
If a returned value is NULL, it is ignored in the result. If all the returned values are NULL, the result is NULL.
Syntax
XMLCONCAT ::= XMLCONCAT (XML_value_expression {, 

XML_value_expression} ) 

      
See "XML_value_expression" for a definition of XML_value_expression.
Example 1
The following example produces an XML element for the first and last names, concatenates the result, and creates a one-column result set:
SELECT 

  XMLCONCAT ( 

    XMLELEMENT (NAME "first", e.FirstName),  

    XMLELEMENT (NAME "last", e.LastName)) AS "Result" 

FROM Employees e 

Result Set:

Result
<FirstName>Marc</FirstName><LastName>Marshall</LastName> 

... 

<FirstName>Richard</FirstName><LastName>Gamble</LastName> 

Example 2
The following example produces an XML element for the first and last names, concatenates the result, and creates a two-column result set:
SELECT e.EmpId, 

  XMLCONCAT ( 

    XMLELEMENT (NAME "first", e.FirstName),  

    XMLELEMENT (NAME "last", e.LastName)) AS "Result" 

FROM Employees e 

Result Set:

EmpId
Result
1 

<FirstName>Marc</FirstName><LastName>Marshall</LastName> 

  

... 

20 

<FirstName>Richard</FirstName><LastName>Gamble</LastName> 

XMLELEMENT

XMLELEMENT is an operator that returns an XML element given an XML element name, an optional list of attributes, and an optional list of values as the content of the new element.
Syntax
XMLELEMENT ::= XMLELEMENT (NAME xml_element_name 

[XMLATTRIBUTES (value_expression [AS attribute_name] [{, 

value_expression [AS attribute_name]}] )

[{, SQL_value_expression | XML_value_expression}]) 

where:
xml_element_name is any valid XML element name. This value must be within double quotes.
XMLATTRIBUTES creates a list of XML attributes for the enclosing XML element.
attribute_name is any valid XML attribute name. This value must be within double quotes.
value_expression is all level 1 alternatives for a value expression as defined in the document ISO/IEC 9075-2.
See "SQL_value_expression" for a definition of SQL_value_expression.
See "XML_value_expression" for a definition of XML_value_expression.
Example 1
The following example creates the Employee element with a subelement named name. All values in the LastName column of the Employees table are returned.
SELECT 

  XMLELEMENT(NAME "Employee", 

    XMLELEMENT(NAME "name", e.LastName)) AS "Employee List" 

FROM Employees e 

Result Set:

Employee List
<Employee> 

  <name>Marshall></name> 

</Employee> 

<Employee> 

  <name>Ayers</name> 

</Employee> 

<Employee> 

  <name>Simpson</name> 

</Employee> 

... 

Example 2
The following example demonstrates defining an XML attribute within an XML element.
SELECT 

      XMLELEMENT(NAME "Employee", 

      XMLATTRIBUTES(e.EmpId, e.LastName as "name")) 

FROM Employees e 

Result Set:

Result
<Employee EmpId="1" name="Marshall"/> 

<Employee EmpId="2" name="Ayers"/> 

... 

<Employee EmpId="20" name="Gamble"/> 

XMLFOREST

XMLFOREST produces a forest of XML elements from a given list of arguments. XMLFOREST accepts a list of SQL value expressions as its arguments, and produces an XML element from each value returned. XMLFOREST uses the name of the column as the name of the XML element, unless otherwise specified in an optional AS clause, and uses the value of the SQL value expression as the content of the XML element.
If a value expression evaluates to NULL, then no element is created for that expression. This is unlike XMLELEMENT, where an empty element is created if a value expression evaluates to NULL.
Syntax
XMLFOREST ::= XMLFOREST 

(value_expression [AS forest_element_name] 

[{, value_expression [AS forest_element_name]}] )   

      
where:
value_expression is all level 1 alternatives for a value expression as defined in the document ISO/IEC 9075-2.
forest_element_name is any valid SQL identifier as defined in the document ISO/IEC 9075-2.
Example
The following example produces four elements (EmpID, FirstName, LastName, and Start) from the value expressions e.EmpID, e.FirstName, e.LastName, and e.StartDate, concatenates the elements produced for each employee, and produces one row for each employee in the result set.
SELECT 

  XMLFOREST ( 

    e.EmpId, 

    e.FirstName, 

    e.LastName, 

    e.StartDate AS "Start") AS "EmployeeInformation" 

FROM Employees e 

Result Set:

EmployeeInformation
<EmpId>1</EmpId><FirstName>Marc</FirstName><LastName>Mars

hall</LastName><Start>1994-09-01</Start> 

... 

<EmpId>20</EmpId><FirstName>Richard</FirstName><LastName>

Gamble</LastName><Start>1996-10-01</Start> 

rest_of_sql99_select

This section of a SQL/XML query allows you to specify the database table from which the data is retrieved and the conditions by which the data is retrieved. The From clause defines the database tables and other optional SQL clauses, such as the Where clause, define the conditions.
Syntax
rest_of_sql99_select ::= from_clause [where_clause] 

[having_clause] [group_by_clause] 

      
These clauses are defined in the document ISO/IEC 9075-2.

Executing SQL/XML Queries

The SQL/XML JDBC driver processes the SQL/XML query and sends one or multiple SQL statements through to the database to retrieve the result set.



No comments:

Post a Comment