Ruby on Rails
HowtoUsareSchemiLegacy

Stavo lavorando per mettere un’interfaccia Rails su una vecchia applicazione. Il problema è che molte delle assunzioni fatte da Rails non esistevano nello schema esistente.
set_table_name ‘modulgruppen’

Ci sono un certo numero di tecniche che ci possono aiutare a risolvere questo problema:

Sono indicati in primo luogo un breve esempio per ogni tecnica, seguito da un esempio carino di utilizzo reale da (Seraphim) che mostra molti di queste tecniche in uso.

Configurare environment.rb per fare in modo che non cerchi i nomi delle tabelle al plurale

Aprite config/environment.rb e scorrete verso il basso il commento fino a “Include your application configuration below”. Aggiungete la linea

ActiveRecord::Base.pluralize_table_names = false

Questo vi permetterà di utilizzare il generatore di scripts se non avete utilizzato dei nomi plurali per i nomi tabelle.

Utilizzando set_table_name per i nomi tabelle che non rispettano la convenzione di rails

Utilizzando il “set_table_name " potete fare in modo che un oggetto ”http://wiki.rubyonrails.com/rails/pages/ActiveRecord" class="existingWikiWord">ActiveRecord si riferisca a qualsiasi tabella voi vogliate.

class Entity < ActiveRecord::Base set_table_name “entity” end

Utilizzando set_primary_key per quelle tabella le cui chiavi primarie non si chiamano id

Se il vostro database utilizza nomi differenti per le sue colonne a chiave primaria, potete chiamare il “set_primary_key” per definire qualsiasi colonna voi vogliate.

class Entity < ActiveRecord::Base set_primary_key “entity_id” end

Utilizzando le viste per i dati in sola lettura

Se avete delle tabelle sul database che assomigliato a questo

create table macchine (macchina_id serial primary key,costruttore_id int, modello_id int); create table costruttori (costruttore_id serial primary key , costruttore_nome text); create table modelli (modello_id serial primary key, modello_name text);

e siete piuttosto sicuri di avere i valori direttamente nell’oggetto macchina, potete scrivere una vista come questa

<pre> -- una vista per descrivere una macchina su rails:-) create view rail_macchine as select macchina_id as id, * from macchine natural join costruttori natural join modelli; </pre>

Allo scopo di lettura, rail_macchine ora dovrebbe agire come un un normale oggetto rails che include il nome del costruttore e del modello.

Utilizzando le regole (rules) PostgreSQL per permettere gli aggiornamenti sulle viste per i dati modificabili

Il sistema “rule” di PostgreSQL vi permette di creare le viste aggiornabili [www.postgresql.org]

Guardare HowtoUsareVistePostgresComeTabelle per istruzioni dettagliate

Utilizzando find_by_sql per le interrogazioni arbitrarie complesse o per le tabelle senza chiave primaria

Se le vostre tabella non hanno delle chiavi primarie logiche potete sempre riservarvi di utilizzare find_by_sql per eseguire delle interrogazioni arbitrarie complesse che non richiedono da nessuna parte una chiave primaria.

<pre> Post.find_by_sql ["SELECT * FROM posts WHERE author = ? AND created > ?", author_id, start_date] </pre>

Utilizzando before_validate_on_create per le chiavi primarie che non si autogenerano.

[Qualcuno mi ha dato questo suggerimento, ma non l’ho ancora provato] ok ho visto questo in molti posti e nella documentazione delle API ma non riesco a farlo funzionare. Qualcuno può creare un esempio di codice reale e dirmi dove inserirlo (es. active record, controller, etc.)? Nello specifico, ho uno schema con una tabella(e) che utilizza l’algoritmo ‘select max(ID_COLUMN)+1 from LEGACY_TABLE’per ottenere l’ID successivo da utilizzare nella chiave primaria. Ho creato un metodo per fare ciò ma Rails sembra voler ottenere questo valore dalla sequence (che non esiste).

Risposta alla domanda qui di sopra (2005-02-03), guardare questa pagina: HowToUsareIDNonGeneratiDalDatabase?

