SQL Server 2022 Enhancements to Batch Mode Processing: A Comprehensive Guide

In the world of data analytics and processing, efficiency and speed are crucial. SQL Server 2022 brings significant enhancements to batch mode processing, making data operations faster and more efficient. In this blog, we’ll explore these enhancements using the JBDB database and demonstrate their benefits through a detailed business use case. Let’s dive in! πŸš€

Business Use Case: Optimizing Financial Reporting

Imagine a financial institution, “FinanceCorp,” that handles large volumes of transactional data daily. The company’s data analysts often run complex queries to generate reports on various financial metrics, including daily transactions, average transaction amounts, and customer spending patterns. However, these queries often take a long time to execute due to the sheer volume of data.

With SQL Server 2022’s enhancements to batch mode processing, FinanceCorp aims to optimize query performance, reduce execution times, and provide near real-time insights. This improvement will enhance decision-making and provide a competitive edge in the financial industry.

Understanding Batch Mode Processing

Batch mode processing is a technique where rows of data are processed in batches, rather than one at a time. This method significantly reduces CPU usage and increases query performance, particularly for analytical workloads. SQL Server 2022 introduces several key enhancements to batch mode processing:

  1. Batch Mode on Rowstore: Previously, batch mode processing was limited to columnstore indexes. SQL Server 2022 extends batch mode processing to rowstore tables, allowing a broader range of queries to benefit from this optimization.
  2. Improved Parallelism: SQL Server 2022 improves parallelism in batch mode processing, allowing more efficient use of system resources and faster query execution.
  3. Enhanced Memory Grant Feedback: The new version provides better memory grant feedback, reducing the risk of excessive memory allocation and improving overall query performance.

Demo: Batch Mode Processing Enhancements with JBDB Database

Let’s see these enhancements in action using the JBDB database. We’ll demonstrate how batch mode processing can optimize query performance.

Step 1: Setting Up the JBDB Database

First, ensure the JBDB database is set up with the necessary tables and data. Here’s a sample setup:

CREATE DATABASE JBDB;
GO

USE JBDB;
GO

CREATE TABLE Transactions (
    TransactionID INT PRIMARY KEY,
    CustomerID INT,
    TransactionDate DATE,
    TransactionAmount DECIMAL(18, 2)
);
GO

-- Insert sample data
INSERT INTO Transactions VALUES 
    (1, 101, '2024-07-01', 100.00), 
    (2, 102, '2024-07-02', 150.00), 
    (3, 103, '2024-07-03', 200.00), 
    (4, 101, '2024-07-04', 250.00),
    (5, 102, '2024-07-05', 300.00);
GO

Step 2: Enabling Batch Mode on Rowstore

SQL Server 2022 allows batch mode processing on rowstore tables without requiring columnstore indexes. Let’s see how this affects query performance:

-- Traditional row-by-row processing
SELECT 
    CustomerID,
    AVG(TransactionAmount) AS AverageAmount
FROM Transactions
GROUP BY CustomerID;
GO

-- Batch mode processing on rowstore
SELECT 
    CustomerID,
    AVG(TransactionAmount) AS AverageAmount
FROM Transactions
GROUP BY CustomerID
OPTION (USE HINT('ENABLE_PARALLEL_PLAN_PREFERENCE'));
GO

The USE HINT('ENABLE_PARALLEL_PLAN_PREFERENCE') hint forces the query to use parallelism, demonstrating the enhanced parallelism in batch mode.

Step 3: Observing Improved Memory Grant Feedback

SQL Server 2022’s improved memory grant feedback optimizes memory allocation for queries. This feature helps prevent excessive memory allocation, which can slow down query performance.

-- Example query with potential memory grant feedback
SELECT 
    COUNT(*)
FROM Transactions
WHERE TransactionAmount > 100.00;
GO

Run this query multiple times and observe the memory grant adjustments in the query plan.

Additional Example Queries: Exploring Batch Mode Processing Enhancements

Let’s explore more scenarios where batch mode processing can significantly improve query performance:

Example 1: Calculating Total Transactions per Day

SELECT 
    TransactionDate,
    SUM(TransactionAmount) AS TotalAmount
FROM Transactions
GROUP BY TransactionDate
ORDER BY TransactionDate;
GO

This query calculates the total transaction amount per day, which can benefit from batch mode processing due to its grouping and aggregation operations.

