setup_database.sql 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543
  1. CREATE DATABASE IF NOT EXISTS inventory_db;
  2. USE inventory_db;
  3. CREATE TABLE IF NOT EXISTS items (
  4. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  5. name VARCHAR(255) NOT NULL,
  6. description TEXT,
  7. serial_number VARCHAR(100) NULL,
  8. picture VARCHAR(255) NULL,
  9. quantity INT(11) NOT NULL DEFAULT 0,
  10. price DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  11. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  12. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
  13. );
  14. CREATE TABLE IF NOT EXISTS rental_prices (
  15. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  16. item_id INT(11) NOT NULL,
  17. client_id INT(11) NULL,
  18. start_date DATE NOT NULL,
  19. end_date DATE NOT NULL,
  20. daily_price DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  21. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  22. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  23. FOREIGN KEY (item_id) REFERENCES items(id) ON DELETE CASCADE,
  24. FOREIGN KEY (client_id) REFERENCES clients(id) ON DELETE SET NULL,
  25. INDEX idx_item_dates (item_id, start_date, end_date)
  26. );
  27. CREATE TABLE IF NOT EXISTS attachments (
  28. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  29. item_id INT(11) NOT NULL,
  30. filename VARCHAR(255) NOT NULL,
  31. original_name VARCHAR(255) NOT NULL,
  32. file_type ENUM('receipt', 'warranty', 'other') NOT NULL DEFAULT 'other',
  33. file_path VARCHAR(255) NOT NULL,
  34. file_size INT(11) NOT NULL,
  35. mime_type VARCHAR(100) NOT NULL,
  36. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  37. FOREIGN KEY (item_id) REFERENCES items(id) ON DELETE CASCADE,
  38. INDEX idx_item_type (item_id, file_type)
  39. );
  40. CREATE TABLE IF NOT EXISTS clients (
  41. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  42. company_name VARCHAR(255) NULL,
  43. y_tunnus VARCHAR(255) NULL,
  44. first_name VARCHAR(100) NOT NULL,
  45. last_name VARCHAR(100) NOT NULL,
  46. email VARCHAR(255) NOT NULL UNIQUE,
  47. phone VARCHAR(20) NULL,
  48. address VARCHAR(255) NULL,
  49. city VARCHAR(100) NULL,
  50. state VARCHAR(100) NULL,
  51. postal_code VARCHAR(20) NULL,
  52. country VARCHAR(100) NULL,
  53. notes TEXT NULL,
  54. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  55. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  56. INDEX idx_email (email),
  57. INDEX idx_name (last_name, first_name),
  58. INDEX idx_y_tunnus (y_tunnus)
  59. );
  60. CREATE TABLE IF NOT EXISTS contact_persons (
  61. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  62. client_id INT(11) NOT NULL,
  63. first_name VARCHAR(100) NOT NULL,
  64. last_name VARCHAR(100) NOT NULL,
  65. email VARCHAR(255) NULL,
  66. phone VARCHAR(20) NULL,
  67. position VARCHAR(100) NULL,
  68. is_primary BOOLEAN DEFAULT FALSE,
  69. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  70. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  71. FOREIGN KEY (client_id) REFERENCES clients(id) ON DELETE CASCADE,
  72. INDEX idx_client_primary (client_id, is_primary),
  73. INDEX idx_name (last_name, first_name)
  74. );
  75. CREATE TABLE IF NOT EXISTS invoices (
  76. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  77. client_id INT(11) NOT NULL,
  78. invoice_number VARCHAR(50) NOT NULL UNIQUE,
  79. issue_date DATE NOT NULL,
  80. due_date DATE NOT NULL,
  81. status ENUM('draft', 'sent', 'paid', 'overdue', 'cancelled') DEFAULT 'draft',
  82. subtotal DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  83. tax_amount DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  84. total_amount DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  85. notes TEXT NULL,
  86. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  87. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  88. FOREIGN KEY (client_id) REFERENCES clients(id) ON DELETE RESTRICT,
  89. INDEX idx_client_status (client_id, status),
  90. INDEX idx_invoice_number (invoice_number),
  91. INDEX idx_due_date (due_date)
  92. );
  93. CREATE TABLE IF NOT EXISTS invoice_items (
  94. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  95. invoice_id INT(11) NOT NULL,
  96. item_id INT(11) NOT NULL,
  97. description VARCHAR(255) NOT NULL,
  98. quantity DECIMAL(10,2) NOT NULL DEFAULT 1.00,
  99. unit_price DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  100. line_total DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  101. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  102. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  103. FOREIGN KEY (invoice_id) REFERENCES invoices(id) ON DELETE CASCADE,
  104. FOREIGN KEY (item_id) REFERENCES items(id) ON DELETE RESTRICT,
  105. INDEX idx_invoice (invoice_id),
  106. INDEX idx_item (item_id)
  107. );
  108. CREATE TABLE IF NOT EXISTS payments (
  109. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  110. invoice_id INT(11) NULL,
  111. client_id INT(11) NOT NULL,
  112. payment_date DATE NOT NULL,
  113. amount DECIMAL(10,2) NOT NULL DEFAULT 0.00,
  114. payment_method ENUM('cash', 'check', 'credit_card', 'bank_transfer', 'other') DEFAULT 'cash',
  115. reference_number VARCHAR(50) NULL,
  116. notes TEXT NULL,
  117. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  118. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  119. FOREIGN KEY (invoice_id) REFERENCES invoices(id) ON DELETE SET NULL,
  120. FOREIGN KEY (client_id) REFERENCES clients(id) ON DELETE RESTRICT,
  121. INDEX idx_invoice (invoice_id),
  122. INDEX idx_client (client_id),
  123. INDEX idx_payment_date (payment_date)
  124. );
  125. CREATE TABLE IF NOT EXISTS chart_of_accounts (
  126. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  127. account_number VARCHAR(20) NOT NULL UNIQUE,
  128. account_name VARCHAR(255) NOT NULL,
  129. account_type ENUM('asset', 'liability', 'equity', 'revenue', 'expense') NOT NULL,
  130. parent_id INT(11) NULL,
  131. description TEXT NULL,
  132. opening_balance DECIMAL(10,2) DEFAULT 0.00,
  133. current_balance DECIMAL(10,2) DEFAULT 0.00,
  134. is_active BOOLEAN DEFAULT TRUE,
  135. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  136. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  137. FOREIGN KEY (parent_id) REFERENCES chart_of_accounts(id) ON DELETE SET NULL,
  138. INDEX idx_account_type (account_type),
  139. INDEX idx_parent (parent_id),
  140. INDEX idx_account_number (account_number)
  141. );
  142. CREATE TABLE IF NOT EXISTS journal_entries (
  143. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  144. entry_number VARCHAR(50) NOT NULL UNIQUE,
  145. entry_date DATE NOT NULL,
  146. description TEXT NULL,
  147. reference_number VARCHAR(50) NULL,
  148. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  149. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  150. INDEX idx_entry_date (entry_date),
  151. INDEX idx_entry_number (entry_number)
  152. );
  153. CREATE TABLE IF NOT EXISTS account_transactions (
  154. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  155. journal_entry_id INT(11) NOT NULL,
  156. account_id INT(11) NOT NULL,
  157. debit_amount DECIMAL(10,2) DEFAULT 0.00,
  158. credit_amount DECIMAL(10,2) DEFAULT 0.00,
  159. description TEXT NULL,
  160. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  161. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  162. FOREIGN KEY (journal_entry_id) REFERENCES journal_entries(id) ON DELETE CASCADE,
  163. FOREIGN KEY (account_id) REFERENCES chart_of_accounts(id) ON DELETE RESTRICT,
  164. INDEX idx_journal_entry (journal_entry_id),
  165. INDEX idx_account (account_id),
  166. INDEX idx_debit_credit (debit_amount, credit_amount)
  167. );
  168. CREATE TABLE IF NOT EXISTS users (
  169. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  170. username VARCHAR(50) NOT NULL UNIQUE,
  171. email VARCHAR(255) NOT NULL UNIQUE,
  172. password_hash VARCHAR(255) NOT NULL,
  173. first_name VARCHAR(100) NOT NULL,
  174. last_name VARCHAR(100) NOT NULL,
  175. role ENUM('admin', 'manager', 'user') DEFAULT 'user',
  176. is_active BOOLEAN DEFAULT TRUE,
  177. last_login TIMESTAMP NULL,
  178. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  179. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  180. INDEX idx_username (username),
  181. INDEX idx_email (email),
  182. INDEX idx_role (role),
  183. INDEX idx_active (is_active)
  184. );
  185. CREATE TABLE IF NOT EXISTS projects (
  186. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  187. customer_id INT(11) NOT NULL,
  188. project_name VARCHAR(255) NOT NULL,
  189. description TEXT NULL,
  190. status ENUM('planning', 'in_progress', 'completed', 'on_hold', 'cancelled') DEFAULT 'planning',
  191. start_date DATE NULL,
  192. end_date DATE NULL,
  193. budget DECIMAL(10,2) NULL,
  194. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  195. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  196. FOREIGN KEY (customer_id) REFERENCES clients(id) ON DELETE CASCADE,
  197. INDEX idx_customer (customer_id),
  198. INDEX idx_status (status),
  199. INDEX idx_dates (start_date, end_date)
  200. );
  201. CREATE TABLE IF NOT EXISTS subprojects (
  202. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  203. project_id INT(11) NOT NULL,
  204. subproject_name VARCHAR(255) NOT NULL,
  205. description TEXT NULL,
  206. status ENUM('planning', 'in_progress', 'completed', 'on_hold', 'cancelled') DEFAULT 'planning',
  207. start_date DATE NULL,
  208. end_date DATE NULL,
  209. budget DECIMAL(10,2) NULL,
  210. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  211. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  212. FOREIGN KEY (project_id) REFERENCES projects(id) ON DELETE CASCADE,
  213. INDEX idx_project (project_id),
  214. INDEX idx_status (status),
  215. INDEX idx_dates (start_date, end_date)
  216. );
  217. -- Accounting tables
  218. CREATE TABLE IF NOT EXISTS accounting_entries (
  219. id INT AUTO_INCREMENT PRIMARY KEY,
  220. entry_date DATE NOT NULL,
  221. description TEXT NOT NULL,
  222. entry_type ENUM('Tulo', 'Kulu') NOT NULL,
  223. category VARCHAR(100),
  224. tax_free_amount DECIMAL(12,2) DEFAULT 0.00,
  225. vat_percentage DECIMAL(5,2) DEFAULT 0.00,
  226. vat_25_5 DECIMAL(12,2) DEFAULT 0.00,
  227. vat_14 DECIMAL(12,2) DEFAULT 0.00,
  228. vat_10 DECIMAL(12,2) DEFAULT 0.00,
  229. total_amount DECIMAL(12,2) DEFAULT 0.00,
  230. net_amount DECIMAL(12,2) DEFAULT 0.00,
  231. vat_amount DECIMAL(12,2) DEFAULT 0.00,
  232. reference_number VARCHAR(50),
  233. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  234. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  235. INDEX idx_entry_date (entry_date),
  236. INDEX idx_entry_type (entry_type),
  237. INDEX idx_category (category)
  238. );
  239. CREATE TABLE IF NOT EXISTS accounting_categories (
  240. id INT AUTO_INCREMENT PRIMARY KEY,
  241. category_code VARCHAR(20) NOT NULL,
  242. category_name VARCHAR(200) NOT NULL,
  243. category_type ENUM('Tulo', 'Kulu') NOT NULL,
  244. vat_percentage DECIMAL(5,2) DEFAULT 0.00,
  245. is_active BOOLEAN DEFAULT TRUE,
  246. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  247. UNIQUE KEY unique_category_code (category_code)
  248. );
  249. CREATE TABLE IF NOT EXISTS accounting_category_group_names (
  250. id INT AUTO_INCREMENT PRIMARY KEY,
  251. category_group_code VARCHAR(3) NOT NULL,
  252. category_group_name VARCHAR(200) NOT NULL,
  253. description TEXT NULL,
  254. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  255. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  256. UNIQUE KEY unique_category_group_code (category_group_code)
  257. );
  258. CREATE TABLE IF NOT EXISTS monthly_summaries (
  259. id INT AUTO_INCREMENT PRIMARY KEY,
  260. year INT NOT NULL,
  261. month INT NOT NULL,
  262. total_income DECIMAL(12,2) DEFAULT 0.00,
  263. total_expenses DECIMAL(12,2) DEFAULT 0.00,
  264. net_result DECIMAL(12,2) DEFAULT 0.00,
  265. vat_payable DECIMAL(12,2) DEFAULT 0.00,
  266. vat_deductible DECIMAL(12,2) DEFAULT 0.00,
  267. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  268. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  269. UNIQUE KEY unique_year_month (year, month)
  270. );
  271. -- Additional tables for project management
  272. CREATE TABLE IF NOT EXISTS costs (
  273. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  274. description VARCHAR(255) NOT NULL,
  275. amount DECIMAL(10,2) NOT NULL,
  276. cost_date DATE NOT NULL,
  277. category VARCHAR(100) NOT NULL DEFAULT 'other',
  278. supplier VARCHAR(255) NULL,
  279. invoice_number VARCHAR(100) NULL,
  280. account_id INT(11) NULL,
  281. payment_method VARCHAR(50) NULL,
  282. receipt_number VARCHAR(100) NULL,
  283. notes TEXT NULL,
  284. created_by INT(11) NULL,
  285. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  286. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  287. INDEX idx_cost_date (cost_date),
  288. INDEX idx_category (category),
  289. INDEX idx_supplier (supplier),
  290. INDEX idx_account_id (account_id),
  291. INDEX idx_created_by (created_by)
  292. );
  293. CREATE TABLE IF NOT EXISTS timers (
  294. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  295. task_id INT(11) NULL,
  296. user_id INT(11) NOT NULL,
  297. start_time TIMESTAMP NULL,
  298. end_time TIMESTAMP NULL,
  299. duration VARCHAR(8) NULL,
  300. description TEXT NULL,
  301. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  302. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  303. INDEX idx_task_id (task_id),
  304. INDEX idx_user_id (user_id),
  305. INDEX idx_start_time (start_time)
  306. );
  307. CREATE TABLE IF NOT EXISTS expense_categories (
  308. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  309. category_code VARCHAR(50) NOT NULL UNIQUE,
  310. category_name VARCHAR(200) NOT NULL,
  311. parent_id INT(11) NULL,
  312. description TEXT NULL,
  313. is_active TINYINT(1) DEFAULT 1,
  314. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  315. INDEX idx_parent_id (parent_id)
  316. );
  317. CREATE TABLE IF NOT EXISTS income_categories (
  318. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  319. category_code VARCHAR(50) NOT NULL UNIQUE,
  320. category_name VARCHAR(200) NOT NULL,
  321. parent_id INT(11) NULL,
  322. description TEXT NULL,
  323. is_active TINYINT(1) DEFAULT 1,
  324. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  325. INDEX idx_parent_id (parent_id)
  326. );
  327. CREATE TABLE IF NOT EXISTS incomes (
  328. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  329. description VARCHAR(255) NOT NULL,
  330. amount DECIMAL(10,2) NOT NULL,
  331. income_date DATE NOT NULL,
  332. category VARCHAR(100) NOT NULL DEFAULT 'other',
  333. client_id INT(11) NULL,
  334. invoice_id INT(11) NULL,
  335. account_id INT(11) NULL,
  336. payment_method VARCHAR(50) NULL,
  337. reference_number VARCHAR(100) NULL,
  338. notes TEXT NULL,
  339. created_by INT(11) NULL,
  340. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  341. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  342. INDEX idx_income_date (income_date),
  343. INDEX idx_category (category),
  344. INDEX idx_client_id (client_id),
  345. INDEX idx_invoice_id (invoice_id),
  346. INDEX idx_account_id (account_id),
  347. INDEX idx_created_by (created_by)
  348. );
  349. CREATE TABLE IF NOT EXISTS work_hours (
  350. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  351. task_id INT(11) NOT NULL,
  352. user_id INT(11) NOT NULL,
  353. date DATE NOT NULL,
  354. hours DECIMAL(5,2) NOT NULL,
  355. description TEXT NULL,
  356. rate DECIMAL(10,2) NULL,
  357. total_amount DECIMAL(10,2) NULL,
  358. created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  359. updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  360. INDEX idx_task_id (task_id),
  361. INDEX idx_user_id (user_id),
  362. INDEX idx_date (date)
  363. );
  364. -- Insert wavium admin user
  365. INSERT INTO users (username, email, password_hash, first_name, last_name, role, is_active) VALUES
  366. ('weikka', 'weikka@wavium.fi', '$2y$12$ZFHPKWs2AcaaYlwno7kkWOoaD0cHNWikf8kwBnetYo/QXvG8smcD6', 'Weikka', 'Valavuo', 'admin', TRUE);
  367. -- Insert expense categories data
  368. INSERT IGNORE INTO expense_categories (category_code, category_name, parent_id, description, is_active) VALUES
  369. ('333', 'Ostot ja ulkopuoliset palvelut', NULL, 'Purchases and external services', 1),
  370. ('334', 'Henkilöstökulut', NULL, 'Personnel costs', 1),
  371. ('335', 'Poistot, edustuskulut ja vuokrat', NULL, 'Depreciation, representation and rental costs', 1),
  372. ('336', 'Muut vähennyskelpoiset kulut', NULL, 'Other deductible expenses', 1),
  373. ('337', 'Rahoituskulut', NULL, 'Financing costs', 1),
  374. ('341', 'Varausten muutokset', NULL, 'Asset changes', 1),
  375. ('343', 'Varausten myynnit', NULL, 'Asset sales', 1),
  376. ('344', 'Matkakulut', NULL, 'Travel expenses', 1),
  377. ('344 Ajoneuvo', 'Matkakulut - Kulkuneuvo', NULL, 'Vehicle travel expenses', 1),
  378. ('344 Kokous', 'Matkakulut - Kokous', NULL, 'Meeting travel expenses', 0),
  379. ('344 Matka-auto', 'Matkakulut - Auto', NULL, 'Car travel expenses', 1),
  380. ('344 Muu', 'Matkakulut - Muu', NULL, 'Other travel expenses', 1),
  381. ('346', 'Muut kulut', NULL, 'Other expenses', 1),
  382. ('349', 'Poistot', NULL, 'Depreciation', 1),
  383. ('353', 'Varainsiirrot', NULL, 'Asset transfers', 1),
  384. ('354', 'Vähennyskelvottomat kulut', NULL, 'Non-deductible expenses', 1),
  385. ('365', 'Vakuutukset', NULL, 'Insurance', 1),
  386. ('366', 'Verot ja maksut', NULL, 'Taxes and fees', 1),
  387. ('367', 'Yhtiölainat ja muut rahoituskulut', NULL, 'Company loans and other financing costs', 1);
  388. -- Insert income categories data
  389. INSERT IGNORE INTO income_categories (category_code, category_name, parent_id, description, is_active) VALUES
  390. ('300', 'Myynti - EU', NULL, 'Sales - EU', 1),
  391. ('300 - 255', 'Myynti - EU 25,5%', NULL, 'Sales - EU 25,5%', 1),
  392. ('301', 'Myynti - Muut maat', NULL, 'Sales - Other countries', 1),
  393. ('302', 'Myynti - Käänteinen vero', NULL, 'Sales - Reverse VAT', 1),
  394. ('303', 'Myynti - Suomi 0%', NULL, 'Sales - Finland 0%', 1),
  395. ('303 - 255', 'Myynti - Suomi 25,5%', NULL, 'Sales - Finland 25,5%', 1),
  396. ('308', 'Myyntitavarat', NULL, 'Sales of fixed assets', 1),
  397. ('309', 'Osuuskorvaukset', NULL, 'Share compensation', 1),
  398. ('310', 'Korkotulot ja muut rahoitustuotot', NULL, 'Interest income and other financial income', 1),
  399. ('311', 'Voitonjako', NULL, 'Profit distribution', 1),
  400. ('312', 'Sijoitustoiminnan tuotot', NULL, 'Investment income', 1),
  401. ('313', 'Apurahat ja muut avustukset', NULL, 'Grants and other subsidies', 1),
  402. ('314', 'Muu tuotto', NULL, 'Other income', 1);
  403. -- Insert default accounting categories
  404. INSERT IGNORE INTO accounting_categories (category_code, category_name, category_type, vat_percentage) VALUES
  405. ('300 - E0', 'Myynti - EU 0%', 'Tulo', 0.00),
  406. ('300 - E255', 'Myynti - EU 25,5%', 'Tulo', 25.50),
  407. ('300 - K', 'Myynti - Käänteinen vero', 'Tulo', 0.00),
  408. ('300 - M0', 'Myynti - Muut maat', 'Tulo', 0.00),
  409. ('300 - S0', 'Myynti - Suomi 0%', 'Tulo', 0.00),
  410. ('300 - S255', 'Myynti - Suomi 25,5%', 'Tulo', 25.50),
  411. ('301', 'Muut tuotot', 'Tulo', 0.00),
  412. ('312', 'Varausten vähennys', 'Tulo', 0.00),
  413. ('313', 'Auton yksityiskäyttö', 'Tulo', 0.00),
  414. ('314', 'Tavaroiden yksityiskäyttö', 'Tulo', 0.00),
  415. ('315', 'Muu yksityiskäyttö', 'Tulo', 0.00),
  416. ('317', 'Tuloslaskelman verovapaat tuotot', 'Tulo', 0.00),
  417. ('318', 'Saadut avustukset ja tuet', 'Tulo', 0.00),
  418. ('319', 'Saadut osingot', 'Tulo', 0.00),
  419. ('320', 'Osinkojen veronalainen osuus', 'Tulo', 0.00),
  420. ('323', 'Korkotuotot ja muut rahoitustuotot', 'Tulo', 0.00),
  421. ('324', 'Muut veronalaiset tuotot', 'Tulo', 0.00),
  422. ('333', 'Ostot ja varastojen muutokset', 'Kulu', 25.50),
  423. ('334', 'Ulkopuoliset palvelut', 'Kulu', 25.50),
  424. ('335', 'Palkat ja palkkiot', 'Kulu', 0.00),
  425. ('336', 'Eläke- ja henkilösivukulut', 'Kulu', 0.00),
  426. ('337', 'Poistot', 'Kulu', 0.00),
  427. ('341', 'Edustuskulut', 'Kulu', 0.00),
  428. ('343', 'Vuokrat', 'Kulu', 25.50),
  429. ('344 - A', 'Ajoneuvokulut', 'Kulu', 25.50),
  430. ('344 - K', 'Kokous- ja neuvottelukulut', 'Kulu', 25.50),
  431. ('344 - M', 'Matkakulut', 'Kulu', 25.50),
  432. ('344 - O', 'Muut vähennyskelpoiset kulut', 'Kulu', 25.50),
  433. ('346', 'Korkokulut', 'Kulu', 0.00),
  434. ('349', 'Muut rahoituskulut', 'Kulu', 0.00),
  435. ('353', 'Varausten lisäykset', 'Kulu', 0.00),
  436. ('354', 'Kirjanpidon ulkopuoliset vähennyskelpoiset kulut', 'Kulu', 0.00),
  437. ('365', 'Välittömät verot', 'Kulu', 0.00),
  438. ('366', 'Sakot ja muut rangaistusmaksut', 'Kulu', 0.00),
  439. ('367', 'Muut vähennyskelvottomat kulut', 'Kulu', 0.00),
  440. ('368', 'Julkinen liikenne', 'Kulu', 10.00);
  441. -- Insert default category groups
  442. INSERT IGNORE INTO accounting_category_group_names (category_group_code, category_group_name, description) VALUES
  443. ('300', 'Tuotot ammatista', NULL),
  444. ('301', 'Muut tuotot', NULL),
  445. ('312', 'Varausten vähennys', NULL),
  446. ('313', 'Auton yksityiskäyttö', NULL),
  447. ('314', 'Tavaroiden yksityiskäyttö', NULL),
  448. ('315', 'Muu yksityiskäyttö', NULL),
  449. ('317', 'Tuloslaskelman verovapaat tuotot', NULL),
  450. ('318', 'Saadut avustukset ja tuet', NULL),
  451. ('319', 'Saadut osingot', NULL),
  452. ('323', 'Korkotuotot ja muut rahoitustuotot', NULL),
  453. ('324', 'Muut veronalaiset tuotot', NULL),
  454. ('333', 'Ostot ja varastojen muutokset', NULL),
  455. ('334', 'Ulkopuoliset palvelut', NULL),
  456. ('335', 'Palkat ja palkkiot', NULL),
  457. ('336', 'Eläke- ja henkilösivukulut', NULL),
  458. ('337', 'Poistot', NULL),
  459. ('341', 'Edustuskulut', NULL),
  460. ('343', 'Vuokrat', NULL),
  461. ('344', 'Matkakulut', NULL),
  462. ('346', 'Korkokulut', NULL),
  463. ('349', 'Muut rahoituskulut', NULL),
  464. ('353', 'Varausten lisäykset', NULL),
  465. ('354', 'Kirjanpidon ulkopuoliset vähennyskelpoiset kulut', NULL),
  466. ('358', 'Elinkeinotoiminnan tulos', NULL),
  467. ('359', 'Elinkeinotoiminnan tappio', NULL),
  468. ('365', 'Välittömät verot', NULL),
  469. ('366', 'Sakot ja muut rangaistusmaksut', NULL),
  470. ('367', 'Muut vähennyskelvottomat kulut', NULL),
  471. ('368', 'Julkinen liikenne', NULL);
  472. -- Insert chart of accounts
  473. INSERT IGNORE INTO chart_of_accounts (account_number, account_name, account_type, parent_id, description, opening_balance, current_balance, is_active) VALUES
  474. ('1000', 'Käyttöpääoma', 'asset', NULL, 'Pääomaisuus', 0.00, 0.00, TRUE),
  475. ('1100', 'Saamiset ja vaatimukset', 'asset', NULL, 'Tase-erät ja poistot', 0.00, 0.00, TRUE),
  476. ('1200', 'Aineelliset vaihto-omaisuudet', 'asset', NULL, 'Varasto ja raaka-aineet', 0.00, 0.00, TRUE),
  477. ('1300', 'Pitkän aikaiset sijoitukset', 'asset', NULL, 'Pitkän aikaiset sijoitukset', 0.00, 0.00, TRUE),
  478. ('1400', 'Kiinteistöt', 'asset', NULL, 'Kiinteistöt ja rakennukset', 0.00, 0.00, TRUE),
  479. ('1500', 'Koneet ja kalusto', 'asset', NULL, 'Koneet, kalusto ja laitteet', 0.00, 0.00, TRUE),
  480. ('1600', 'Aineettomat varat', 'asset', NULL, 'Aineettomat varat', 0.00, 0.00, TRUE),
  481. ('1700', 'Sijoitukset rahoituslaitoksissa', 'asset', NULL, 'Rahoituslaitokset', 0.00, 0.00, TRUE),
  482. ('1800', 'Erityiset vaihto-omaisuudet', 'asset', NULL, 'Erityiset vaihto-omaisuudet', 0.00, 0.00, TRUE),
  483. ('1900', 'Vaihto-omaisuudet luovutukseen', 'asset', NULL, 'Myyntikohteiset varat', 0.00, 0.00, TRUE),
  484. ('2000', 'Oma pääoma', 'liability', NULL, 'Oma pääoma', 0.00, 0.00, TRUE),
  485. ('2100', 'Pitkän aikaiset velat', 'liability', NULL, 'Pitkän aikaiset velat', 0.00, 0.00, TRUE),
  486. ('2200', 'Verovelat', 'liability', NULL, 'Verovelat ja vakuudet', 0.00, 0.00, TRUE),
  487. ('2300', 'Ostovelat ja saamiset', 'liability', NULL, 'Ostovelat ja saamiset', 0.00, 0.00, TRUE),
  488. ('2400', 'Maksuvelat ja ennakot', 'liability', NULL, 'Maksuvelat ja saadut ennakot', 0.00, 0.00, TRUE),
  489. ('2500', 'Verovelat konserneille', 'liability', NULL, 'Verovelat konserneille', 0.00, 0.00, TRUE),
  490. ('2600', 'Muut velat', 'liability', NULL, 'Muut velat', 0.00, 0.00, TRUE),
  491. ('2700', 'Siirrot konserninointiin', 'liability', NULL, 'Siirrot konserninointiin', 0.00, 0.00, TRUE),
  492. ('2800', 'Tilikauden tuloverot', 'liability', NULL, 'Tilikauden tuloverot', 0.00, 0.00, TRUE),
  493. ('3000', 'Osakepääoma', 'equity', NULL, 'Osakepääoma', 0.00, 0.00, TRUE),
  494. ('3100', 'Sijoitetun pääoman rahastot', 'equity', NULL, 'Sijoitetun pääoman rahastot', 0.00, 0.00, TRUE),
  495. ('3200', 'Muut pääomat rahastot', 'equity', NULL, 'Muut pääomat rahastot', 0.00, 0.00, TRUE),
  496. ('3300', 'Tilikauden voitto', 'equity', NULL, 'Tilikauden voitto/tappio', 0.00, 0.00, TRUE),
  497. ('4000', 'Myyntituotot', 'revenue', NULL, 'Myyntituotot', 0.00, 0.00, TRUE),
  498. ('4100', 'Palvelutuotot', 'revenue', NULL, 'Palvelutuotot', 0.00, 0.00, TRUE),
  499. ('4200', 'Vuokratuotot', 'revenue', NULL, 'Vuokratuotot', 0.00, 0.00, TRUE),
  500. ('4300', 'Korko- ja valuuttatuotot', 'revenue', NULL, 'Korko- ja valuuttatuotot', 0.00, 0.00, TRUE),
  501. ('4400', 'Muu tuotto', 'revenue', NULL, 'Muu tuotto', 0.00, 0.00, TRUE),
  502. ('4500', 'Siirrot konserninointiin', 'revenue', NULL, 'Siirrot konserninointiin', 0.00, 0.00, TRUE),
  503. ('5000', 'Aineelliset kulut', 'expense', NULL, 'Aineelliset kulut ja palvelut', 0.00, 0.00, TRUE),
  504. ('5100', 'Henkilöstökulut', 'expense', NULL, 'Henkilöstökulut', 0.00, 0.00, TRUE),
  505. ('5200', 'Poistot ja alennukset', 'expense', NULL, 'Poistot ja alennukset', 0.00, 0.00, TRUE),
  506. ('5300', 'Vuokrat ja vuokrakulut', 'expense', NULL, 'Vuokrat ja vuokrakulut', 0.00, 0.00, TRUE),
  507. ('5400', 'Korko- ja rahoituskulut', 'expense', NULL, 'Korko- ja rahoituskulut', 0.00, 0.00, TRUE),
  508. ('5500', 'Tase-erät ja poistot', 'expense', NULL, 'Tase-erät ja poistot', 0.00, 0.00, TRUE),
  509. ('5600', 'Arvonmäärityksen alennukset', 'expense', NULL, 'Arvonmäärityksen alennukset', 0.00, 0.00, TRUE),
  510. ('5700', 'Verotukset ja maksut', 'expense', NULL, 'Verotukset ja maksut', 0.00, 0.00, TRUE),
  511. ('5800', 'Muut kulut', 'expense', NULL, 'Muut kulut', 0.00, 0.00, TRUE),
  512. ('5900', 'Siirrot konserninointiin', 'expense', NULL, 'Siirrot konserninointiin', 0.00, 0.00, TRUE);