You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

105 lines
4.8 KiB

  1. MySQL database "literature", table "users"
  2. ==========================================
  3. field names
  4. -----------
  5. fields available in table "users" description
  6. --------------------------------- -----------
  7. first_name the users first name (required!) --> needed for building the user's full name
  8. last_name the user's surname (required!) --> needed for building the user's full name
  9. title the user's job title
  10. institution the name of the employing institution
  11. abbrev_institution the abbreviated name of the employing institution (required!) --> needed for building a correct call_number for any record
  12. corporate_institution the name of the corporate institution
  13. address_line_1 any additional address information required for the institution's postal address (such as building, p.o. box, street, etc.)
  14. address_line_2 any additional address information required for the institution's postal address (such as building, p.o. box, street, etc.)
  15. address_line_3 any additional address information required for the institution's postal address (such as building, p.o. box, street, etc.)
  16. zip_code the zip code of the institution's postal address
  17. city the city of the institution
  18. state the state of the institution
  19. country the country of the institution
  20. phone the user's phone number at work
  21. email the user's email address at work (required!) -> needed for logging into the database (must be unique among all users!)
  22. url the user's (professional) web page
  23. keywords any keys for this user
  24. notes any notes for this user
  25. last_login date & time of the user's last successful login to the database -> future versions may use this info to ask the user for a new password
  26. logins total number of successful logins for this user -> future versions may offer simple usage statistics
  27. language the user's preferred language -> future versions might offer language customization
  28. user_id the user's unique ID number (which is simply the unique serial number of this record)
  29. user_groups the user groups to which this user belongs (note that this field contains names of *user* groups, which must not be confused with the user's personal groups that list groups of particular *references*)
  30. marked gives the possibility to set a flag for this record
  31. created_date the creation date of this record
  32. created_time the creation time of this record
  33. created_by who created this record
  34. modified_date the modification date of this record
  35. modified_time the modification time of this record
  36. modified_by who modified this record
  37. column types
  38. ------------
  39. first_name VARCHAR(50)
  40. last_name VARCHAR(50)
  41. title VARCHAR(25)
  42. institution VARCHAR(255)
  43. abbrev_institution VARCHAR(25)
  44. corporate_institution VARCHAR(255)
  45. address_line_1 VARCHAR(50)
  46. address_line_2 VARCHAR(50)
  47. address_line_3 VARCHAR(50)
  48. zip_code VARCHAR(25)
  49. city VARCHAR(40)
  50. state VARCHAR(50)
  51. country VARCHAR(40)
  52. phone VARCHAR(50)
  53. email VARCHAR(50)
  54. url VARCHAR(255)
  55. keywords TEXT
  56. notes TEXT
  57. last_login DATETIME
  58. logins MEDIUMINT UNSIGNED NOT NULL
  59. language VARCHAR(50)
  60. user_id MEDIUMINT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY
  61. user_groups TEXT
  62. marked ENUM('no','yes') NOT NULL
  63. created_date DATE
  64. created_time TIME
  65. created_by VARCHAR(100)
  66. modified_date DATE
  67. modified_time TIME
  68. modified_by VARCHAR(100)
  69. table creation code
  70. -------------------
  71. CREATE TABLE users (first_name VARCHAR(50), last_name VARCHAR(50), title VARCHAR(25), institution VARCHAR(255), abbrev_institution VARCHAR(25), corporate_institution VARCHAR(255), address_line_1 VARCHAR(50), address_line_2 VARCHAR(50), address_line_3 VARCHAR(50), zip_code VARCHAR(25), city VARCHAR(40), state VARCHAR(50), country VARCHAR(40), phone VARCHAR(50), email VARCHAR(50), url VARCHAR(255), keywords TEXT, notes TEXT, last_login DATETIME, logins MEDIUMINT UNSIGNED NOT NULL, language VARCHAR(50), user_id MEDIUMINT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY, user_groups TEXT, marked ENUM('no','yes') NOT NULL, created_date DATE, created_time TIME, created_by VARCHAR(100), modified_date DATE, modified_time TIME, modified_by VARCHAR(100));
  72. rules for data import
  73. ---------------------
  74. - fields are separated by tabs, records are separated by returns (if not specified otherwise within the LOAD DATA statement)
  75. - order of fields must resemble the above field order!
  76. - DATE format must be YYYY-MM-DD
  77. - TIME format must be HH:MM:SS
  78. - carriage returns *within* fields (ASCII character 11) must be replaced with a "UNIX return" (ASCII character 10) -> Search for: (\x0B) Replace with: \\n
  79. - empty fields are indicated by \N -> Search for: (?<=\t|^)(?=\t|$) Replace with: \\N
  80. - character encoding: higher ASCII chars must be encoded as ISO-8859-1
  81. - file encoding must be UNIX
  82. load data code
  83. --------------
  84. LOAD DATA LOCAL INFILE "/PATH/TO/FILE/users.txt" INTO TABLE users;
  85. or, alternatively, use something like the following from your shell:
  86. mysqlimport --local -u root -p YOUR_DB_NAME "/PATH/TO/FILE/users.txt"