Example 2: Identifying High-Value Transactions

SELECT 
    TransactionID,
    CustomerID,
    TransactionAmount
FROM Transactions
WHERE TransactionAmount > 200.00
OPTION (USE HINT('ENABLE_PARALLEL_PLAN_PREFERENCE'));
GO

Batch mode processing can speed up the filtering of high-value transactions, providing quick insights into significant purchases.

Example 3: Analyzing Customer Spending Patterns

SELECT 
    CustomerID,
    COUNT(TransactionID) AS TotalTransactions,
    SUM(TransactionAmount) AS TotalSpent
FROM Transactions
GROUP BY CustomerID
ORDER BY TotalSpent DESC;
GO

This query analyzes customer spending patterns, which can be critical for targeted marketing and personalized services. Batch mode processing enhances performance by efficiently handling the aggregation of transaction data.

Example 4: Calculating Monthly Transaction Averages

SELECT 
    YEAR(TransactionDate) AS Year,
    MONTH(TransactionDate) AS Month,
    AVG(TransactionAmount) AS AverageMonthlyAmount
FROM Transactions
GROUP BY YEAR(TransactionDate), MONTH(TransactionDate)
ORDER BY Year, Month;
GO

Calculating monthly averages involves aggregating data over time periods, making it an ideal candidate for batch mode processing.

Example 5: Detecting Transaction Spikes

WITH DailyTotals AS (
    SELECT 
        TransactionDate,
        SUM(TransactionAmount) AS TotalAmount
    FROM Transactions
    GROUP BY TransactionDate
)
SELECT 
    TransactionDate,
    TotalAmount,
    LAG(TotalAmount) OVER (ORDER BY TransactionDate) AS PreviousDayAmount,
    (TotalAmount - LAG(TotalAmount) OVER (ORDER BY TransactionDate)) AS DayOverDayChange
FROM DailyTotals
ORDER BY TransactionDate;
GO

This query uses window functions to detect day-over-day changes in transaction amounts, helping identify spikes in transactions. Batch mode processing optimizes the handling of these calculations.

Business Impact of Batch Mode Processing Enhancements

For FinanceCorp, the enhancements to batch mode processing mean faster report generation, reduced CPU usage, and more efficient memory utilization. This improvement leads to:

  • Faster Insights: Financial analysts can generate reports in a fraction of the time, allowing for quicker decision-making.
  • Cost Savings: Improved efficiency reduces the need for expensive hardware upgrades and lowers operational costs.
  • Competitive Advantage: Near real-time insights provide a strategic advantage in the highly competitive financial sector.

Conclusion

SQL Server 2022’s enhancements to batch mode processing offer substantial benefits, particularly for businesses handling large volumes of data. By leveraging these improvements, organizations like FinanceCorp can achieve faster query performance, optimize resource usage, and gain a competitive edge. Whether you’re in finance, healthcare, or any data-driven industry, these enhancements can significantly impact your data processing capabilities. 🌟

Stay tuned for more insights and detailed technical guides on the latest features in SQL Server 2022! πŸŽ‰

For more tutorials and tips on SQL Server, including performance tuning and database management, be sure to check out our JBSWiki YouTube channel.

Thank You,
Vivek Janakiraman

Disclaimer:
The views expressed on this blog are mine alone and do not reflect the views of my company or anyone else. All postings on this blog are provided β€œAS IS” with no warranties, and confers no rights.

SQL Server 2022 and Big Data Clusters: A Comprehensive Guide

SQL Server 2022 brings transformative enhancements to Big Data Clusters (BDC), making it a powerful platform for managing and analyzing large-scale data across diverse sources. This exhaustive blog explores the latest updates and features in SQL Server 2022 Big Data Clusters, including data virtualization, big data analytics, and the unified data platform. We’ll also delve into a step-by-step implementation guide and provide a detailed business use case, demonstrating the practical applications and benefits of these advancements.


Business Use Case: Financial Services and Risk Analysis πŸ’Ό

Scenario: A global financial services firm operates in multiple markets, offering a wide range of services including investment banking, asset management, and retail banking. The firm handles vast amounts of data from various sources, including transaction data, market data, customer profiles, and external economic indicators. The firm aims to leverage big data analytics to enhance risk assessment, detect fraudulent activities, and optimize investment strategies.

