ACRL News Issue (B) of College & Research Libraries 5 5 8 /C&RL News Database development and working with a programmer By A n n e H ed rich a n d H arlan B rew er Careful p la n n in g p lu s a good program m er equal success Y ou have a great idea for collecting infor­ mation that would help your library. The information w ould need to be organized nipulated, and updated to be the most useful. The obvious thing to do is to create a database to do all of this. You look at the software avail­ able and peek at the instructions for program­ ming. You realize that if you had a year’s leave of absence and could take an appropriate pro­ gramming class, or had a half year’s leave and time to learn the programming from the instruc­ tion manual, you could do the programming yourself. Or, you could hire a programmer. Perhaps you are doing a survey of library needs or use, and need a respondent tracking system, or a database of how people responded to your questions. Maybe you are creating a database of a local resource, or you w ant an inventory management system of some kind. In any of these situations, you may find your­ self in need o f a com puter programmer to cre­ ate a database that meets your needs. Program­ mers know the field, and are familiar with database creation, structure, and uses. They can save you lots of time and headaches. They can also be expensive. Here are some tips for w ork­ ing with a programmer that will help maxi­ mize their benefit to you and minimize the costs. Assessing the needs of your project It is important to determine w hether or not you really need a programmed database for your project. Your needs might be answered by one of the software packages already on the market. For example, spreadsheets work , well for keeping data organized, and they pro­ vide the ability to do calculations and statisti­ cal work with the information you have. If you will want to compare the data in different com­ binations and do other data manipulation, you may need something more. Check to see if a similar project has been done elsewhere. Lit­ mear­ature searches, questions posted on appro­ priate Internet discussion groups, or checking with colleagues may all provide leads to other projects. Occasionally such a project has pro­ duced software that is for sale. Tweaking soft­ ware that pretty much meets your needs takes a lot less work and m oney than starting from scratch. If you have determined that the only way for you to make your unique project work is to create your ow n database, the next step is to set dow n in detail what you w ant to do. Write dow n what information you will put into the database, and w hat you w ant to do with it af­ ter it is in there. Will you be updating data? If so, will you be keeping the original informa­ tion in the database? How do you want to dis­ play an d /o r report data? Will simple data dis­ plays do, or will you want a function that creates printed professional reports? These are all ques­ tions that you will w ant to answer before you start to create your database. Have a sheet of categories of information collected and the spe­ cific ways you will manipulate it (e.g., creating a list from one of the fields in each record). This will help with linking fields and organiz­ ing records in database creation. Perhaps a word about the parts of databases w ould be useful here. The programmer works with software to create a database. This can be software that is available on the market and has a programming language of its own, or it can be creating a database on a com puter that A n n e Hedrich is a reference librarian a t Utah State University, e-mail: annhed@ cc.usu.edu; H arlan Brewer is a Ph.D. student at Utah State University, e-mail: hbrewer@msn.com mailto:annhed@cc.usu.edu mailto:hbrewer@msn.com September 1 9 9 7 / 5 5 9 understands common com puter languages such as Fortran, Basic, or C. Data in databases are organized into fields, w hich are similar to fields o n bibliographic databases used in libraries. Fields are com bined to make a record, again similar to bibliographic databases familiar to librarians. Records may be organized into tables, or they may be the highest level o f organiza­ tion in the database. Putting fields together in different com binations (achieved by linking fields), or pulling out only records with a speci­ fied entry or type of entry in a field, are ways of combining data. Planning the project When planning a project, always have the end in mind. Plan how long the project should take, and set a timeline for the work. Decide what will determine w h en the project is com pleted— w hether it is w hen all of the data are entered, or w hen reports have b een submitted, or, in some cases, w hen a certain time period has passed. Completion of the project should not rely on the am ount of funding. If you deter­ mine that the end of the project will be w hen all of the money for programming or data in­ put has b een spent, you will en d u p with half of a project. Talk to people at institutions w here similar projects have b een done. This will give you a good idea of w hat to expect from the project as a whole, and from the database and the pro­ grammer in particular. Determine the costs of the project. You will need to budget for a programmer for x hours, including time for database creation, database adjustments, determining database integrity, and troubleshooting w hen things d o n ’t w ork as you thought they w ould. Talking to people w ho have done similar projects or asking several local programmers are ways o f getting an esti­ mate of how many hours your particular project will require. Research the standard program­ ming pay rate in your area. Consider your o p ­ tions. Student programmers will be cheaper by the hour, but you may end u p with a product of less quality because you are probably w ork­ ing with som eone with less experience. Addi­ tionally, student programmers might take longer to do the programming work, and en d u p cost­ ing almost as much as an experienced profes­ sional programmer. Volunteers may w ork well, but again, consider the experience o f the p er­ son you select and the ramifications of that level of experience. W homever you hire, make sure that he or she docum ents w hat he or she has done on your project. That way, if you ever need to w ork with som eone else, you will not have to pay that person to sp en d time figuring out w hat the first programmer did. You will also n eed to pay som eone to input data, either in cash, or in your time if you are the one to do the data entry. You may have paper, copying, an d /o r mailing costs (for example, if the data are to come from a survey). If you do not al­ ready own the software you plan on using, you will n eed to purchase it. Picking a programmer There are two primary things to consider w hen choosing a programmer. The first is the quality of work that you expect to receive. The second is w hether or not you can communicate well with your programmer. W hen picking a programmer, look at the experience of the candidates. How long have they b een programming? What educational cre­ dentials do they have: do they have a bachelor’s degree in com puter science, o r are they relying o n the Basic program m ing they did in high school m ath class in th e 1970s? H ave they w orked with the software that you have cho­ sen? Ask them how long they have w orked with the software, not only as a developer but as a user too. From being a user, they have a better sense o f w hat the software can do and can bet­ ter counsel you to develop it efficiently. Do they have recommendations for other software? Get an idea of their experience by asking what other databases they have designed. Ask them if they are familiar with database normalization and w hether they have done this or not. (Nor­ malization means that the data are consistent throughout the organization o f the database. It generally ensures that you have minimal data redundancy, in addition to consistent record updates and consistent record deletions.) Ask for references and check with other clients to see if they w ere satisfied with the program ­ ming work. The other area o f consideration is commu­ nication. Can the programmer explain things to you so that you understand him or her? Do not try to cover up your lack o f understanding o f com puters by n o d d in g a lot an d saying “mm m ” at w hat seem to be appropriate m o­ ments. You are partners in database develop­ ment, and you must understand w hat is going on, at least at a rudimentary level, to make sure that the product m atches your need. Asking for 5 6 0 / C&RL News High Society. Ice Cream Socials. Gang Wars. Fighting Words. Human society has countless manifestations and meanings. We track them, and provide you with thousands of references to enhance your research. Sociological Abstracts (SA), Social Planning/Policy & Development Abstracts (SOPODA) and Linguistics and Language Behavior Abstracts (LLBA) contain a spectrum of information directly related to your areas of interest and expertise. Drawing from more than 2,400 journals published in 35 countries, we present abstracts of articles, books and conference papers. Our bibliographic entries will guide you to relevant dissertations and important book and other media reviews. All are expertly indexed and classified for easy access. SA, SOPODA and LLBA are available in a variety of media: print, online, CD-ROM, and magnetic tape. Let us help you discover the social worlds and patterns of communication by which we live. SAI's Web site, located at www.socabs.org, contains searchable subsets of the SA, SOPODA, and LLBA databases, hot topics, the Note Us newsletter, and links to other relevant sites and resources. For more information on our products and services, visit our Web site, or contact us at: s o c io lo g ic a l a b s tra c ts , in c. P.O. Box 22206, San Diego, CA 92192-0206 619.695.8803 Fax 619.695.0416 Internet: socio@cerfnet.com Web site http://www.socabs.org SAI products are available in print; online from Knight-Ridder, DIMDI, OCLĆ and Ovid; on CD-ROM from SilverPlatter, EBSCO, Ovid and NISC; and on magnetic tape directly from SAI. For document delivery contact SOCIOLOGY* Express at 619.695.8803 or Fax 310.208.2982. clarification also gives you a better chance to assess if you really can or can’t understand what the programmer is talking about. Does the pro­ grammer understand you? Does he or she ask questions to make sure he o r she is clear about w hat you want? And, finally, you might want to consider if you feel that there is something beyond communication there. Would you like to m eet with this person on a weekly or bi­ w eekly basis for a period of time? After all, you may be working with this person for years! W orking with a programmer All aspects o f your working relationship should be detailed before w ork begins. Set a pay rate and schedule. A tentative timeline should be mutually understood, as well as w hat will d e­ termine the en d o f the project. Plan w hen you will meet about the progress of the database development. Plan how you will contact the programmer with questions o r requests ou t­ side of the regular meetings. Many of these ac­ tivities come under the rubric o f general m an­ agement. As with any situation, heeding practical m anagem ent strategies will pay off in less con­ fusion and headaches later. Plan for the following phases in your project: meetings to convey your needs to the program­ mer, database normalization, database devel­ opm ent with feedback, test run, data entry, another test run, final adjustments, and any ongoing adjustments if the project is a continu­ ous one with, say, annual updates. Realize that you may be in one o f the phases of the project longer than you thought you w ould be. You, as project manager, will w ant to check to m ake su re th e inform ation is e n te re d co r­ rectly. D atabase integrity m ust also b e d e ­ term in ed (are the d ata going into all o f the fields you n e e d them to?) The programmer can help you set up and run tests to check the database. Constructing a database is time consuming, but there are times w hen nothing but such a resource will do (compare using an online cata­ log with using a card catalog!). A key to the successful creation of a useful tool is finding a good programmer to work with. And primary to a successful relationship with a programmer is good communication. Careful planning will help ensure the success of your project. Finally, real­ ize that you cannot plan everything, and that the unexpected might com e up. Flexibility is important to k eep a balanced approach and your sanity. Good luck, and have some fun! ■ http://www.socabs.org mailto:socio@cerfnet.com http://www.socabs.org