Wednesday, March 6, 2013
Tuesday, March 5, 2013
Query Optimization ...........1
- ----- This post is excerpt of Pinal Dave 's article published on www.sqlauthority.com ----
- ----- Try to get causes of each sentence -----
- Notes prepared for “Good, Better and Best Programming Techniques” meeting
- Do not prefix stored procedure with SP_ prefix. As they are first searched in master database, before it is searched in any other database.
- Always install latest server packs and security packs.
- Make sure your SQL Server runs on optimal hardware. If your operating system supports 64 bit SQL Server, install 64 bit SQL Server on it. Raid 10 Array.
- Reduce Network Traffic by using Stored Procedure. Return only required result set from database. If application needs paging it should have done in SQL Server instead of at application level.
- After running query check Actual Execution Plan for cost of the query. Query can be analyzed in Database Engine Tuning Advisor.
- Use User Defined Functions sparsely, use Stored Procedures instead.
- Stored Procedure can achieve all the tasks UDF can do. SP provides much more features than UDFs.
- Test system with realistic data rather than sample data. Realistic data provides better scenario for testing and reveals problems with real system before it goes to production.
- Do not use SELECT *, use proper column names to decrease network traffic and fewer locks on table.
- Avoid Cursors as it results in performance degradation. Sub Query, derived tables, CTE can perform same operation.
- Reduces the use of nullable columns.
- NULL columns consumes an extra byte on each column used as well as adds overhead in queries. Also NULL is not good for logic development for programmers.
- Reduce deadlocks using query hints and proper logic of order in columns.
- Normalized database always increases scalability and stability of the system. Do not go over 3rd normal form as it will adversely affect performance.
- Use WHERE clauses to compare assertive logic. Use IN rather than NOT IN even though IN will require more value to specify in clause.
- BLOBS must be stored filesystem and database should have path to them only. If path is common stored them in application variable and append with filename from the BLOBColumnName.
- Always perform referential integrity checks and data validations using constraints such as the foreign key and check constraints.
- SQL Server optimizer will use an index scan if the ORDER BY clause is on an indexed column.
- Stored Procedure should return same numbers of resultset and same columns in any input parameters. Result Set of Stored Procedure should be deterministic.
- Index should be created on highly selective columns, which are used in JOINS, WHERE and ORDER BY clause.
- Format SQL Code. Make it readable. Wrap it.
- Use Column name in ORDER BY clause instead of numbers.
- Do not use TEXT or NTEXT if possible. In SQL Server 2005 use VARCHAR(MAX) or NVARCHAR(MAX).
- Join tables in order that they always perform the most restrictive search first to filter out the maximum number of rows in the early phases of a multiple table join.
- Remember to SET NOCOUNT ON at the beginning of your SQL bataches, stored procedures, triggers to avoid network traffic. This will also reduct the chances of error on linked server.
- Do not use temp tables use CTE or Derived tables instead.
- Always take backup of all the data.
- Never ever work on production server.
- Ask someone for help if you need it. We all need to learn.
Saturday, March 2, 2013
What is JNDI
The Java Naming and Directory Interface (JNDI) is an application
programming interface (API) for accessing different kinds of naming and
directory services. JNDI is not specific to a particular naming or
directory service, it can be used to access many different kinds of
systems including file systems; distributed objects systems like CORBA,
Java RMI, and EJB; and directory services like LDAP, Novell NetWare, and
NIS+.
JNDI is similar to JDBC in that they are both Object-Oriented Java
APIs that provide a common abstraction for accessing services from
different vendors. While JDBC can be used to access a variety of
relational databases, JNDI can be used to access a variety of of naming
and directory services.
check http://www.jguru.com/faq/view.jsp?EID=10852
To know JNDI one should know first what is Naming and Directory Service.
Subscribe to:
Posts (Atom)