Challenges:

  1. Data Silos: The firm deals with data stored across multiple, isolated systems, including relational databases, NoSQL databases, and data lakes. This fragmentation hinders comprehensive analysis and decision-making.
  2. Scalability and Performance: As the firm’s data volumes grow, it faces challenges in scaling its infrastructure and maintaining performance during complex analytics operations.
  3. Real-Time Analytics Needs: The firm requires real-time insights to respond swiftly to market changes, detect anomalies, and make informed investment decisions.
  4. Data Security and Compliance: Handling sensitive financial data necessitates robust security measures and compliance with regulatory standards, such as GDPR and SOX.

SQL Server 2022 Big Data Clusters provide an integrated solution that addresses these challenges, enabling the firm to consolidate data, perform advanced analytics, and derive actionable insights.


Key Enhancements in SQL Server 2022 Big Data Clusters 🌐

1. Data Virtualization 🧩

Overview: Data virtualization is a core feature of SQL Server 2022 Big Data Clusters, allowing organizations to integrate data from disparate sources without the need for data replication or movement. This capability is particularly beneficial for financial services firms, where data often resides in various formats and systems.

Technical Details:

  • PolyBase Integration: PolyBase serves as the cornerstone of data virtualization in SQL Server 2022. It allows querying data from external sources such as Oracle, MongoDB, Hadoop, and other SQL Servers as if they were part of the local SQL Server database.
  • Data Federation: The data federation feature enables seamless querying across multiple data sources, providing a unified view of data. This is achieved through the use of external tables and data source connectors.
  • Performance Optimization: Enhancements in query performance and data retrieval speeds, thanks to optimizations in data source connectors and query execution plans, make data virtualization more efficient.

Business Impact:

  • Comprehensive Risk Analysis: The financial services firm can aggregate data from various systems, including market feeds, customer transactions, and external economic indicators, to create a comprehensive view of financial risks. This integrated approach enables more accurate and timely risk assessments.
  • Reduced Data Redundancy: By leveraging data virtualization, the firm can avoid the costs and complexities associated with data duplication and storage, as there is no need to physically consolidate data from different sources.

2. Enhanced Big Data Analytics πŸ“Š

Overview: SQL Server 2022 Big Data Clusters enhance the capabilities for big data analytics, allowing organizations to process and analyze large datasets with advanced tools and technologies.

Technical Details:

  • Apache Spark Integration: Apache Spark is integrated into the Big Data Clusters environment, providing a powerful engine for large-scale data processing and analytics. Spark supports various workloads, including batch processing, streaming analytics, and machine learning.
  • Data Science and Machine Learning Tools: The platform includes built-in support for popular data science languages such as R and Python, and tools like Jupyter Notebooks. This integration facilitates the development and deployment of machine learning models and advanced analytical workflows.
  • Scalable Data Processing: Big Data Clusters are designed to scale out horizontally, accommodating growing data volumes and complex computational tasks. This scalability is crucial for handling high-throughput data streams and intensive analytics workloads.

Business Impact:

  • Advanced Fraud Detection: The firm can leverage machine learning models to identify patterns and anomalies in transaction data, helping to detect and prevent fraudulent activities in real-time.
  • Predictive Analytics for Investment Strategies: By using predictive models, the firm can forecast market trends and optimize investment portfolios, enhancing decision-making and maximizing returns.
  • Customer Segmentation and Personalization: Advanced analytics enable the firm to segment customers based on behavior and preferences, allowing for targeted marketing and personalized financial services.

3. Unified Data Platform πŸ”—

Overview: SQL Server 2022 Big Data Clusters offer a unified data platform that integrates data storage, data management, and analytics. This platform provides a cohesive environment for building and deploying data-driven applications.

Technical Details:

  • Kubernetes-based Architecture: The platform is built on Kubernetes, an open-source container orchestration system. This architecture offers flexibility, scalability, and ease of management, making it ideal for deploying and managing big data applications.
  • Multi-Workload Support: The platform supports multiple workloads, including transactional, analytical, and data science workloads, within a single environment. This integration facilitates the seamless transition of data between different stages of the analytics pipeline.
  • Security and Compliance: SQL Server 2022 Big Data Clusters include robust security features, such as encryption at rest and in transit, role-based access control (RBAC), and auditing capabilities. These features help organizations meet stringent regulatory requirements and protect sensitive data.