Utilizzando le chiavi primarie composte

Rails non supporta nativamente le chiavi primarie composte (es. primary key(col1, col2)). Qualcuno vorrebbe cortesemente spiegarmi come fare a gestirle?

Le ragioni per utilizzare un chiave primaria composta possono essere:

Una possibile soluzione per utilizzare le chiavi primarie composte:

Aggiungere una colonna id alla tabella interessata. Fate in modo che questa colonna sia autoincrementante.

E usate set_primary_key ‘id’ sulla vostra classe active record. Nessun bisogno di cambiare la definizio del database. Aggiungere una colonna id dovrebbe ovviare il problema.

Generando accessori agli attributi senza i prefissi di colonna

un breve articolo su questo argomento, il cui codice è il seguente:


class << ActiveRecord::Base

  def set_column_prefix(prefix)
    column_names.each do |name|
      next if name == primary_key

      if name[/#{prefix}(.*)/e]
        a = $1

        define_method(a.to_sym) do
          read_attribute(name)
        end

        define_method("#{a}=".to_sym) do |value|
          write_attribute(name, value)
        end

      end
    end
  end
end

E viene utilizzato come:


class NewsSection < ActiveRecord::Base
  set_table_name 'nact_news_section'
  set_primary_key 'ns_id'
  set_column_prefix 'ns_'
end

Potete utilizzare questa tecnica per mappare qualsiasi tipo di fastidio sistematico nei nomi delle colonne.

Esempio di codice in applicazioni reali: Sistemare i modelli per allinearsi ai dati (Seraphim)

Di seguito è spiegato come sistemare i modelli.

Qui, alla casa di pubblicazione, abbiamo un database legacy che ho pensato di agganciare a Rails. La parte rilevante dello schema appare più o meno come questo (i nomi sono stati cambiati per proteggere il colpevole):

CREATE TABLE people ( p_ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY, p_Title VARCHAR, p_FirstName VARCHAR, p_LastName VARCHAR, …); CREATE TABLE bookentries ( BookID INT NOT NULL AUTO_INCREMENT PRIMARY KEY, PersonID INT, BookText TEXT, …); CREATE TABLE books ( ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY, BookName VARCHAR, …); CREATE TABLE office ( o_ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY, o_Title VARCHAR, o_Address TEXT, city_id INT, …); CREATE TABLE city ( city_id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, city_name VARCHAR, …); CREATE TABLE peoplelink ( ID INT NOT NULL AUTO_INCREMENT PRIMARY KEY, p_ID INT, o_ID INT );

Stiamo collezionando delle registrazioni riguardo alle persone e in quale directory vanno e di quale tipo. Per ogni persona (person) in ogni libro(book), abbiamo bisogno di essere in grado di collezionare le informazioni di entrambi e dei loro uffici, e delle informazioni specifiche alle loro registrazioni nel libro.

Prima di iniziare a poterci preoccupare delle relazioni, dobbiamo definire prima alcuni principi base. In primo luogo Rails necessita di sapere come trovare i dati – gli dobbiamo dire i nomi tabelle e gli indici. Questo viene fatto sovrascrivendo i metodi \ActiveRecord::Base.table_name() e primary_key in questo modo:

class Office < ActiveRecord::Base
set_table_name “office”
set_primary_key “o_ID”
end

…e via dicendo per ognuna delle nostre quattro classi.

Fatto questo, possiamo iniziare a lavorare sulle relazioni.

Le relazioni da implementare sono le seguenti:

Qui c’è come funziona in Rails. Abbiamo quattro modelli base, Person, Office, City e Book. La classe Person has_and_belongs_to_many (ha e appartiene a molti) Offices (Uffici), e has_and_belongs_to_many (ha e appartiene a molti) Books (Libri). la classe Office (Ufficio) belongs_to (appartiene a) a una City (Città), e la classe City (Città) has_many (ha molti) Offices (Uffici).
Iniziamo dal più semplice. Per dire che un Office appartiene a una classe City, facciamo:

belongs_to :city, :foreign_key=> “city_id”

in testa al file office.rb. La definizione :foreign_key @ dice ad \ActiveRecord di cercare il campo @city_id nella tabella mappata alla classe office. Per un caso, questo campo ha lo stesso nome che ActiveRecord si aspetterebbe di trovare
La relazione inversa è:

has_many :offices, :foreign_key => ‘city_id’

in testa al file city.rb. Ora, poichè questa è una relazione di tipo has_many, la definizione della :foreign_key dice ad \ActiveRecord di guardare nella tabella mappata ad office.

Le relazioni molti a molti non sono molto più complicate.

has_and_belongs_to_many :offices, :join_table => peoplelink’, \ :foreign_key => ‘p_ID’, :association_foreign_key => ‘o_ID’

Questo va dentro il file person.rb. La definizione della :foreign_key e della :association_foreign_key si riferiscono entrambe ai nomi campi all’interno della tabella peoplelink. Può risultare utile definire il contrario, ma non lo farò qui. Dovrebbe essere abbastanza ovvio.

Per renderlo chiaro, la relazione finale, tra people e books, è definita in questo modo:

has_and_belongs_to_many :books, :join_table => ‘bookentries’, \ :foreign_key => ‘PersonID’, :association_foreign_key => ‘BookID’

Che fa in modo che tutto abbia un senso, ma lo scaffold non leggerà le FK nello schema originale del database? Sono un pò confuso riguardo al punto d’entrata di un grande schema che ha già le proprie chiavi definite. Da qualche altra parte ho letto che si deve fisicamente definire un campo di connessione in una relazione uno a molti per fare in modo che scaffold funzioni. E’ questo il caso?

Qual’è il modo più semplice per forzare il downcasing degli attributi di un Modello per una tabella che ha i nomi dei propri campi definiti in maniera mista o tutti maiuscoli?

Ricevete degli errori di Segmentation Faults con i databases Legacy?

Questa era il mio problema. Rails funzionava perfettamente con un database “rails” ma quando ho provato a connetterlo con un database legacy si incrocchiava e bruciava. Dopo settimane di perdita di capelli ho fatto questo piccolo passo.

gem uninstall mysql

Ho poi installato gli ultimi bindings ruby-mysql da
qui
Questo ha risolto i problemi con mysql4.1+ che avevo.

Bath and Shower
Fragrance
Gift Sets
Hair Care
Makeup
Men’s Grooming
Shaving and Hair Removal
Skin Care
Tools and Accessories

Baby Apparel
Baby Bathing & Skin Care
Baby Bedding
Baby Car Seats
Baby Diapering
Baby Feeding
For Moms
Baby Furniture
Baby Gear
Baby Gifts
Baby Health & Baby Care
Nursery Décor
Potty Training
Baby Safety
Baby Strollers

Books – Business & Investing
Books – Children’s Books
Books – Comics & Graphic Novels
Books – Computers & Internet
Books – Cooking, Food & Wine
Books – Entertainment
Books – Gay & Lesbian
Books – Health, Mind & Body
Books – History
Books – Home & Garden
Books – Law
Books – Literature & Fiction
Books – Medicine
Books – Mystery & Thrillers
Books – Nonfiction
Books – Outdoors & Nature
Books – Parenting & Families
Books – Professional & Technical
Books – Reference
Books – Religion & Spirituality
Books – Romance
Books – Science
Books – Science Fiction & Fantasy
Books – Sports
Books – Teens
Books – Travel

Camera & Photo – Accessories
Camera & Photo – Camcorders
Camera & Photo – Digital Cameras
Camera & Photo – Film Cameras
Camera & Photo – Optics
Camera & Photo – Printers & Scanners

Health & Personal Care – Baby & Child Care
Health & Personal Care – Food & Snacks
Health & Personal Care – Health & Personal Care Outlet Store
Health & Personal Care – Health Care
Health & Personal Care – House Supplies
Health & Personal Care – Nutrition & Fitness
Health & Personal Care – Personal Care
Health & Personal Care – Sexual Wellness

Computers – Computer Add-Ons
Computers – Desktops
Computers – Handhelds & PDAs
Computers – Notebooks

Electronics – Accessories & Supplies
Electronics – Audio & Video
Electronics – Camera & Photo
Electronics – Car Electronics
Electronics – Computers & Add-Ons
Electronics – GPS & Navigation
Electronics – Home Automation & Security
Electronics – Office Electronics
Electronics – Service & Replacement Plans

Gourmet Food – Appetizers & Hors d’oeuvres
Gourmet Food – Baking Supplies
Gourmet Food – Beverages
Gourmet Food – Bread
Gourmet Food – Breakfast Foods
Gourmet Food – Candy
Gourmet Food – Cheese
Gourmet Food – Chocolate
Gourmet Food – Coffee & Tea
Gourmet Food – Cookies
Gourmet Food – Dairy Foods & Eggs
Gourmet Food – Desserts
Gourmet Food – Fruits & Vegetables
Gourmet Food – Gourmet Gifts
Gourmet Food – Jams, Jellies & Preserves
Gourmet Food – Meat, Game & Pâtés
Gourmet Food – Oils, Vinegars & Salad Dressings
Gourmet Food – Pasta, Beans, Grains & Rice
Gourmet Food – Prepared Meals
Gourmet Food – Salsas & Condiments
Gourmet Food – Seafood & Caviar
Gourmet Food – Seasonings, Herbs & Spices
Gourmet Food – Snack Food
Gourmet Food – Soups & Stocks

Grocery – Appetizers & Hors D’Oeuvres
Grocery – Baking Supplies
Grocery – Beverages
Grocery – Boxed Meals & Side Dishes
Grocery – Breads
Grocery – Breakfast Foods
Grocery – Canned & Packaged Goods
Grocery – Coffee, Tea & Cocoa
Grocery – Condiments, Sauces & Spreads
Grocery – Dairy & Eggs
Grocery – Desserts & Pastries
Grocery – Fruits & Vegetables
Grocery – Health & Family
Grocery – Herbs, Spices & Seasonings
Grocery – Household Supplies
Grocery – Meats
Grocery – Pasta & Grains
Grocery – Pet Supplies
Grocery – Seafood
Grocery – Snacks, Cookies & Candy

Home & Garden – Backyard Birding
Home & Garden – Bar Tools & Glasses
Home & Garden – Bedding & Bath
Home & Garden – Coffee, Tea & Espresso
Home & Garden – Cook’s Tools & Gadgets
Home & Garden – Cookware & Baking
Home & Garden – Cutlery
Home & Garden – Fresh Flowers & Indoor Plants
Home & Garden – Furniture & Décor
Home & Garden – Gardening Tools
Home & Garden – Grills, Smokers & Outdoor Cooking
Home & Garden – Heating & Lighting
Home & Garden – Kitchen & Table Linens
Home & Garden – Large Appliances
Home & Garden – Leisure & Fitness
Home & Garden – Outdoor Décor
Home & Garden – Patio Furniture
Home & Garden – Pest Control
Home & Garden – Pet Supplies
Home & Garden – Plants & Planting
Home & Garden – Small Appliances
Home & Garden – Tableware
Home & Garden – Vacuums, Cleaning & Storage
Home & Garden – Weather Instruments
Home & Garden – Wine Accessories

Industrial & Scientific – Adhesive Tapes
Industrial & Scientific – Fasteners
Industrial & Scientific – Industrial Abrasives
Industrial & Scientific – Industrial Adhesives
Industrial & Scientific – Industrial Cutting Tools
Industrial & Scientific – Industrial Hoses
Industrial & Scientific – Material Handling Equipment
Industrial & Scientific – Mechanical Components
Industrial & Scientific – Precision Measurement Products
Industrial & Scientific – Raw Materials

Jewelry – Accessories
Jewelry – Body Jewelry
Jewelry – Bracelets
Jewelry – Brooches & Pins
Jewelry – Charms
Jewelry – Children’s Jewelry
Jewelry – Earrings
Jewelry – Engagement
Jewelry – Jewelry Sets
Jewelry – Men’s Jewelry
Jewelry – Necklaces & Pendants
Jewelry – Religious Jewelry
Jewelry – Rings
Jewelry – Wedding & Anniversary

Kindle Store – Advice & How-to
Kindle Store – Arts & Entertainment
Kindle Store – Biographies & Memoirs
Kindle Store – Business & Investing
Kindle Store – Children’s Chapter Books
Kindle Store – Computers & Internet
Kindle Store – Fantasy
Kindle Store – Fiction
Kindle Store – History
Kindle Store – Humor
Kindle Store – Lifestyle & Home
Kindle Store – Literary Fiction
Kindle Store – Mystery & Thrillers
Kindle Store – Nonfiction
Kindle Store – Parenting & Families
Kindle Store – Politics & Current Events
Kindle Store – Reference
Kindle Store – Religion & Spirituality
Kindle Store – Romance
Kindle Store – Science
Kindle Store – Science Fiction
Kindle Store – Sports
Kindle Store – Travel

Kitchen & Housewares – Bar Tools & Glasses
Kitchen & Housewares – Coffee, Tea & Espresso
Kitchen & Housewares – Cook’s Tools & Gadgets
Kitchen & Housewares – Cookware & Baking
Kitchen & Housewares – Cutlery
Kitchen & Housewares – Dining Room Furniture
Kitchen & Housewares – Kitchen & Table Linens
Kitchen & Housewares – Kitchen Furniture
Kitchen & Housewares – Small Appliances
Kitchen & Housewares – Storage & Organization
Kitchen & Housewares – Tableware
Kitchen & Housewares – Wine Accessories

Magazine Subscriptions – Arts & Crafts
Magazine Subscriptions – Automotive
Magazine Subscriptions – Bridal
Magazine Subscriptions – Business & Finance
Magazine Subscriptions – Children’s
Magazine Subscriptions – Computer & Internet
Magazine Subscriptions – Electronics & Audio
Magazine Subscriptions – Entertainment
Magazine Subscriptions – Family & Parenting
Magazine Subscriptions – Fashion & Style
Magazine Subscriptions – Food & Gourmet
Magazine Subscriptions – Games & Hobbies
Magazine Subscriptions – Gay & Lesbian
Magazine Subscriptions – Health & Fitness
Magazine Subscriptions – History
Magazine Subscriptions – Home & Garden
Magazine Subscriptions – International
Magazine Subscriptions – Lifestyle & Cultures
Magazine Subscriptions – Literary
Magazine Subscriptions – Men’s Interest
Magazine Subscriptions – Music
Magazine Subscriptions – News & Politics
Magazine Subscriptions – Pets
Magazine Subscriptions – Religion & Spirituality
Magazine Subscriptions – Science & Nature
Magazine Subscriptions – Sports & Leisure
Magazine Subscriptions – Teens
Magazine Subscriptions – Travel & Regional
Magazine Subscriptions – Women’s Interest

Miscellaneous – Aircraft
Miscellaneous – Antiques
Miscellaneous – Coins
Miscellaneous – Collectibles
Miscellaneous – General
Miscellaneous – Other Products
Miscellaneous – Scientific Supplies
Miscellaneous – Stamps
Miscellaneous – Vehicles
Miscellaneous – Watercraft

MP3 Downloads – MP3 Albums
MP3 Downloads – MP3 Songs

Music – Alternative Rock
Music – Blues
Music – Broadway & Vocalists
Music – Children’s Music
Music – Christian & Gospel
Music – Classic Rock
Music – Classical
Music – Country
Music – Dance & DJ
Music – Folk
Music – Hard Rock & Metal
Music – International
Music – Jazz
Music – Latin Music
Music – Miscellaneous
Music – New Age
Music – Pop
Music – R&B
Music – Rap & Hip-Hop
Music – Rock
Music – Soundtracks

Classical Music – Ballads
Classical Music – Canons
Classical Music – Concertos
Classical Music – Etudes
Classical Music – Fantasies
Classical Music – Fugues
Classical Music – Improvisation
Classical Music – Inventions
Classical Music – Lullabies & Berceuse
Classical Music – Oratorio
Classical Music – Preludes
Classical Music – Requiems, Elegies & Tombeau
Classical Music – Rondos
Classical Music – Scherzo
Classical Music – Serenades & Divertimentos
Classical Music – Short Forms
Classical Music – Sonatas
Classical Music – Suites
Classical Music – Symphonies
Classical Music – Theatrical, Incidental & Program Music
Classical Music – Toccatas
Classical Music – Variations

Musical Instruments – Band & Orchestra
Musical Instruments – Bass Guitars
Musical Instruments – DJ, Electronic Music & Karaoke
Musical Instruments – Drums & Percussion
Musical Instruments – Folk & World Instruments
Musical Instruments – Guitars
Musical Instruments – Instrument Accessories
Musical Instruments – Keyboards
Musical Instruments – Live Sound & Stage
Musical Instruments – Recording Equipment

Office Products – Business Presentation Supplies
Office Products – Educational Supplies
Office Products – Mailroom Supplies
Office Products – Office Furniture & Accessories
Office Products – Office Lighting
Office Products – Office Supplies

Cell Phones & Service – All
Cell Phones & Service – Bluetooth
Cell Phones & Service – Camera
Cell Phones & Service – E-mail
Cell Phones & Service – Flip
Cell Phones & Service – Kid’s
Cell Phones & Service – Mobile Broadband Cards
Cell Phones & Service – MP3
Cell Phones & Service – PDA
Cell Phones & Service – Prepaid
Cell Phones & Service – Video
Cell Phones & Service – Wi-Fi

Software – Business & Office
Software – Children’s Software
Software – Education & Reference
Software – Graphics
Software – Home & Hobbies
Software – Language & Travel
Software – Linux
Software – Macintosh
Software – Networking
Software – Operating Systems
Software – Outlet
Software – Personal Finance
Software – Programming
Software – Software for Handhelds
Software – Utilities
Software – Video & Music
Software – Web Development

Sports & Outdoors – Accessories
Sports & Outdoors – Airsoft
Sports & Outdoors – Apparel
Sports & Outdoors – Archery
Sports & Outdoors – Badminton
Sports & Outdoors – Ballet & Dance
Sports & Outdoors – Baseball
Sports & Outdoors – Basketball
Sports & Outdoors – Boating
Sports & Outdoors – Bowling
Sports & Outdoors – Boxing
Sports & Outdoors – Camping & Hiking
Sports & Outdoors – Cheerleading
Sports & Outdoors – Climbing
Sports & Outdoors – Crew
Sports & Outdoors – Cricket
Sports & Outdoors – Curling
Sports & Outdoors – Cycling & Wheel Sports
Sports & Outdoors – Disc Sports
Sports & Outdoors – Diving
Sports & Outdoors – Dog Sports
Sports & Outdoors – Equestrian Sports
Sports & Outdoors – Exercise & Fitness
Sports & Outdoors – Fan Shop
Sports & Outdoors – Fencing
Sports & Outdoors – Field Hockey
Sports & Outdoors – Fishing
Sports & Outdoors – Football
Sports & Outdoors – Game Room
Sports & Outdoors – Golf
Sports & Outdoors – Gymnastics
Sports & Outdoors – Hockey
Sports & Outdoors – Hunting
Sports & Outdoors – Jai Alai
Sports & Outdoors – Kayaking
Sports & Outdoors – Lacrosse
Sports & Outdoors – Lawn Games
Sports & Outdoors – Martial Arts
Sports & Outdoors – Motor Sports
Sports & Outdoors – Paddle Court Sports
Sports & Outdoors – Paintball
Sports & Outdoors – Pilates
Sports & Outdoors – Polo
Sports & Outdoors – Racquetball
Sports & Outdoors – Rodeo
Sports & Outdoors – Rugby
Sports & Outdoors – Running
Sports & Outdoors – RV Equipment
Sports & Outdoors – Scooters
Sports & Outdoors – Shoes
Sports & Outdoors – Skateboarding
Sports & Outdoors – Skating
Sports & Outdoors – Skydiving
Sports & Outdoors – Sledding
Sports & Outdoors – Snow Skiing
Sports & Outdoors – Snowboarding
Sports & Outdoors – Snowmobiling
Sports & Outdoors – Snowshoeing
Sports & Outdoors – Soccer
Sports & Outdoors – Softball
Sports & Outdoors – Sports Medicine
Sports & Outdoors – Squash
Sports & Outdoors – Surfing
Sports & Outdoors – Swimming
Sports & Outdoors – Tennis & Racquet Sports
Sports & Outdoors – Track & Field
Sports & Outdoors – Triathlon
Sports & Outdoors – Volleyball
Sports & Outdoors – Water Polo
Sports & Outdoors – Water Sports
Sports & Outdoors – Windsurfing
Sports & Outdoors – Wrestling
Sports & Outdoors – Yoga

Tools & Hardware – Air Tools
Tools & Hardware – Appliances
Tools & Hardware – Building Supplies & Heavy Equipment
Tools & Hardware – Electrical
Tools & Hardware – Hand Tools
Tools & Hardware – Hardware
Tools & Hardware – Heating & Cooling
Tools & Hardware – Home Improvement Outlet
Tools & Hardware – Lawn & Garden
Tools & Hardware – Lighting
Tools & Hardware – Organization & Storage
Tools & Hardware – Painting Tools & Supplies
Tools & Hardware – Plumbing
Tools & Hardware – Power Tool Accessories
Tools & Hardware – Power Tools
Tools & Hardware – Safety & Security

Toys & Games – Action Figures
Toys & Games – Activities & Amusements
Toys & Games – Arts & Crafts
Toys & Games – Bikes, Skates & Ride-Ons
Toys & Games – Construction, Blocks & Models
Toys & Games – Dolls
Toys & Games – Electronics for Kids
Toys & Games – Games
Toys & Games – Hobbies
Toys & Games – Kids’ Furniture & Room Décor
Toys & Games – Learning & Education
Toys & Games – Music
Toys & Games – Party Supplies
Toys & Games – Play Vehicles
Toys & Games – Preschool
Toys & Games – Pretend Play & Dress-up
Toys & Games – Puzzles
Toys & Games – Sports & Outdoor Play
Toys & Games – Stuffed Animals & Plush
Toys & Games – Toy Figures & Playsets

Unbox Video Downloads – International
Unbox Video Downloads – Movies
Unbox Video Downloads – Nonfiction
Unbox Video Downloads – TV

DVD – Action & Adventure
DVD – African American Cinema
DVD – Animation
DVD – Anime & Manga
DVD – Art House & International
DVD – Classics
DVD – Comedy
DVD – Cult Movies
DVD – Documentary
DVD – Drama
DVD – Educational
DVD – Fitness & Yoga
DVD – Gay & Lesbian
DVD – Horror
DVD – Kids & Family
DVD – Military & War
DVD – Music Video & Concerts
DVD – Musicals & Performing Arts
DVD – Mystery & Suspense
DVD – Science Fiction & Fantasy
DVD – Special Interests
DVD – Sports
DVD – Television
DVD – Westerns

"Computer & Video Games – ":http://astore.amazon.com/vgamesbuy-20

VHS – Action & Adventure
VHS – African American Cinema
VHS – Animation
VHS – Anime & Manga
VHS – Art House & International
VHS – Boxed Sets
VHS – Classics
VHS – Comedy
VHS – Cult Movies
VHS – Documentary
VHS – Drama
VHS – Educational
VHS – Fitness
VHS – Gay & Lesbian
VHS – Horror
VHS – Kids & Family
VHS – Military & War
VHS – Music Video & Concerts
VHS – Musicals & Performing Arts
VHS – Mystery & Suspense
VHS – Science Fiction & Fantasy
VHS – Spanish Language
VHS – Special Interests
VHS – Sports
VHS – Television
VHS – Westerns
VHS – Widescreen

Watches – Accessories
Watches – Casual Watches
Watches – Collectible Watches
Watches – Dress Watches
Watches – Fashion Watches
Watches – Pocket Watches
Watches – Sport Watches