! -> Note
$ -> Affected files
-24-Dec-2009 Merged changes from main trunk 2.2.1-2.2.2 as follows
+11-Jan-2010 Janusz Dobrowolski
+! Optimized database indexes.
+$ /sql/alter2.3.sql
+ /sql/en_US-demo.sql
+ /sql/en_US-new.sql
+27-Dec-2009 Janusz Dobrowolski
++ Remote packages repository support for extensions and languages
+$ /config.default.php
+ /frontaccounting.php
+ /admin/inst_lang.php
+ /admin/inst_module.php
+ /includes/access_levels.inc
+ /includes/ui/ui_lists.inc
+ /sql/alter2.3.php
+# Small fix in handle_submit
+$ /admin/create_coy.php
+! Using var_dump function for storing variables in config files.
+$ /admin/db/maintenance_db.inc
++ Added copy_file(), check_write() helper functions.
+$ /includes/main.inc
++ Aded array_search_key() helper.
+$ /includes/lang/gettext.php
++ Added helper for checking langauge support.
+$ /includes/current_user.inc
++ Added helper for radio buttons.
+$ /includes/ui/ui_input.inc
+! Extension links support moved to application class.
+$ /applications/application.php
+ /applications/customers.php
+ /applications/dimensions.php
+ /applications/generalledger.php
+ /applications/inventory.php
+ /applications/manufacturing.php
+ /applications/setup.php
+ /applications/suppliers.php
+ /includes/archive.inc (new)
+ /includes/packages.inc (new)
++ Support for popup buttons
+$ /js/inserts.js
+
+24-Dec-2009 Merged changes from main trunk 2.2.1-2.2.2 as follows
! Release 2.2.2
$ /update.html
! Changed so Printed Sales Order (Quotation) shows TOTAL VAT INCL. if it is.
-ALTER TABLE 0_comments ADD KEY type_and_id (`type`, `id`);
+ALTER TABLE 0_comments ADD KEY `type_and_id` (`type`, `id`);
ALTER TABLE 0_quick_entries ADD COLUMN `bal_type` TINYINT(1) NOT NULL default '0';
+
+# Key optimizations
+ALTER TABLE 0_fiscal_year ADD UNIQUE KEY(`begin`), ADD UNIQUE KEY(`end`);
+ALTER TABLE 0_useronline ADD KEY(`ip`);
+ALTER TABLE 0_dimensions ADD KEY(`date_`), ADD KEY(`due_date`), ADD KEY(`type_`);
+ALTER TABLE 0_gl_trans ADD KEY (`dimension_id`), ADD KEY (`dimension2_id`), ADD KEY (`tran_date`), ADD KEY `account_and_tran_date` (`account`, `tran_date`);
+ALTER TABLE 0_chart_master DROP KEY `account_code`;
+ALTER TABLE 0_chart_types ADD KEY(`class_id`);
+ALTER TABLE 0_bank_accounts ADD KEY (`account_code`);
+ALTER TABLE 0_bank_trans ADD KEY (`bank_act`,`reconciled`), ADD KEY (`bank_act`,`trans_date`);
+ALTER TABLE 0_budget_trans ADD KEY `Account` (`account`, `tran_date`, `dimension_id`, `dimension2_id`);
+ALTER TABLE 0_trans_tax_details ADD KEY `Type_and_Number` (`trans_type`,`trans_no`), ADD KEY (`tran_date`);
+ALTER TABLE 0_audit_trail DROP KEY `fiscal_year`, ADD KEY `Seq` (`fiscal_year`, `gl_date`, `gl_seq`), ADD KEY `Type_and_Number` (`type`,`trans_no`);
+ALTER TABLE 0_item_codes ADD KEY (`item_code`);
+ALTER TABLE 0_stock_moves ADD KEY `Move` (`stock_id`,`loc_code`, `tran_date`);
+ALTER TABLE 0_wo_issues ADD KEY (`workorder_id`);
+ALTER TABLE 0_wo_manufacture ADD KEY (`workorder_id`);
+ALTER TABLE 0_wo_requirements ADD KEY (`workorder_id`);
+ALTER TABLE 0_bom DROP KEY `Parent_2`;
+ALTER TABLE 0_refs ADD KEY `Type_and_Reference` (`type`,`reference`);
+ALTER TABLE 0_grn_items ADD KEY (`grn_batch_id`);
+ALTER TABLE 0_grn_batch ADD KEY (`delivery_date`), ADD KEY (`purch_order_no`);
+ALTER TABLE 0_supp_invoice_items ADD KEY `Transaction` (`supp_trans_type`, `supp_trans_no`, `stock_id`);
+ALTER TABLE 0_purch_order_details ADD KEY `order` (`order_no`, `po_detail_item`);
+ALTER TABLE 0_purch_orders ADD KEY (`ord_date`);
+ALTER TABLE 0_supp_trans ADD KEY (`tran_date`), DROP PRIMARY KEY, ADD PRIMARY KEY (`type`, `trans_no`);
+ALTER TABLE 0_suppliers ADD KEY (`supp_ref`);
+ALTER TABLE 0_supp_allocations ADD KEY `From` (`trans_type_from`, `trans_no_from`), ADD KEY `To` (`trans_type_to`, `trans_no_to`);
+ALTER TABLE 0_cust_branch DROP KEY `br_name`, ADD KEY (`branch_ref`), ADD KEY (`group_no`);
+ALTER TABLE 0_debtors_master ADD KEY (`debtor_ref`);
+ALTER TABLE 0_debtor_trans DROP PRIMARY KEY, ADD PRIMARY KEY (`type`, `trans_no`), ADD KEY (`tran_date`);
+ALTER TABLE 0_debtor_trans_details ADD KEY `Transaction` (`debtor_trans_type`, `debtor_trans_no`);
+ALTER TABLE 0_cust_allocations ADD KEY `From` (`trans_type_from`, `trans_no_from`), ADD KEY `To` (`trans_type_to`, `trans_no_to`);
+ALTER TABLE 0_sales_order_details ADD KEY `sorder` (`trans_type`, `order_no`);
+ALTER TABLE 0_chart_master ADD KEY `accounts_by_type` (`account_type`, `account_code`);
+# fix invalid constraint on databases generated from 2.2 version on en_US-new.sql
+#ALTER TABLE `0_tax_types` DROP KEY `name`;
`gl_date` date NOT NULL default '0000-00-00',
`gl_seq` int(11) unsigned default NULL,
PRIMARY KEY (`id`),
- KEY (`fiscal_year`, `gl_seq`)
+ KEY `Seq` (`fiscal_year`, `gl_date`, `gl_seq`),
+ KEY `Type_and_Number` (`type`,`trans_no`)
) TYPE=InnoDB ;
### Data of table `0_audit_trail` ###
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
KEY `bank_account_name` (`bank_account_name`),
- KEY `bank_account_number` (`bank_account_number`)
+ KEY `bank_account_number` (`bank_account_number`),
+ KEY (`account_code`)
) TYPE=MyISAM AUTO_INCREMENT=3 ;
`reconciled` date default NULL,
PRIMARY KEY (`id`),
KEY `bank_act` (`bank_act`,`ref`),
- KEY `type` (`type`,`trans_no`)
+ KEY `type` (`type`,`trans_no`),
+ KEY (`bank_act`,`reconciled`),
+ KEY (`bank_act`,`trans_date`)
) TYPE=InnoDB AUTO_INCREMENT=12 ;
KEY `id` (`id`),
KEY `loc_code` (`loc_code`),
KEY `parent` (`parent`,`loc_code`),
- KEY `Parent_2` (`parent`),
KEY `workcentre_added` (`workcentre_added`)
) TYPE=MyISAM AUTO_INCREMENT=4 ;
`person_type_id` int(11) default NULL,
`person_id` tinyblob,
PRIMARY KEY (`counter`),
- KEY `Type_and_Number` (`type`,`type_no`)
+ KEY `Type_and_Number` (`type`,`type_no`),
+ KEY `Account` (`account`, `tran_date`, `dimension_id`, `dimension2_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`account_type` int(11) NOT NULL default '0',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`account_code`),
- KEY `account_code` (`account_code`),
- KEY `account_name` (`account_name`)
+ KEY `account_name` (`account_name`),
+ KEY `accounts_by_type` (`account_type`, `account_code`)
) TYPE=MyISAM ;
`parent` int(11) NOT NULL default '-1',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
+ KEY (`class_id`),
KEY `name` (`name`)
) TYPE=MyISAM AUTO_INCREMENT=13 ;
`trans_type_from` int(11) default NULL,
`trans_no_to` int(11) default NULL,
`trans_type_to` int(11) default NULL,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `From` (`trans_type_from`, `trans_no_from`),
+ KEY `To` (`trans_type_to`, `trans_no_to`)
) TYPE=InnoDB AUTO_INCREMENT=2 ;
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`branch_code`,`debtor_no`),
KEY `branch_code` (`branch_code`),
- KEY `br_name` (`br_name`)
+ KEY (`branch_ref`),
+ KEY (`group_no`)
) TYPE=MyISAM AUTO_INCREMENT=4 ;
`trans_link` int(11) NOT NULL default '0',
`dimension_id` int(11) NOT NULL default '0',
`dimension2_id` int(11) NOT NULL default '0',
- PRIMARY KEY (`trans_no`,`type`),
- KEY `debtor_no` (`debtor_no`,`branch_code`)
+ PRIMARY KEY (`type`, `trans_no`),
+ KEY `debtor_no` (`debtor_no`,`branch_code`),
+ KEY (`tran_date`)
) TYPE=InnoDB ;
`discount_percent` double NOT NULL default '0',
`standard_cost` double NOT NULL default '0',
`qty_done` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `Transaction` (`debtor_trans_type`, `debtor_trans_no`)
) TYPE=InnoDB AUTO_INCREMENT=9 ;
`notes` tinytext NOT NULL,
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`debtor_no`),
- UNIQUE KEY `name` (`name`)
+ UNIQUE KEY `name` (`name`),
+ KEY (`debtor_ref`)
) TYPE=MyISAM AUTO_INCREMENT=4 ;
`date_` date NOT NULL default '0000-00-00',
`due_date` date NOT NULL default '0000-00-00',
PRIMARY KEY (`id`),
- UNIQUE KEY `reference` (`reference`)
+ UNIQUE KEY `reference` (`reference`),
+ KEY (`date_`),
+ KEY (`due_date`),
+ KEY (`type_`)
) TYPE=InnoDB AUTO_INCREMENT=3 ;
`begin` date default '0000-00-00',
`end` date default '0000-00-00',
`closed` tinyint(1) NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ UNIQUE KEY(`begin`),
+ UNIQUE KEY(`end`)
) TYPE=InnoDB AUTO_INCREMENT=3 ;
`person_type_id` int(11) default NULL,
`person_id` tinyblob,
PRIMARY KEY (`counter`),
- KEY `Type_and_Number` (`type`,`type_no`)
+ KEY `Type_and_Number` (`type`,`type_no`),
+ KEY (`dimension_id`),
+ KEY (`dimension2_id`),
+ KEY (`tran_date`),
+ KEY `account_and_tran_date` (`account`, `tran_date`)
) TYPE=InnoDB AUTO_INCREMENT=84 ;
`reference` varchar(60) NOT NULL default '',
`delivery_date` date NOT NULL default '0000-00-00',
`loc_code` varchar(5) default NULL,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY(`delivery_date`),
+ KEY(`purch_order_no`)
) TYPE=InnoDB AUTO_INCREMENT=2 ;
`description` tinytext,
`qty_recd` double NOT NULL default '0',
`quantity_inv` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY (`grn_batch_id`)
) TYPE=InnoDB AUTO_INCREMENT=4 ;
`is_foreign` tinyint(1) NOT NULL default '0',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
- UNIQUE KEY `stock_id` (`stock_id`,`item_code`)
+ UNIQUE KEY `stock_id` (`stock_id`,`item_code`),
+ KEY (`item_code`)
) TYPE=MyISAM AUTO_INCREMENT=6 ;
`std_cost_unit` double NOT NULL default '0',
`quantity_ordered` double NOT NULL default '0',
`quantity_received` double NOT NULL default '0',
- PRIMARY KEY (`po_detail_item`)
+ PRIMARY KEY (`po_detail_item`),
+ KEY `order` (`order_no`, `po_detail_item`)
) TYPE=InnoDB AUTO_INCREMENT=6 ;
`requisition_no` tinytext,
`into_stock_location` varchar(5) NOT NULL default '',
`delivery_address` tinytext NOT NULL,
- PRIMARY KEY (`order_no`)
+ PRIMARY KEY (`order_no`),
+ KEY (`ord_date`)
) TYPE=InnoDB AUTO_INCREMENT=3 ;
`id` int(11) NOT NULL default '0',
`type` int(11) NOT NULL default '0',
`reference` varchar(100) NOT NULL default '',
- PRIMARY KEY (`id`,`type`)
+ PRIMARY KEY (`id`,`type`),
+ KEY `Type_and_Reference` (`type`,`reference`)
) TYPE=InnoDB ;
`unit_price` double NOT NULL default '0',
`quantity` double NOT NULL default '0',
`discount_percent` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `sorder` (`trans_type`, `order_no`)
) TYPE=InnoDB AUTO_INCREMENT=6 ;
`standard_cost` double NOT NULL default '0',
`visible` tinyint(1) NOT NULL default '1',
PRIMARY KEY (`trans_id`),
- KEY `type` (`type`,`trans_no`)
+ KEY `type` (`type`,`trans_no`),
+ KEY `Move` (`stock_id`,`loc_code`, `tran_date`)
) TYPE=InnoDB AUTO_INCREMENT=37 ;
`trans_type_from` int(11) default NULL,
`trans_no_to` int(11) default NULL,
`trans_type_to` int(11) default NULL,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `From` (`trans_type_from`, `trans_no_from`),
+ KEY `To` (`trans_type_to`, `trans_no_to`)
) TYPE=InnoDB AUTO_INCREMENT=2 ;
`unit_price` double NOT NULL default '0',
`unit_tax` double NOT NULL default '0',
`memo_` tinytext,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `Transaction` (`supp_trans_type`, `supp_trans_no`, `stock_id`)
) TYPE=InnoDB AUTO_INCREMENT=6 ;
`ov_gst` double NOT NULL default '0',
`rate` double NOT NULL default '1',
`alloc` double NOT NULL default '0',
- PRIMARY KEY (`trans_no`,`type`),
+ PRIMARY KEY (`type`, `trans_no`),
KEY `supplier_id` (`supplier_id`),
KEY `SupplierID_2` (`supplier_id`,`supp_reference`),
- KEY `type` (`type`)
+ KEY `type` (`type`),
+ KEY (`tran_date`)
) TYPE=InnoDB ;
`payment_discount_account` varchar(11) default NULL,
`notes` tinytext NOT NULL,
`inactive` tinyint(1) NOT NULL default '0',
- PRIMARY KEY (`supplier_id`)
+ PRIMARY KEY (`supplier_id`),
+ KEY (`supp_ref`)
) TYPE=MyISAM AUTO_INCREMENT=4 ;
`net_amount` double NOT NULL default '0',
`amount` double NOT NULL default '0',
`memo` tinytext,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `Type_and_Number` (`trans_type`,`trans_no`),
+ KEY (`tran_date`)
) TYPE=InnoDB AUTO_INCREMENT=12 ;
`issue_date` date default NULL,
`loc_code` varchar(5) default NULL,
`workcentre_id` int(11) default NULL,
- PRIMARY KEY (`issue_no`)
+ PRIMARY KEY (`issue_no`),
+ KEY (`workorder_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`workorder_id` int(11) NOT NULL default '0',
`quantity` double NOT NULL default '0',
`date_` date NOT NULL default '0000-00-00',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY (`workorder_id`)
) TYPE=InnoDB AUTO_INCREMENT=2 ;
`std_cost` double NOT NULL default '0',
`loc_code` char(5) NOT NULL default '',
`units_issued` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY (`workorder_id`)
) TYPE=InnoDB AUTO_INCREMENT=22 ;
`ip` varchar(40) NOT NULL default '',
`file` varchar(100) NOT NULL default '',
PRIMARY KEY `id` (`id`) ,
- KEY (`timestamp`)
+ KEY (`timestamp`),
+ KEY(`ip`)
) TYPE=MYISAM AUTO_INCREMENT=1;
`gl_date` date NOT NULL default '0000-00-00',
`gl_seq` int(11) unsigned default NULL,
PRIMARY KEY (`id`),
- KEY (`fiscal_year`, `gl_seq`)
+ KEY `Seq` (`fiscal_year`, `gl_date`, `gl_seq`),
+ KEY `Type_and_Number` (`type`,`trans_no`)
) TYPE=InnoDB ;
### Data of table `0_audit_trail` ###
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
KEY `bank_account_name` (`bank_account_name`),
- KEY `bank_account_number` (`bank_account_number`)
+ KEY `bank_account_number` (`bank_account_number`),
+ KEY (`account_code`)
) TYPE=MyISAM AUTO_INCREMENT=3 ;
`reconciled` date default NULL,
PRIMARY KEY (`id`),
KEY `bank_act` (`bank_act`,`ref`),
- KEY `type` (`type`,`trans_no`)
+ KEY `type` (`type`,`trans_no`),
+ KEY (`bank_act`,`reconciled`),
+ KEY (`bank_act`,`trans_date`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
KEY `id` (`id`),
KEY `loc_code` (`loc_code`),
KEY `parent` (`parent`,`loc_code`),
- KEY `Parent_2` (`parent`),
KEY `workcentre_added` (`workcentre_added`)
) TYPE=MyISAM AUTO_INCREMENT=1 ;
`person_type_id` int(11) default NULL,
`person_id` tinyblob,
PRIMARY KEY (`counter`),
- KEY `Type_and_Number` (`type`,`type_no`)
+ KEY `Type_and_Number` (`type`,`type_no`),
+ KEY `Account` (`account`, `tran_date`, `dimension_id`, `dimension2_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`account_type` int(11) NOT NULL default '0',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`account_code`),
- KEY `account_code` (`account_code`),
- KEY `account_name` (`account_name`)
+ KEY `account_name` (`account_name`),
+ KEY `accounts_by_type` (`account_type`, `account_code`)
) TYPE=MyISAM ;
`parent` int(11) NOT NULL default '-1',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
+ KEY (`class_id`),
KEY `name` (`name`)
) TYPE=MyISAM AUTO_INCREMENT=13 ;
`trans_type_from` int(11) default NULL,
`trans_no_to` int(11) default NULL,
`trans_type_to` int(11) default NULL,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `From` (`trans_type_from`, `trans_no_from`),
+ KEY `To` (`trans_type_to`, `trans_no_to`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`branch_code`,`debtor_no`),
KEY `branch_code` (`branch_code`),
- KEY `br_name` (`br_name`)
+ KEY (`branch_ref`),
+ KEY (`group_no`)
) TYPE=MyISAM AUTO_INCREMENT=1 ;
`trans_link` int(11) NOT NULL default '0',
`dimension_id` int(11) NOT NULL default '0',
`dimension2_id` int(11) NOT NULL default '0',
- PRIMARY KEY (`trans_no`,`type`),
- KEY `debtor_no` (`debtor_no`,`branch_code`)
+ PRIMARY KEY (`type`, `trans_no`),
+ KEY `debtor_no` (`debtor_no`,`branch_code`),
+ KEY (`tran_date`)
) TYPE=InnoDB ;
`discount_percent` double NOT NULL default '0',
`standard_cost` double NOT NULL default '0',
`qty_done` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `Transaction` (`debtor_trans_type`, `debtor_trans_no`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`notes` tinytext NOT NULL,
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`debtor_no`),
- UNIQUE KEY `name` (`name`)
+ UNIQUE KEY `name` (`name`),
+ KEY (`debtor_ref`)
) TYPE=MyISAM AUTO_INCREMENT=1 ;
`date_` date NOT NULL default '0000-00-00',
`due_date` date NOT NULL default '0000-00-00',
PRIMARY KEY (`id`),
- UNIQUE KEY `reference` (`reference`)
+ UNIQUE KEY `reference` (`reference`),
+ KEY (`date_`),
+ KEY (`due_date`),
+ KEY (`type_`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`begin` date default '0000-00-00',
`end` date default '0000-00-00',
`closed` tinyint(1) NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ UNIQUE KEY(`begin`),
+ UNIQUE KEY(`end`)
) TYPE=InnoDB AUTO_INCREMENT=2 ;
`person_type_id` int(11) default NULL,
`person_id` tinyblob,
PRIMARY KEY (`counter`),
- KEY `Type_and_Number` (`type`,`type_no`)
+ KEY `Type_and_Number` (`type`,`type_no`),
+ KEY (`dimension_id`),
+ KEY (`dimension2_id`),
+ KEY (`tran_date`),
+ KEY `account_and_tran_date` (`account`,`tran_date`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`reference` varchar(60) NOT NULL default '',
`delivery_date` date NOT NULL default '0000-00-00',
`loc_code` varchar(5) default NULL,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY(`delivery_date`),
+ KEY(`purch_order_no`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`description` tinytext,
`qty_recd` double NOT NULL default '0',
`quantity_inv` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY (`grn_batch_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`is_foreign` tinyint(1) NOT NULL default '0',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
- UNIQUE KEY `stock_id` (`stock_id`,`item_code`)
+ UNIQUE KEY `stock_id` (`stock_id`,`item_code`),
+ KEY (`item_code`)
) TYPE=MyISAM AUTO_INCREMENT=1 ;
`std_cost_unit` double NOT NULL default '0',
`quantity_ordered` double NOT NULL default '0',
`quantity_received` double NOT NULL default '0',
- PRIMARY KEY (`po_detail_item`)
+ PRIMARY KEY (`po_detail_item`),
+ KEY `order` (`order_no`, `po_detail_item`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`requisition_no` tinytext,
`into_stock_location` varchar(5) NOT NULL default '',
`delivery_address` tinytext NOT NULL,
- PRIMARY KEY (`order_no`)
+ PRIMARY KEY (`order_no`),
+ KEY (`ord_date`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
### Data of table `0_quick_entries` ###
INSERT INTO `0_quick_entries` VALUES ('1', '1', 'Maintenance', '0', 'Amount', '0');
-INSERT INTO `0_quick_entries` VALUES ('2', '4', 'Phone', '0', 'Amount'. '0');
+INSERT INTO `0_quick_entries` VALUES ('2', '4', 'Phone', '0', 'Amount', '0');
INSERT INTO `0_quick_entries` VALUES ('3', '2', 'Cash Sales', '0', 'Amount', '0');
`id` int(11) NOT NULL default '0',
`type` int(11) NOT NULL default '0',
`reference` varchar(100) NOT NULL default '',
- PRIMARY KEY (`id`,`type`)
+ PRIMARY KEY (`id`,`type`),
+ KEY `Type_and_Reference` (`type`,`reference`)
) TYPE=InnoDB ;
`unit_price` double NOT NULL default '0',
`quantity` double NOT NULL default '0',
`discount_percent` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `sorder` (`trans_type`, `order_no`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
CREATE TABLE `0_stock_category` (
`category_id` int(11) NOT NULL auto_increment,
`description` varchar(60) NOT NULL default '',
- `dflt_tax_type` int(11) NOT NULL default '0',
+ `dflt_tax_type` int(11) NOT NULL default '1',
`dflt_units` varchar(20) NOT NULL default 'each',
`dflt_mb_flag` char(1) NOT NULL default 'B',
`dflt_sales_act` varchar(11) NOT NULL default '',
`standard_cost` double NOT NULL default '0',
`visible` tinyint(1) NOT NULL default '1',
PRIMARY KEY (`trans_id`),
- KEY `type` (`type`,`trans_no`)
+ KEY `type` (`type`,`trans_no`),
+ KEY `Move` (`stock_id`,`loc_code`, `tran_date`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`trans_type_from` int(11) default NULL,
`trans_no_to` int(11) default NULL,
`trans_type_to` int(11) default NULL,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `From` (`trans_type_from`, `trans_no_from`),
+ KEY `To` (`trans_type_to`, `trans_no_to`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`unit_price` double NOT NULL default '0',
`unit_tax` double NOT NULL default '0',
`memo_` tinytext,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `Transaction` (`supp_trans_type`, `supp_trans_no`, `stock_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`ov_gst` double NOT NULL default '0',
`rate` double NOT NULL default '1',
`alloc` double NOT NULL default '0',
- PRIMARY KEY (`trans_no`,`type`),
+ PRIMARY KEY (`type`, `trans_no`),
KEY `supplier_id` (`supplier_id`),
KEY `SupplierID_2` (`supplier_id`,`supp_reference`),
- KEY `type` (`type`)
+ KEY `type` (`type`),
+ KEY (`tran_date`)
) TYPE=InnoDB ;
`payment_discount_account` varchar(11) default NULL,
`notes` tinytext NOT NULL,
`inactive` tinyint(1) NOT NULL default '0',
- PRIMARY KEY (`supplier_id`)
+ PRIMARY KEY (`supplier_id`),
+ KEY (`supp_ref`)
) TYPE=MyISAM AUTO_INCREMENT=1 ;
`name` varchar(60) NOT NULL default '',
`inactive` tinyint(1) NOT NULL default '0',
PRIMARY KEY (`id`),
- UNIQUE KEY `name` (`name`,`rate`)
) TYPE=InnoDB AUTO_INCREMENT=2 ;
`net_amount` double NOT NULL default '0',
`amount` double NOT NULL default '0',
`memo` tinytext,
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY `Type_and_Number` (`trans_type`,`trans_no`),
+ KEY (`tran_date`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`issue_date` date default NULL,
`loc_code` varchar(5) default NULL,
`workcentre_id` int(11) default NULL,
- PRIMARY KEY (`issue_no`)
+ PRIMARY KEY (`issue_no`),
+ KEY (`workorder_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`workorder_id` int(11) NOT NULL default '0',
`quantity` double NOT NULL default '0',
`date_` date NOT NULL default '0000-00-00',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY (`workorder_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`std_cost` double NOT NULL default '0',
`loc_code` char(5) NOT NULL default '',
`units_issued` double NOT NULL default '0',
- PRIMARY KEY (`id`)
+ PRIMARY KEY (`id`),
+ KEY (`workorder_id`)
) TYPE=InnoDB AUTO_INCREMENT=1 ;
`ip` varchar(40) NOT NULL default '',
`file` varchar(100) NOT NULL default '',
PRIMARY KEY `id` (`id`) ,
- KEY (`timestamp`)
+ KEY (`timestamp`),
+ KEY(`ip`)
) TYPE=MYISAM AUTO_INCREMENT=1;