Business Impact:

  • Streamlined Operations: The unified data platform simplifies data management, reducing the operational burden on IT teams and enabling them to focus on delivering value-added services. This is particularly important for large financial institutions with complex data ecosystems.
  • Enhanced Security and Compliance: The platform’s built-in security features ensure the protection of sensitive financial data, helping the firm to comply with regulations such as GDPR, SOX, and PCI DSS. This compliance is critical for maintaining customer trust and avoiding legal penalties.

Implementation Guide: Setting Up SQL Server 2022 Big Data Clusters πŸ› οΈ

Implementing SQL Server 2022 Big Data Clusters involves several key steps, from preparing the infrastructure to deploying and configuring the cluster components. This guide provides a detailed roadmap to help you get started.

Step 1: Prepare the Environment 🌱

  1. Infrastructure Setup:
    • Ensure you have the necessary hardware and network infrastructure to support Big Data Clusters. This includes high-performance storage solutions, sufficient memory, and robust network connectivity.
    • Consider using a cloud-based Kubernetes service, such as Azure Kubernetes Service (AKS), for scalability and ease of management. This option provides a managed environment that simplifies cluster deployment and maintenance.
  2. Install Kubernetes:
    • Set up a Kubernetes cluster as the foundation for Big Data Clusters. This involves configuring the control plane and worker nodes, as well as setting up necessary Kubernetes components like etcd, kubelet, and kube-proxy.
    • Use tools like kubectl and Helm to manage Kubernetes resources and deployments.

Step 2: Deploy Big Data Clusters πŸš€

  1. Big Data Cluster Deployment:
    • Use the SQL Server Big Data Clusters deployment wizard or command-line tools to deploy the cluster. The deployment process includes setting up the SQL Server master instance, data pools, storage pools, and compute pools.
    • Configure cluster components such as the control plane, data plane, and application services. The control plane manages cluster operations, while the data plane handles data storage and processing.
  2. Configure Data Virtualization:
    • Set up PolyBase to enable data virtualization. This involves configuring PolyBase services, creating external data sources, and defining external tables.
    • Connect to external data sources, such as SQL Server, Oracle, Hadoop, and MongoDB, using PolyBase connectors. This setup allows you to query and integrate data from various sources seamlessly.

Step 3: Set Up Analytics and Data Science Workflows πŸ”¬

  1. Deploy Apache Spark:
    • Install and configure Apache Spark within the Big Data Cluster. This includes setting up Spark clusters, configuring Spark workloads, and integrating with other data services.
    • Set up Spark jobs for data processing, machine learning, and analytics. Use tools like Apache Zeppelin or Jupyter Notebooks for interactive data exploration and analysis.
  2. Data Science Tools:
    • Integrate R and Python environments for data science and machine learning. This involves installing necessary packages and libraries, setting up development environments, and configuring access to data sources.
    • Deploy Jupyter Notebooks or other interactive data science tools to facilitate the development and testing of data science models. These tools provide a collaborative environment for data scientists and analysts.

Step 4: Manage and Secure the Cluster πŸ”’

  1. Security Configuration:
    • Implement role-based access control (RBAC) to manage user permissions and access to data and services within the cluster. Define roles and assign permissions based on the principle of least privilege.
    • Enable data encryption at rest and in transit to protect sensitive data. Configure SSL/TLS for secure communication between cluster components and data sources.
  2. Monitoring and Maintenance:
    • Set up monitoring tools to track the health, performance, and utilization of the Big Data Cluster. Use tools like Prometheus and Grafana for real-time monitoring and alerting.
    • Regularly update and maintain the cluster to ensure optimal performance and security. This includes applying software patches, updating Kubernetes and SQL Server components, and performing regular backups.

Conclusion: Unlocking the Power of Big Data with SQL Server 2022 Big Data Clusters 🌟

SQL Server 2022 Big Data Clusters offer a comprehensive solution for managing and analyzing large-scale data. The platform’s advanced features, including data virtualization, enhanced big data analytics, and a unified data platform, empower organizations to overcome the challenges of data integration, scalability, and real-time analytics.

For the financial services firm in our use case, these capabilities translate into more effective risk management, fraud detection, and investment optimization. By leveraging advanced analytics and machine learning, the firm can gain deeper insights into market trends, customer behavior, and potential risks, enabling data-driven decision-making and a competitive edge.

