<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>knowledgescape</title>
	<atom:link href="http://knowledgescape.co.uk/feed/" rel="self" type="application/rss+xml" />
	<link>http://knowledgescape.co.uk</link>
	<description>preserving the knowledge</description>
	<lastBuildDate>Wed, 27 Jul 2011 06:02:08 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	
		<item>
		<title>Predicting change of requirements</title>
		<link>http://knowledgescape.co.uk/2011/01/predicting-change-of-requirements/</link>
		<comments>http://knowledgescape.co.uk/2011/01/predicting-change-of-requirements/#comments</comments>
		<pubDate>Thu, 27 Jan 2011 05:50:48 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Methodologies]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=217</guid>
		<description><![CDATA[Firstly, there are no absolute ways of defending against change; to do so would require a degree of clairvoyance seldom bestowed on the humble software engineer. But by looking at the provenance of your requirements, you can make a good start at predicting the ways in which the software might need to change in the [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>Firstly, there are no absolute ways of defending against change; to do so would require a degree of clairvoyance seldom bestowed on the humble software engineer. But by looking at the provenance of your requirements, you can make a good start at predicting the ways in which the software might need to change in the future.</p>
<p>Really obvious clues might be that a requirement derives from a law or regulation. These change, so any behaviours dictated by this requirement, may require to be controlled by parameters rather than hard-coded. Or that area of the software might be best done in a more generic way, not tied so closely to the current business processes, so that when the processes have to change as a result of a change in the regulations, the risk of costly re-development is minimised.</p>
<p>Note that I say minimised, rather than avoided. Again, you cannot predict the ways in which the regulations might change, just that there is a risk that they might.</p>
<p>These risks need to be quantified in order to decide where to build in this flexibility though. How likely is it that a particular area will change should have a bearing on how you treat that need for future change. </p>
<p>For example, I have worked, as a maintenance developer, on a number of systems whose developer assumed (with a fair amount of justification) that VAT would never change, and had hardcoded the calculations with the fixed amount. So when VAT did change, this necessitated a huge find/replace operation. But what I replaced it with, was a call to find out what the current rate at a particular date was, as I reasoned that now the Government have found a new toy to tinker with, they are likely to tinker with it again, so let&#8217;s deal with that now. </p>
<p>But this is the kind of thing that may only become obvious in hindsight. It&#8217;s not an exact science. All you can do is evaluate your requirements and make an assessment of how likely they are to change and use this to focus in on areas that need to be flexible.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2011/01/predicting-change-of-requirements/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The well-trodden path</title>
		<link>http://knowledgescape.co.uk/2010/09/the-well-trodden-path/</link>
		<comments>http://knowledgescape.co.uk/2010/09/the-well-trodden-path/#comments</comments>
		<pubDate>Fri, 24 Sep 2010 10:24:38 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[archaeology]]></category>
		<category><![CDATA[Methodologies]]></category>
		<category><![CDATA[thoughts]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=214</guid>
		<description><![CDATA[As some of you may know, I&#8217;m interested in landscape archaeology &#8211; looking at what&#8217;s around me in the landscape and tracing features and signs of previous land use. As part of my study, I&#8217;m learning to recognise features that might be quite old and to deduce the reasons that they are there. It&#8217;s more [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>As some of you may know, I&#8217;m interested in landscape archaeology &#8211; looking at what&#8217;s around me in the landscape and tracing features and signs of previous land use. As part of my study, I&#8217;m learning to recognise features that might be quite old and to deduce the reasons that they are there. It&#8217;s more interesting than it sounds, honest!</p>
<p>Some people are amazed when I tell them what I do for a day job &#8211; but it&#8217;s so different! Is it? That well-worn lane is where it is because over time, people have found that this is the easiest/best way to get from a to b. Yes, there&#8217;s that other way, but it&#8217;s boggy in Winter, but this path is always passable, and therefore gets used more. People see the path and use it because it *is* a path, and there it still is today.</p>
<p>It&#8217;s the same with business processes. They are a way of getting from a to b, and over the years people have worked out what the best way of achieving that is. On first inspection, you might well ask why they don&#8217;t take that other route, as you can&#8217;t see any good reason not to. But people that have been there a while know the pitfalls and may even have been that route themselves.</p>
<p>Just as you might put up a sign in the landscape to warn of possible dangers, it&#8217;s important to note the other routes that were considered, and why they are not suitable. You stop the potential for endless circular discussion by documenting the warnings, but more importantly, you also allow for the re-evaluation in future, if the pitfalls are made safe. Knowledge is powerful stuff.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2010/09/the-well-trodden-path/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Speaking the same language</title>
		<link>http://knowledgescape.co.uk/2010/09/speaking-the-same-language/</link>
		<comments>http://knowledgescape.co.uk/2010/09/speaking-the-same-language/#comments</comments>
		<pubDate>Wed, 01 Sep 2010 07:59:45 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Methodologies]]></category>
		<category><![CDATA[analysis]]></category>
		<category><![CDATA[collaboration]]></category>
		<category><![CDATA[language]]></category>
		<category><![CDATA[soft skills]]></category>
		<category><![CDATA[software development]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=212</guid>
		<description><![CDATA[One of the first things I do when starting a new project, or meeting a new client, is to compile a glossary of terms. Each industry has its own jargon, and each business probably has its own spin on that, and a set of short-cuts to concepts that may only make sense once you understand [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>One of the first things I do when starting a new project, or meeting a new client, is to compile a glossary of terms.</p>
<p>Each industry has its own jargon, and each business probably has its own spin on that, and a set of short-cuts to concepts that may only make sense once you understand the business thoroughly.</p>
<p>Knowing these verbal shortcuts, and using the right language to use can make all the difference when you are getting to know users and starting the collaboration process. Knowing the right words marks you as part of the tribe, one of the initiated. The user can relax and know that they don&#8217;t have to start from basics, that they can get straight on with the part that interests them.</p>
<p>It&#8217;s important to check your understanding as soon as possible, as a misunderstanding that is left unchecked, can lead to a serious loss of confidence later on. I&#8217;ve seen a project stumble almost fatally because a word was used that was not recognised as being part of the authorised lexicon.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2010/09/speaking-the-same-language/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Times they are a&#8217;changin&#8217; &#8211; let&#8217;s talk</title>
		<link>http://knowledgescape.co.uk/2010/08/times-they-are-achangin-lets-tal/</link>
		<comments>http://knowledgescape.co.uk/2010/08/times-they-are-achangin-lets-tal/#comments</comments>
		<pubDate>Tue, 17 Aug 2010 06:50:57 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Methodologies]]></category>
		<category><![CDATA[thoughts]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=209</guid>
		<description><![CDATA[No system is going to be successful if the end users reject it, that&#8217;s self-evident. But how do you make sure that it&#8217;s as much their baby as yours? Part of my analysis process is to test out the TRUTHs, POLICYs, LAWs and WISHes that I discover, by running them past as many interested parties [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>No system is going to be successful if the end users reject it, that&#8217;s self-evident. But how do you make sure that it&#8217;s as much their baby as yours?</p>
<p>Part of my analysis process is to test out the TRUTHs, POLICYs, LAWs and WISHes that I discover, by running them past as many interested parties as possible. Of course, not everyone gets to make decisions, but input is important. You will discover all sorts of things that maybe no-one had thought to mention and you may be told lots of things that will not longer be a TRUTH in the new system, or POLICYs that will no longer apply. Do not dismiss these. Your users will have been doing this job for a long time and have a great deal of experience that you do not. I add a caveat here &#8211; always always always ask the reason for the answers you receive. You cannot expect to be able to evaluate the input if you cannot see why you have been told something. After all, people often believe things that are not true.</p>
<p>Part of the importance of working with end users on this process is to discover what they hold dear and how you can map that onto the new world with minimum discomfort. Humans are wired to hold onto things they already have or know. This is a survival instinct. The fear of loss is greater than the expectation of gain, and the longer the thing has been owned, the harder it is to conceive of letting go. Once you know this, you can start to work around it.</p>
<p>The fact is, businesses need to change to remain viable. But what you have to do is be subtle about it. Investing the time to involve the end users softens the blow of the loss of the old way, by allowing them to feel ownership of the new way. If you can get them excited about all the shiny new stuff that will be available, and how much better things will be, and importantly &#8211; how you are taking their ideas on board and letting them shape things that will affect them &#8211; the easier the separation from the old system will be.</p>
<p>This has the added benefit that you will have a cohort of evangelists ready to spread the word about the great things that are coming, and to help their team members adjust. Training will also be easier, as your evangelists know the new way almost as well as you do. </p>
<p>Go on, talk to your users, what have you got to lose?</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2010/08/times-they-are-achangin-lets-tal/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The semantics of requirements</title>
		<link>http://knowledgescape.co.uk/2010/07/the-semantics-of-requirements/</link>
		<comments>http://knowledgescape.co.uk/2010/07/the-semantics-of-requirements/#comments</comments>
		<pubDate>Sun, 11 Jul 2010 09:25:29 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Methodologies]]></category>
		<category><![CDATA[software development]]></category>
		<category><![CDATA[strategy]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=203</guid>
		<description><![CDATA[So how do you work out what you really need? There are as many answers to that question as there are practitioners of the subtle art of requirements gathering. I think it&#8217;s important to employ common sense and not adhere to a purely academic approach here. Ultimately you are dealing with software for people, and [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>So how do you work out what you really need?</p>
<p>There are as many answers to that question as there are practitioners of the subtle art of requirements gathering. I think it&#8217;s important to employ common sense and not adhere to a purely academic approach here. Ultimately you are dealing with software for people, and people don&#8217;t always behave rationally. And seldom do they read the books that tell you how requirements elicitation should be performed.</p>
<p>So I take a practical approach. I start by trying to work out where the boundaries of the system will be, and who will be joining in the game. Even if the parties are not interested in participating, I still like to be able to see all the moving parts and work out what I think the potential impact will be on these parts.</p>
<p>I&#8217;m not arrogant enough to believe that you can entirely predict the behaviour of real people when faced with a new set of processes and procedures, so I like to take it right back to basics and take the end users and other stakeholders with me.</p>
<p>I start by writing down everything anyone tells me, and who told me it and when. From this, i assemble a list of assertions about the world, which I call TRUTHS. These are things that must be true of the new system e.g. &#8216;a User must be able to locate an item of inventory on a shelf&#8217;. I&#8217;m not calling them requirements at this stage as this hasn&#8217;t been tested yet. Once I have a set of TRUTHS, these must be tested by the stakeholders to see if they are indeed TRUE. My definition of TRUE encompasses the idea of being always true for the given problem domain. If your business changes and stops keeping inventory, you have changed the problem domain and will have a new set of requirements to satisfy.</p>
<p>TRUTHS do not include such things as &#8216;we must send x letter withing 4 days&#8217; as this is not always going to be true. This is a POLICY. This is a rule devised by the business to control how something is done, not the things that must be done. POLICY-type requirements can and will change. Pressure on staff may mean that 4 days is not possible, and the POLICY changes to 5 days. But you will always need to be able to locate that item of inventory.</p>
<p>Also in the mix are a type of externally-introduced POLICY that I call a LAW. This is where legislation or possibly even laws of physics determine what the system must do. I make the distinction between POLICY and LAW to show which items come within the control of the commissioners and which don&#8217;t. Sometimes the distinction can be hard to make, if your POLICY is as a direct result of compliance with legislation. I use inheritance to express where a POLICY is connected to a LAW (and therefore subject to change if the legal basis for it changes).</p>
<p>Once you&#8217;ve established all the things that must be true of the finished system, everything else is probably a WISH. This is not to say that these are optional, frivolous or should be discarded without consideration. It will be many of the WISHes that make the difference between a perceived failure, and a resounding success.</p>
<p>I think it&#8217;s important to get the stakeholders thinking about the semantics of their requirements, because it&#8217;s important to consider *why* something is a requirement, especially when trying to prioritise. If you don&#8217;t know why a system should do something, how do you know that it should?</p>
<p>A side effect of this process is that people begin to really question what they do and why they do it, which can only be a good thing.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2010/07/the-semantics-of-requirements/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>When is a requirement not a requirement?</title>
		<link>http://knowledgescape.co.uk/2010/05/when-is-a-requirement-not-a-requirement/</link>
		<comments>http://knowledgescape.co.uk/2010/05/when-is-a-requirement-not-a-requirement/#comments</comments>
		<pubDate>Mon, 17 May 2010 14:51:10 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Methodologies]]></category>
		<category><![CDATA[software development]]></category>
		<category><![CDATA[strategy]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=197</guid>
		<description><![CDATA[Commissioning software is *hard*. Lots of people have lots of potentially conflicting ideas and opinions; you might have a legacy system that does almost what your users want, but not quite; you might want to make use of a new technology, or introduce more automation into the process to drive greater efficiency. How do you [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>Commissioning software is *hard*. Lots of people have lots of potentially conflicting ideas and opinions; you might have a legacy system that does almost what your users want, but not quite; you might want to make use of a new technology, or introduce more automation into the process to drive greater efficiency. How do you take all of these inputs and turn them into a watertight expression of your needs that someone might fulfil them for you? And how can you be sure that requirements expressed at the beginning of a lengthy project will still define the ultimate solution that your business will need?</p>
<p>The short answer is, you can&#8217;t hope to.</p>
<p>There are many reasons why this can&#8217;t happen, but the most striking one for me is that of elapsing time. If you express your needs perfectly on day one, by day two a new requirement may have occurred to you. By day three your competitor has made a move that you need to counter, by day four there is a new piece of legislation that you need to comply with etc etc. I exaggerate, of course, but not by much. This is why, with the best will in the world, and the most intelligent people determining the requirements, the requirements for the software at the point of delivery may no longer resemble the requirements at the start of the project. Importantly, this is no-one&#8217;s fault. But it does leave you with software that is not fit for your new purpose, and that is everyone&#8217;s problem.</p>
<p>To me, requirements need to be living things. They need to have a birth, they must have parents (originators), they must be examined at regular intervals to make sure they are still healthy, and sometimes they must die and be replaced by new requirements. A requirement that does not meet these rules, is not a true requirement, as it cannot be justified. So if your requirements are just sentences adrift in time and space, can you be sure they are truly requirements?</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2010/05/when-is-a-requirement-not-a-requirement/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Simple Content Management</title>
		<link>http://knowledgescape.co.uk/2009/05/simple-content-management/</link>
		<comments>http://knowledgescape.co.uk/2009/05/simple-content-management/#comments</comments>
		<pubDate>Sat, 23 May 2009 08:07:03 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Web Development]]></category>
		<category><![CDATA[CMS]]></category>
		<category><![CDATA[Simplicity]]></category>
		<category><![CDATA[WebDevelopment]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=182</guid>
		<description><![CDATA[Sometimes you just want a simple way to let your users edit the pages on their site without having to yell for a developer all the time. There are many many CMS offerings out there, with varying degrees of complexity. Most of them require quite a bit of wrangling. Wouldn&#8217;t it be lovely if you [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>Sometimes you just want a simple way to let your users edit the pages on their site without having to yell for a developer all the time. There are many many CMS offerings out there, with varying degrees of complexity. Most of them require quite a bit of wrangling. Wouldn&#8217;t it be lovely if you didn&#8217;t have to sacrifice a chicken in order to get your new CMS working?<br />
<a title="Perch - a simple but powerful CMS" href="http://grabaperch.com" target="_blank">Perch</a> is there for when you *don&#8217;t* need a moon on a stick. For when you just want to edit some pages without any mystic voodoo. Perch will be ready for release at the end of May, but pop over to <a title="Perch - a powerful CMS for small sites" href="http://www.rachelandrew.co.uk/archives/2009/05/22/perch-a-lightweight-but-powerful-cms-for-small-sites/trackback/" target="_self">edgeofmyseat.com</a> for more information</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2009/05/simple-content-management/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Why a spreadsheet isn&#8217;t a database</title>
		<link>http://knowledgescape.co.uk/2009/05/why-a-spreadsheet-isnt-a-database/</link>
		<comments>http://knowledgescape.co.uk/2009/05/why-a-spreadsheet-isnt-a-database/#comments</comments>
		<pubDate>Wed, 13 May 2009 14:52:07 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[appropriate use of technology]]></category>
		<category><![CDATA[Database]]></category>
		<category><![CDATA[spreadsheet]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=122</guid>
		<description><![CDATA[When I discuss workflow and get told &#8216;and then we type it into this spreadsheet&#8217;, I worry. Spreadsheets do have their uses, and when used appropriately are a fantastic way to display or manipulate data. What they are not, is a database. Unfortunately, a spreadsheet is a quick and dirty way of routing round system [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>When I discuss workflow and get told &#8216;and then we type it into this spreadsheet&#8217;, I worry. Spreadsheets do have their uses, and when used appropriately are a fantastic way to display or manipulate data. What they are <em>not</em>, is a database.</p>
<p>Unfortunately, a spreadsheet is a quick and dirty way of routing round system limitations, in the same way that storing all your data in a Notes field is. Don&#8217;t have a field to store &#8216;SnowmanType&#8217; in? No problem, we can keep track of that in a spreadsheet!</p>
<p>I confess to having a personal horror of the spreadsheet database simply because, as a relational database person, they are just so.. so <em>woolly</em>. You can put anything <em>anywhere</em>. Ugh. For example, I work with a third-party supplier who sends me spreadsheets of (manually-maintained) data. One week, I wondered why my automatic import wasn&#8217;t working. It turned out to be because halfway down a column of data, she had suddenly transposed two columns, and what used to be Postcode was now SupplierName. That&#8217;s just wrong, and quite possibly immoral.</p>
<p>This horror of spreadsheets tends to make me quite a rapid developer, because I know that as soon as a problem has been identified, if I don&#8217;t come up with something sharpish, I&#8217;ll have a spreadsheet to defuse. The incentive of avoiding cleaning up an &#8216;Excel Database&#8217; before I can import it into something more sensible, is quite a powerful one.</p>
<p>Don&#8217;t get me wrong, I <em>use</em> spreadsheets. I spit out data into them and format it into something pretty that you can then play with. But they are an output, not the whole solution. If I can&#8217;t delete all the data from your spreadsheet, and recreate it with minimal fuss, then you are storing your data in the wrong place and I need to help you with that.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2009/05/why-a-spreadsheet-isnt-a-database/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Don&#8217;t fear the U-turn</title>
		<link>http://knowledgescape.co.uk/2009/04/dont-fear-the-u-turn/</link>
		<comments>http://knowledgescape.co.uk/2009/04/dont-fear-the-u-turn/#comments</comments>
		<pubDate>Tue, 28 Apr 2009 06:07:08 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[thoughts]]></category>
		<category><![CDATA[planning]]></category>
		<category><![CDATA[strategy]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/?p=176</guid>
		<description><![CDATA[Listening to Radio 4 this morning (I love Farming Today!), I was listening to the news reporting that Jack Straw has executed a u-turn on the plan to build large prisons. To my amazement, people were mocking him for having changed his mind. Much as I generally dislike Jack Straw, my opinion of him improved [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>Listening to Radio 4 this morning (I love Farming Today!), I was listening to the news reporting that Jack Straw has executed a u-turn on the plan to build large prisons. To my amazement, people were mocking him for having changed his mind.</p>
<p>Much as I generally dislike Jack Straw, my opinion of him improved somewhat as a result of his ability to change his mind. As far as I understand the 30-second news story, he did the right thing. He had an idea, it looked to him like a good idea, he asked a few people what they thought, they didn&#8217;t like it and said it was a bad idea, he wasn&#8217;t sure, so he decided not to go ahead with what he now wasn&#8217;t sure was a good idea. If only more people felt able to do that.</p>
<p>From my perspective, he got two things right: he canvassed opinion, and he then used that to revise his decision. It is not a sign of weakness to ask other people to think about your problem with you. It is not a sign of weakness to then use their advice. It is not a sign of weakness to change your mind. It is a sign of weakness to blindly go ahead with what you now see is a bad idea just because you are not brave enough to hold up your hand and say you&#8217;ve made a mistake.</p>
<p>The same applies to development projects: if you see you&#8217;ve made a design mistake, you can always paper over it and leave it as a hidden treasure for the maintenance programmer who inherits the system. Or, you can bite the bullet, admit you&#8217;ve got it wrong, and then re-do the work until it is right. Unfortunately, it is hard to communicate to non-techs exactly why you need to re-do the work and why you are adding extra time to the project. It&#8217;s easier to pretend you haven&#8217;t noticed the problem and just steam ahead and meet deadlines.</p>
<p>The trouble is, when you get it wrong, users suffer. Good software is invisible to the user &#8211; they stop noticing what they are using to do their job, and just do their job. Bad software makes every task seem difficult and awkward. So I would argue (and have done) that it is better to nip the problems in the bud in the development stage, rather than leave it for someone to apply sticking plasters later on.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2009/04/dont-fear-the-u-turn/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Downturn thinking</title>
		<link>http://knowledgescape.co.uk/2009/04/downturn-thinking/</link>
		<comments>http://knowledgescape.co.uk/2009/04/downturn-thinking/#comments</comments>
		<pubDate>Sat, 25 Apr 2009 12:07:15 +0000</pubDate>
		<dc:creator>Kathy Bragg</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[thoughts]]></category>
		<category><![CDATA[opportunities]]></category>
		<category><![CDATA[planning]]></category>
		<category><![CDATA[strategy]]></category>

		<guid isPermaLink="false">http://knowledgescape.co.uk/2009/04/downturn-thinking/</guid>
		<description><![CDATA[Whilst I don&#8217;t want to appear to dismiss the pain of those who have been unfortunate enough to lose jobs or income as a result of the economic downturn, it appears that it&#8217;s a really exciting time for those of us who enjoy making things better. Most companies have some form of IT infrastructure: you [...]


No related posts.

Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.]]></description>
			<content:encoded><![CDATA[<p>Whilst I don&#8217;t want to appear to dismiss the pain of those who have been unfortunate enough to lose jobs or income as a result of the economic downturn, it appears that it&#8217;s a really exciting time for those of us who enjoy making things better.</p>
<p>Most companies have some form of IT infrastructure: you almost have to. Most of the companies that have this IT infrastructure, do not appreciate what it can, and does, enable them to do. Which is excellent, because good IT should be unobtrusive; it should be a natural part of your everyday life and enable you to do your job more effectively.</p>
<p>Time progresses and technologies improve, but has your business reevaluated its IT strategy lately? What is there available now that could help you survive this downturn? Is there any way you could invest some money now and enable your operation to become leaner, smarter, faster. Evolution doesn&#8217;t just apply to nature, you know.</p>
<p>Almost every day, I come across an instance of a user-grown &#8216;system&#8217; that has evolved to try and cope with a demand. It&#8217;s not the best solution, but it does the job. Once I&#8217;ve worked out <em>what</em> that job is, I can then rationalise the process and smooth off those rough corners that have been a niggle for the users. I am always amazed with the ingenuity of people when faced with a problem. Sometimes the solutions they come up with just need a little automation to make them more efficient.</p>
<p>The other day, I met with a group of users who have a particularly cumbersome application designed for them. The original user of the system signed off the development work solely on the basis that it was &#8216;better than what we had before&#8217;. So, over the years, as needs have changed, it has become harder and harder to use this application, as it didn&#8217;t really do what was required in the first place.</p>
<p>Before the meeting, I sat and thought about the process that the application is designed to assist with. I put myself into the position of a user of the system, and all the things I would want and need to be able to do. The users did the same and came to me with a mind-map of their process and a wishlist of features. I talked them through my ideas and then asked them what they thought. I had covered most of their wish list, and more. So development work will start on that, and together we will turn a department struggling to cope, into an efficient, stress-free team, who can spend more time on customer service, and less time wondering which button to press.</p>
<p>These are exciting times indeed.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://knowledgescape.co.uk/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>

<p>No related posts.</p>
<p>Related posts brought to you by <a href='http://mitcho.com/code/yarpp/'>Yet Another Related Posts Plugin</a>.</p>]]></content:encoded>
			<wfw:commentRss>http://knowledgescape.co.uk/2009/04/downturn-thinking/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

