excel_accounting_schema.sql 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. -- Database schema for Excel-based Finnish accounting system
  2. -- Based on Excelpohja.xlsx structure
  3. -- Monthly accounting entries table
  4. CREATE TABLE IF NOT EXISTS accounting_entries (
  5. id INT AUTO_INCREMENT PRIMARY KEY,
  6. entry_date DATE NOT NULL,
  7. description TEXT NOT NULL,
  8. entry_type ENUM('Tulo', 'Kulu') NOT NULL,
  9. category VARCHAR(100),
  10. tax_free_amount DECIMAL(12,2) DEFAULT 0.00,
  11. vat_percentage DECIMAL(5,2) DEFAULT 0.00,
  12. vat_25_5 DECIMAL(12,2) DEFAULT 0.00,
  13. vat_14 DECIMAL(12,2) DEFAULT 0.00,
  14. vat_10 DECIMAL(12,2) DEFAULT 0.00,
  15. total_amount DECIMAL(12,2) DEFAULT 0.00,
  16. net_amount DECIMAL(12,2) DEFAULT 0.00,
  17. vat_amount DECIMAL(12,2) DEFAULT 0.00,
  18. reference_number VARCHAR(50),
  19. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  20. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  21. INDEX idx_entry_date (entry_date),
  22. INDEX idx_entry_type (entry_type),
  23. INDEX idx_category (category)
  24. );
  25. -- Accounting categories configuration
  26. CREATE TABLE IF NOT EXISTS accounting_categories (
  27. id INT AUTO_INCREMENT PRIMARY KEY,
  28. category_code VARCHAR(20) NOT NULL,
  29. category_name VARCHAR(200) NOT NULL,
  30. category_type ENUM('Tulo', 'Kulu') NOT NULL,
  31. vat_percentage DECIMAL(5,2) DEFAULT 0.00,
  32. is_active BOOLEAN DEFAULT TRUE,
  33. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  34. UNIQUE KEY unique_category_code (category_code)
  35. );
  36. -- Monthly summaries
  37. CREATE TABLE IF NOT EXISTS monthly_summaries (
  38. id INT AUTO_INCREMENT PRIMARY KEY,
  39. year INT NOT NULL,
  40. month INT NOT NULL,
  41. total_income DECIMAL(12,2) DEFAULT 0.00,
  42. total_expenses DECIMAL(12,2) DEFAULT 0.00,
  43. net_result DECIMAL(12,2) DEFAULT 0.00,
  44. vat_payable DECIMAL(12,2) DEFAULT 0.00,
  45. vat_deductible DECIMAL(12,2) DEFAULT 0.00,
  46. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  47. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  48. UNIQUE KEY unique_year_month (year, month)
  49. );
  50. -- Expense categories (from Excel sheet structure)
  51. CREATE TABLE IF NOT EXISTS expense_categories (
  52. id INT AUTO_INCREMENT PRIMARY KEY,
  53. category_code VARCHAR(50) NOT NULL,
  54. category_name VARCHAR(200) NOT NULL,
  55. parent_id INT NULL,
  56. description TEXT,
  57. is_active BOOLEAN DEFAULT TRUE,
  58. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  59. FOREIGN KEY (parent_id) REFERENCES expense_categories(id) ON DELETE SET NULL,
  60. UNIQUE KEY unique_category_code (category_code)
  61. );
  62. -- Income categories (from Excel sheet structure)
  63. CREATE TABLE IF NOT EXISTS income_categories (
  64. id INT AUTO_INCREMENT PRIMARY KEY,
  65. category_code VARCHAR(50) NOT NULL,
  66. category_name VARCHAR(200) NOT NULL,
  67. parent_id INT NULL,
  68. description TEXT,
  69. is_active BOOLEAN DEFAULT TRUE,
  70. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  71. FOREIGN KEY (parent_id) REFERENCES income_categories(id) ON DELETE SET NULL,
  72. UNIQUE KEY unique_category_code (category_code)
  73. );
  74. -- Insert default expense categories
  75. INSERT IGNORE INTO expense_categories (category_code, category_name, description) VALUES
  76. ('333', 'Ostot ja ulkopuoliset palvelut', 'Purchases and external services'),
  77. ('334', 'Henkilöstökulut', 'Personnel costs'),
  78. ('335', 'Poistot, edustuskulut ja vuokrat', 'Depreciation, representation and rental costs'),
  79. ('336', 'Muut vähennyskelpoiset kulut', 'Other deductible expenses'),
  80. ('337', 'Rahoituskulut', 'Financing costs'),
  81. ('341', 'Varausten muutokset', 'Asset changes'),
  82. ('343', 'Varausten myynnit', 'Asset sales'),
  83. ('344', 'Matkakulut', 'Travel expenses'),
  84. ('344 Matka-auto', 'Matkakulut - Car', 'Car travel expenses'),
  85. ('344 Ajoneuvo', 'Matkakulut - Vehicle', 'Vehicle travel expenses'),
  86. ('344 Muu', 'Matkakulut - Other', 'Other travel expenses'),
  87. ('344 Kokous', 'Matkakulut - Meeting', 'Meeting travel expenses'),
  88. ('346', 'Muut kulut', 'Other expenses'),
  89. ('349', 'Poistot', 'Depreciation'),
  90. ('353', 'Varainsiirrot', 'Asset transfers'),
  91. ('354', 'Vähennyskelvottomat kulut', 'Non-deductible expenses'),
  92. ('365', 'Vakuutukset', 'Insurance'),
  93. ('366', 'Verot ja maksut', 'Taxes and fees'),
  94. ('367', 'Yhtiölainat ja muut rahoituskulut', 'Company loans and other financing costs');
  95. -- Insert default income categories
  96. INSERT IGNORE INTO income_categories (category_code, category_name, description) VALUES
  97. ('300', 'Myynti - EU 0 %', 'Sales - EU 0% VAT'),
  98. ('301', 'Myynti - Muut maat', 'Sales - Other countries'),
  99. ('302', 'Myynti - Käänteinen vero', 'Sales - Reverse VAT'),
  100. ('303', 'Myynti - Suomi 0 %', 'Sales - Finland 0% VAT'),
  101. ('308', 'Myyntitavarat', 'Sales of fixed assets'),
  102. ('309', 'Osuuskorvaukset', 'Share compensation'),
  103. ('310', 'Korkotulot ja muut rahoitustuotot', 'Interest income and other financial income'),
  104. ('311', 'Voitonjako', 'Profit distribution'),
  105. ('312', 'Sijoitustoiminnan tuotot', 'Investment income'),
  106. ('313', 'Apurahat ja muut avustukset', 'Grants and other subsidies'),
  107. ('314', 'Muu tuotto', 'Other income');
  108. -- Insert accounting categories
  109. INSERT IGNORE INTO accounting_categories (category_code, category_name, category_type, vat_percentage) VALUES
  110. ('333', 'Ostot ja ulkopuoliset palvelut', 'Kulu', 24.00),
  111. ('334', 'Henkilöstökulut', 'Kulu', 0.00),
  112. ('335', 'Poistot, edustuskulut ja vuokrat', 'Kulu', 24.00),
  113. ('336', 'Muut vähennyskelpoiset kulut', 'Kulu', 24.00),
  114. ('337', 'Rahoituskulut', 'Kulu', 0.00),
  115. ('341', 'Varausten muutokset', 'Kulu', 0.00),
  116. ('343', 'Varausten myynnit', 'Kulu', 0.00),
  117. ('344', 'Matkakulut', 'Kulu', 24.00),
  118. ('346', 'Muut kulut', 'Kulu', 24.00),
  119. ('349', 'Poistot', 'Kulu', 0.00),
  120. ('353', 'Varainsiirrot', 'Kulu', 0.00),
  121. ('354', 'Vähennyskelvottomat kulut', 'Kulu', 0.00),
  122. ('365', 'Vakuutukset', 'Kulu', 24.00),
  123. ('366', 'Verot ja maksut', 'Kulu', 0.00),
  124. ('367', 'Yhtiölainat ja muut rahoituskulut', 'Kulu', 0.00),
  125. ('300', 'Myynti - EU 0 %', 'Tulo', 0.00),
  126. ('301', 'Myynti - Muut maat', 'Tulo', 0.00),
  127. ('302', 'Myynti - Käänteinen vero', 'Tulo', 0.00),
  128. ('303', 'Myynti - Suomi 0 %', 'Tulo', 0.00),
  129. ('308', 'Myyntitavarat', 'Tulo', 0.00),
  130. ('309', 'Osuuskorvaukset', 'Tulo', 0.00),
  131. ('310', 'Korkotulot ja muut rahoitustuotot', 'Tulo', 0.00),
  132. ('311', 'Voitonjako', 'Tulo', 0.00),
  133. ('312', 'Sijoitustoiminnan tuotot', 'Tulo', 0.00),
  134. ('313', 'Apurahat ja muut avustukset', 'Tulo', 0.00),
  135. ('314', 'Muu tuotto', 'Tulo', 0.00);