SQL Server 2022 Big Data Clusters are not just for financial services; they can be applied across various industries, including healthcare, retail, manufacturing, and more. Whether you’re a data scientist, IT professional, or business leader, this platform offers the tools and technologies needed to unlock the full potential of your data. 🌐

Stay tuned for more insights into SQL Server 2022 features and how they can transform your data strategy. πŸš€

For more tutorials and tips on SQL Server, including performance tuning and database management, be sure to check out our JBSWiki YouTube channel.

Thank You,
Vivek Janakiraman

Disclaimer:
The views expressed on this blog are mine alone and do not reflect the views of my company or anyone else. All postings on this blog are provided β€œAS IS” with no warranties, and confers no rights.

SQL Server 2022 Enhancements in SQL Server Analysis Services (SSAS)

SQL Server 2022 marks a significant leap forward in the capabilities of SQL Server Analysis Services (SSAS), offering a plethora of enhancements that streamline analytical processing, improve performance, and enhance data modeling capabilities. This detailed exploration will cover these improvements, their technical underpinnings, and how they translate into tangible business benefits, using a retail chain as a practical example.


Business Use Case: Retail Chain Analytics 🏬

Scenario: A large retail chain operates hundreds of outlets across multiple regions, both online and offline. The company utilizes SSAS for comprehensive data analysis, focusing on inventory management, sales performance, customer behavior, and marketing effectiveness. By leveraging SSAS, the company aims to gain actionable insights, optimize operations, and enhance customer engagement.

Challenges: The retail chain faces several challenges, including:

  1. Managing and analyzing vast amounts of data from diverse sources.
  2. Ensuring data freshness and availability for real-time decision-making.
  3. Scaling analytical capabilities to accommodate growing data volumes and user demand.
  4. Securing sensitive customer and sales data in compliance with regulatory standards.

Let’s explore how the new features in SQL Server 2022 SSAS address these challenges and drive business value.


Key Enhancements in SQL Server 2022 SSAS πŸš€

1. Improved Tabular Model Performance 🏎️

Technical Details:

  • Optimized Storage Engine: SQL Server 2022 SSAS introduces optimizations in the storage engine, enabling faster data compression and more efficient data retrieval. The improved VertiPaq engine utilizes advanced encoding and compression techniques, reducing memory usage and improving query performance.
  • Parallel Processing: Enhanced support for parallel processing allows for simultaneous data loads and query executions, maximizing CPU utilization and speeding up data refreshes and user queries.

Business Impact:

  • Faster Data Insights: For the retail chain, this means that complex sales and inventory data can be processed more quickly, providing near real-time insights. For instance, the company can analyze daily sales trends across different regions and adjust marketing strategies on the fly.
  • Increased Efficiency: The IT team can optimize data models without compromising performance, allowing for more complex and granular analysis, such as segmenting customers by purchase behavior or analyzing the effectiveness of promotions.

2. Enhanced DirectQuery Performance ⚑

Technical Details:

  • Improved Query Optimizer: The DirectQuery mode in SSAS now benefits from an improved query optimizer, which generates more efficient execution plans for complex queries. This reduces the time taken to retrieve data from underlying data sources.
  • Optimized Data Source Connections: SQL Server 2022 SSAS enhances the connectivity with various data sources, including SQL Server, Azure SQL Database, and other databases. This includes better handling of network latency and improved data retrieval efficiency.

Business Impact:

  • Real-Time Analytics: The retail chain can leverage DirectQuery to analyze live data, such as monitoring real-time sales across stores during promotional events. This enables the company to make immediate adjustments, such as reallocating stock to high-demand locations or altering marketing messages.
  • Flexible Reporting: Analysts can create dynamic reports that reflect the most current data, without waiting for data imports or refreshes. This is particularly useful for time-sensitive analyses, like tracking the impact of a sudden market trend or competitor activity.

3. Improved Data Modeling Capabilities πŸ“Š

Technical Details:

  • Calculated Tables: SQL Server 2022 SSAS introduces calculated tables, allowing users to define new tables based on DAX expressions. This feature enables more complex data transformations and the creation of intermediate data sets for analysis.
  • Enhanced Hierarchies and Relationships: The updated SSAS supports more complex data relationships and hierarchies, providing greater flexibility in modeling multi-dimensional data. This includes improved support for many-to-many relationships and bi-directional filtering.

