-- Create the EMP table
CREATE TABLE company (
    id int(10) PRIMARY KEY NOT NULL AUTO_INCREMENT,
    companyName VARCHAR(100),
    address VARCHAR(300),
    phone VARCHAR(15),
    email VARCHAR(60),
    supplierId INT(6) FOREIGN KEY REFERENCES supplier(id),
    buyerId INT(6) FOREIGN KEY REFERENCES buyertable(id),
    createdBy INT(10),
    createDate date,
    updateBy INT(10),
    updateDate date
);

CREATE TABLE supplier (
    id int(10) PRIMARY KEY NOT NULL AUTO_INCREMENT,
    supplierName VARCHAR(100),
    address VARCHAR(300),
    phone VARCHAR(15),
    email VARCHAR(60),
    companyId int(6),
    createdBy INT(10),
    createDate date,
    updateBy INT(10),
    updateDate date
);
CREATE TABLE item (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    itemName VARCHAR(100),
    categoryId int,
    uom VARCHAR(15),
    createdBy INT,
    createDate date,
    updateBy INT,
    updateDate date
);
CREATE TABLE category (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    categoryName VARCHAR(100),
    uom VARCHAR(15),
    createdBy INT,
    createDate date,
    updateBy INT,
    updateDate date
);
CREATE TABLE style (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    styleName VARCHAR(100),
    createdBy INT,
    createDate date,
    updateBy INT,
    updateDate date
);
CREATE TABLE color (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    colorName VARCHAR(100),
    createdBy INT,
    createDate date,
    updateBy INT,
    updateDate date
);
CREATE TABLE Country (
    id int(10) PRIMARY KEY NOT NULL AUTO_INCREMENT,
    CountryName VARCHAR(100),
    CreateDate date,
    CreatedBy INT(10),
    UpdateDate date,
    UpdateBy INT(10) 
);
CREATE TABLE UserTable (
    id int(10) PRIMARY KEY NOT NULL,
    user_name VARCHAR(100),
    email varchar(100),
    phone VARCHAR(50),
    address VARCHAR(200),
    create_date date,
    created_by int(10),
    update_date date,
    update_by int(10) 
);
CREATE TABLE BuyerTable (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    buyer_name VARCHAR(100),
    email varchar(100),
    phone VARCHAR(50),
    address VARCHAR(200),
    countryId int,
    create_date date,
    created_by int,
    update_date date,
    update_by int 
);
alter table BuyerTable add CountryId number(5);

CREATE TABLE OrderGmt (
    id int(10) PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    qty int(10),
    color VARCHAR(50),
    itemId int(5),
    buyerId int(5),
    orderDate DATE,
    shipMode varchar(50),
    shipDate date,
    supplierId int(5),
    categoryId int(5),
    fobPrice int(5),
    smv int(5),
    efficiency int(5),
    shipmentCountryId int(5),
    styleName int(5),
    countryId int(5),
    createDate date,
    createdBy int(10),
    updateDate date,
    updateBy int(10),
     
    FOREIGN KEY createdBy REFERENCES Usertable(id),
    FOREIGN key updateBy REFERENCES UserTable(id) 
);
CREATE TABLE salesContract (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    orderId int,
    orderQty int,
    poNumber VARCHAR(50),
    itemId int,
    buyerId int,
    orderDate DATE,
    shipMode varchar(50),
    shipDate date,
    lcApplicant varchar(300),
    lienBank varchar(200),
    payTerm varchar(150),
    benificiary varchar(150),
    shipCountryId int,
    createDate date,
    createdBy int,
    updateDate date,
    updateBy int 
);
CREATE TABLE btbLc (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    orderId int,
    orderQty int,
    poNumber VARCHAR(50),
    itemId int,
    supplierId int,
    orderDate DATE,
    shipMode varchar(50),
    shipDate date,
    lcApplicant varchar(300),
    lienBank varchar(200),
    payTerm varchar(150),
    benificiary varchar(150),
    shipCountryId int,
    createDate date,
    createdBy int,
    updateDate date,
    updateBy int 
);
CREATE TABLE pitable (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    orderId int,
    orderQty int,
    poNumber VARCHAR(50),
    itemId int,
    supplierId int,
    orderDate DATE,
    shipMode varchar(50),
    shipDate date,
    lcApplicant varchar(300),
    lienBank varchar(200),
    payTerm varchar(150),
    benificiary varchar(150),
    shipCountryId int,
    currency varchar(50),
    exchangeRate int,
    createDate date,
    createdBy int,
    updateDate date,
    updateBy int 
);
CREATE TABLE exportinvoice (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    orderId int,
    orderQty int,
    lcNumber VARCHAR(50),
    invoiceValue int,
    buyerId int,
    invoiceDate DATE,
    shipMode varchar(50),
    shipDate date,
    exportformnumber varchar(300),
    shipCountryId int,
    currency varchar(50),
    exchangeRate int,
    createDate date,
    createdBy int,
    updateDate date,
    updateBy int 
);
ALTER TABLE `exportinvoice` ADD `buyerid` INT NOT NULL AFTER `shipCountryId`;