Business Impact:

  • Richer Analytical Models: The retail chain can build more sophisticated models that incorporate complex customer relationships, such as analyzing cross-channel purchase behavior (in-store vs. online) or tracking customer loyalty across multiple touchpoints.
  • Custom Calculations: The ability to use calculated tables and advanced DAX expressions allows for custom metrics and KPIs. For example, the company can calculate customer lifetime value (CLV) or assess the impact of a loyalty program on repeat purchases.

4. Scalability Improvements πŸ“ˆ

Technical Details:

  • Memory and Storage Optimization: SQL Server 2022 SSAS introduces enhancements in memory and storage management, including more efficient use of available hardware resources. This allows for larger models and more data to be processed and stored within SSAS.
  • Improved Processing Capabilities: The processing engine has been optimized to handle larger data volumes and more complex calculations, enabling the system to scale effectively as data and user demand grow.

Business Impact:

  • Handling Growing Data Volumes: As the retail chain expands and accumulates more data, SSAS can scale to accommodate this growth. This ensures that performance remains consistent even during peak periods, such as holiday shopping seasons.
  • Supporting More Users: The enhanced scalability allows the system to support a growing number of concurrent users, including analysts, managers, and external partners. This democratizes access to data, fostering a data-driven culture across the organization.

5. Enhanced Security and Compliance πŸ”’

Technical Details:

  • Role-Based Access Control (RBAC): SSAS in SQL Server 2022 provides more granular control over user permissions, allowing administrators to define roles with specific access rights to data and features within the model.
  • Data Encryption: Support for encryption at rest ensures that sensitive data stored within SSAS models is protected, meeting compliance requirements such as GDPR and CCPA.

Business Impact:

  • Data Security: For the retail chain, safeguarding customer data is paramount. The enhanced security features ensure that only authorized personnel can access sensitive information, reducing the risk of data breaches.
  • Compliance Assurance: By adhering to stringent data protection standards, the company can avoid potential legal and financial penalties, as well as maintain customer trust.

6. Integration with Azure Services ☁️

Technical Details:

  • Azure Synapse Analytics Integration: SQL Server 2022 SSAS can seamlessly integrate with Azure Synapse Analytics, providing a powerful platform for data warehousing and big data analytics. This integration supports hybrid architectures, allowing data to be processed both on-premises and in the cloud.
  • Azure Data Lake and Machine Learning Integration: The integration with Azure Data Lake enables efficient storage and retrieval of large datasets, while Azure Machine Learning integration facilitates the incorporation of machine learning models into analytical workflows.

Business Impact:

  • Advanced Analytics: The retail chain can leverage Azure’s advanced analytics capabilities to perform predictive analysis, such as forecasting sales trends or identifying potential churn risks among customers. These insights can be fed back into SSAS for reporting and decision-making.
  • Hybrid Cloud Flexibility: The ability to integrate with Azure services allows the company to adopt a hybrid cloud strategy, balancing on-premises and cloud resources to optimize costs and performance. This flexibility is crucial for scaling analytics as the business grows.

Conclusion: Empowering Better Decision-Making with SQL Server 2022 SSAS 🎯

SQL Server 2022 SSAS offers an impressive array of enhancements that significantly boost the analytical capabilities of organizations. For the retail chain in our use case, these improvements translate into faster, more accurate insights, enabling the company to respond swiftly to market changes and optimize operations across the board.

The integration with Azure services extends the power of SSAS, offering scalable, advanced analytics solutions that can handle the most demanding data workloads. Whether it’s through real-time data analysis, sophisticated data modeling, or enhanced security measures, SQL Server 2022 SSAS empowers organizations to make data-driven decisions with confidence.

In a data-driven world, staying ahead means leveraging the latest technologies to extract maximum value from your data. SQL Server 2022 SSAS is a key tool in this endeavor, offering unparalleled performance, flexibility, and security. 🌟

Stay tuned for more insights into SQL Server 2022 features and how they can transform your business operations. πŸš€

For more tutorials and tips on SQL Server, including performance tuning and database management, be sure to check out our JBSWiki YouTube channel.

Thank You,
Vivek Janakiraman

Disclaimer:
The views expressed on this blog are mine alone and do not reflect the views of my company or anyone else. All postings on this blog are provided β€œAS IS” with no warranties, and confers no rights.