CREATE TABLE importinvoice (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    orderId int,
    orderQty int,
    lcNumber VARCHAR(50),
    invoiceValue int,
    supplierId int,
    invoiceDate DATE,
    shipMode varchar(50),
    shipDate date,
    exportformnumber varchar(300),
    shipCountryId int,
    currency varchar(50),
    exchangeRate int,
    createDate date,
    createdBy int,
    updateDate date,
    updateBy int 
);
CREATE TABLE docSubmission (
    id int PRIMARY KEY NOT NULL AUTO_INCREMENT,
    systemId VARCHAR(50),
    orderId int,
    lcNumber VARCHAR(50),
    invoiceValue int,
    buyerId int,
    docSubDate DATE,
    certificate varchar(50),
    shipDate date,
    exportformnumber varchar(300),
    bankrefnumber varchar(300),
    shipCountryId int,
    currency varchar(50),
    exchangeRate int,
    createDate date,
    createdBy int,
    updateDate date,
    updateBy int 
);

INSERT INTO `country` (`country_code`, `country_name`)  VALUES 
('US', 'United States'),
('CA', 'Canada'),
('AF', 'Afghanistan'),
('AL', 'Albania'),
('DZ', 'Algeria'),
('AS', 'American Samoa'),
('AD', 'Andorra'),
('AO', 'Angola'),
( 'AI', 'Anguilla'),
( 'AQ', 'Antarctica'),
( 'AG', 'Antigua and/or Barbuda'),
( 'AR', 'Argentina'),
( 'AM', 'Armenia'),
( 'AW', 'Aruba'),
( 'AU', 'Australia'),
( 'AT', 'Austria'),
( 'AX', 'Åland Islands'),
( 'AZ', 'Azerbaijan'),
( 'BS', 'Bahamas'),
( 'BH', 'Bahrain'),
('BD', 'Bangladesh'),
( 'BB', 'Barbados'),
( 'BY', 'Belarus'),
( 'BE', 'Belgium'),
( 'BZ', 'Belize'),
( 'BJ', 'Benin'),
( 'BM', 'Bermuda'),
( 'BT', 'Bhutan'),
( 'BO', 'Bolivia'),
( 'BA', 'Bosnia and Herzegovina'),
( 'BW', 'Botswana'),
( 'BV', 'Bouvet Island'),
( 'BR', 'Brazil'),
( 'IO', 'British lndian Ocean Territory'),
( 'BN', 'Brunei Darussalam'),
( 'BG', 'Bulgaria'),
( 'BF', 'Burkina Faso'),
( 'BI', 'Burundi'),
( 'KH', 'Cambodia'),
( 'CM', 'Cameroon'),
( 'CV', 'Cape Verde'),
( 'KY', 'Cayman Islands'),
( 'CF', 'Central African Republic'),
( 'TD', 'Chad'),
( 'CL', 'Chile'),
( 'CN', 'China'),
( 'CX', 'Christmas Island'),
( 'CC', 'Cocos (Keeling) Islands'),
( 'CO', 'Colombia'),
( 'KM', 'Comoros'),
( 'CG', 'Congo'),
( 'CK', 'Cook Islands'),
( 'CR', 'Costa Rica'),
( 'HR', 'Croatia (Hrvatska)'),
( 'CU', 'Cuba'),
( 'CY', 'Cyprus'),
( 'CZ', 'Czech Republic'),
( 'DK', 'Denmark'),
( 'DJ', 'Djibouti'),
( 'DM', 'Dominica'),
( 'DO', 'Dominican Republic'),
( 'TP', 'East Timor'),
( 'EC', 'Ecuador'),
( 'EG', 'Egypt'),
( 'SV', 'El Salvador'),
( 'GQ', 'Equatorial Guinea'),
( 'ER', 'Eritrea'),
( 'EE', 'Estonia'),
( 'ET', 'Ethiopia'),
( 'FK', 'Falkland Islands (Malvinas)'),
( 'FO', 'Faroe Islands'),
( 'FJ', 'Fiji'),
( 'FI', 'Finland'),
( 'FR', 'France'),
( 'FX', 'France, Metropolitan'),
( 'GF', 'French Guiana'),
( 'PF', 'French Polynesia'),
( 'TF', 'French Southern Territories'),
( 'GA', 'Gabon'),
( 'GM', 'Gambia'),
( 'GE', 'Georgia'),
( 'DE', 'Germany'),
( 'GH', 'Ghana'),
( 'GI', 'Gibraltar'),
( 'GR', 'Greece'),
( 'GL', 'Greenland'),
( 'GD', 'Grenada'),
( 'GP', 'Guadeloupe'),
( 'GU', 'Guam'),
( 'GT', 'Guatemala'),
( 'GN', 'Guinea'),
( 'GW', 'Guinea-Bissau'),
( 'GY', 'Guyana'),
( 'HT', 'Haiti'),
( 'HM', 'Heard and Mc Donald Islands'),
( 'HN', 'Honduras'),
( 'HK', 'Hong Kong'),
( 'HU', 'Hungary'),
( 'IS', 'Iceland'),
( 'IN', 'India'),
( 'ID', 'Indonesia'),
( 'IR', 'Iran (Islamic Republic of)'),
( 'IQ', 'Iraq'),
( 'IE', 'Ireland'),
( 'IL', 'Israel'),
( 'IT', 'Italy'),
( 'CI', 'Ivory Coast'),
( 'JM', 'Jamaica'),
( 'JP', 'Japan'),
( 'JO', 'Jordan'),
( 'KZ', 'Kazakhstan'),
( 'KE', 'Kenya'),
( 'KI', 'Kiribati'),
( 'KP', 'Korea, Democratic People''s Republic of'),
( 'KR', 'Korea, Republic of'),
( 'XK', 'Kosovo'),
( 'KW', 'Kuwait'),
( 'KG', 'Kyrgyzstan'),
( 'LA', 'Lao People''s Democratic Republic'),
( 'LV', 'Latvia'),
( 'LB', 'Lebanon'),
( 'LS', 'Lesotho'),
( 'LR', 'Liberia'),
( 'LY', 'Libyan Arab Jamahiriya'),
( 'LI', 'Liechtenstein'),
( 'LT', 'Lithuania'),
( 'LU', 'Luxembourg'),
( 'MO', 'Macau'),
( 'MK', 'Macedonia'),
( 'MG', 'Madagascar'),
( 'MW', 'Malawi'),
( 'MY', 'Malaysia'),
( 'MV', 'Maldives'),
( 'ML', 'Mali'),
( 'MT', 'Malta'),
( 'MH', 'Marshall Islands'),
( 'MQ', 'Martinique'),
( 'MR', 'Mauritania'),
( 'MU', 'Mauritius'),
( 'TY', 'Mayotte'),
( 'MX', 'Mexico'),
( 'FM', 'Micronesia, Federated States of'),
( 'MD', 'Moldova, Republic of'),
( 'MC', 'Monaco'),
( 'MN', 'Mongolia'),
( 'ME', 'Montenegro'),
( 'MS', 'Montserrat'),
( 'MA', 'Morocco'),
( 'MZ', 'Mozambique'),
( 'MM', 'Myanmar'),
( 'NA', 'Namibia'),
( 'NR', 'Nauru'),
( 'NP', 'Nepal'),
( 'NL', 'Netherlands'),
( 'AN', 'Netherlands Antilles'),
( 'NC', 'New Caledonia'),
( 'NZ', 'New Zealand'),
( 'NI', 'Nicaragua'),
( 'NE', 'Niger'),
( 'NG', 'Nigeria'),
( 'NU', 'Niue'),
( 'NF', 'Norfork Island'),
( 'MP', 'Northern Mariana Islands'),
( 'NO', 'Norway'),
( 'OM', 'Oman'),
( 'PK', 'Pakistan'),
( 'PW', 'Palau'),
( 'PA', 'Panama'),
( 'PG', 'Papua New Guinea'),
( 'PY', 'Paraguay'),
( 'PE', 'Peru'),
( 'PH', 'Philippines'),
( 'PN', 'Pitcairn'),
( 'PL', 'Poland'),
( 'PT', 'Portugal'),
( 'PR', 'Puerto Rico'),
( 'QA', 'Qatar'),
( 'RE', 'Reunion'),
( 'RO', 'Romania'),
( 'RU', 'Russian Federation'),
( 'RW', 'Rwanda'),
( 'KN', 'Saint Kitts and Nevis'),
( 'LC', 'Saint Lucia'),
( 'VC', 'Saint Vincent and the Grenadines'),
( 'WS', 'Samoa'),
( 'SM', 'San Marino'),
( 'ST', 'Sao Tome and Principe'),
( 'SA', 'Saudi Arabia'),
( 'SN', 'Senegal'),
( 'RS', 'Serbia'),
( 'SC', 'Seychelles'),
( 'SL', 'Sierra Leone'),
( 'SG', 'Singapore'),
( 'SK', 'Slovakia'),
( 'SI', 'Slovenia'),
( 'SB', 'Solomon Islands'),
( 'SO', 'Somalia'),
( 'ZA', 'South Africa'),
( 'GS', 'South Georgia South Sandwich Islands'),
( 'ES', 'Spain'),
( 'LK', 'Sri Lanka'),
( 'SH', 'St. Helena'),
( 'PM', 'St. Pierre and Miquelon'),
( 'SD', 'Sudan'),
( 'SR', 'Suriname'),
( 'SJ', 'Svalbarn and Jan Mayen Islands'),
( 'SZ', 'Swaziland'),
( 'SE', 'Sweden'),
( 'CH', 'Switzerland'),
( 'SY', 'Syrian Arab Republic'),
( 'TW', 'Taiwan'),
( 'TJ', 'Tajikistan'),
( 'TZ', 'Tanzania, United Republic of'),
( 'TH', 'Thailand'),
( 'TG', 'Togo'),
( 'TK', 'Tokelau'),
( 'TO', 'Tonga'),
( 'TT', 'Trinidad and Tobago'),
( 'TN', 'Tunisia'),
( 'TR', 'Turkey'),
( 'TM', 'Turkmenistan'),
( 'TC', 'Turks and Caicos Islands'),
( 'TV', 'Tuvalu'),
( 'UG', 'Uganda'),
( 'UA', 'Ukraine'),
( 'AE', 'United Arab Emirates'),
( 'GB', 'United Kingdom'),
( 'UM', 'United States minor outlying islands'),
( 'UY', 'Uruguay'),
( 'UZ', 'Uzbekistan'),
( 'VU', 'Vanuatu'),
( 'VA', 'Vatican City State'),
( 'VE', 'Venezuela'),
( 'VN', 'Vietnam'),
( 'VG', 'Virgin Islands (British)'),
( 'VI', 'Virgin Islands (U.S.)'),
( 'WF', 'Wallis and Futuna Islands'),
( 'EH', 'Western Sahara'),
( 'YE', 'Yemen'),
( 'YU', 'Yugoslavia'),
( 'YT', 'Mayotte'),
( 'ZR', 'Zaire'),
( 'ZM', 'Zambia'),
( 'ZW', 'Zimbabwe');

INSERT INTO `buyertable` (`country_code`, `country_name`)  VALUES 
('US', 'United States'),
('CA', 'Canada'),
('AF', 'Afghanistan'),
('AL', 'Albania'),
('DZ', 'Algeria'),
('AS', 'American Samoa'),
('AD', 'Andorra'),
('AO', 'Angola'),
( 'AI', 'Anguilla'),
( 'AQ', 'Antarctica'),
( 'AG', 'Antigua and/or Barbuda'),
( 'AR', 'Argentina'),
( 'AM', 'Armenia'),
( 'AW', 'Aruba'),
( 'AU', 'Australia'),
( 'AT', 'Austria'),
( 'AX', 'Åland Islands'),
( 'AZ', 'Azerbaijan');