Archives

Not Quite 2000 Words

girard
I owe a lot to Mr. Frank Girard. This blog is a product of his work as well as mine. Mr. Girard taught me how to write in high school, but I wasn’t a big fan of his at the time.

I remember getting detention for “cross pollination.” Mr. Girard would regularly split us up into small groups to brainstorm topics on which we would write, and we never seemed to get grouped with our friends. If he caught you talking to someone in another group, he would call that “cross pollination” which was an “abomination of nature” and you’d spend time in detention. He was quite a character and often referred to himself as “God’s older brother.” After having been labeled a “social butterfly” by my 7th grade art teacher, it shouldn’t be any surprise that I would get caught “cross pollinating” on a regular basis. However, this was not why I didn’t like Mr. Girard.

I didn’t like him because he was ridiculously hard to please. I’ll never forget the first paper I turned in because he forced me to re-write it. Remember kids, this was back in the day when we our homework was hand written by candle light. Alright, well I made up the candlelight part. Very few of us had computers at home, and those that did often had no way to print their work. Spell check? Are you serious? Back in the day you actually had to know how to spell. There were no punctuation suggestions. Re-writes really were re-writes, not just edits. This…. was writing.

He would assign 2000 word essays, oh my god 2000 words (which is nothing for me now). I remember counting words to make sure I hit the minimum, and writing them in such a way as to take up more pages than necessary. Afterward, being forced to re-write a 2000 word paper was a demoralizing experience.

So, I re-wrote it with the corrections he suggested. I turned it in and received it back with a C. Even the second draft was covered with so much red ink that I thought he had opened a vein and hemorrhaged all over it.

This was shocking because I had sailed through every previous writing class. At first I thought this taskmaster simply had it in for me, until I looked at other’s papers. It was obvious that a significant portion of the school’s budget must’ve gone into red pens for Mr. Girard. So, I buckled down because I had to complete this class for graduation and eventually my writing improved. He was so strict in his grading and missed nothing. When I learned to avoid most of my mistakes, he found more advanced problems to correct. Eventually, my writing improved and so did my grades, but I wasn’t very appreciative until much later in life.

When I went to college I aced my English classes, because of Mr. Girard. I wrote much better than most of my peers. In fact, it became obvious to me that the professor who taught Bio Ethics (primarily a writing class) stopped correcting my papers after the first one and simply scrawled a grade on them seemingly at random. There were some comments in the margins of the first and last pages, but nothing else. This was offensive to me because I spent hours writing them to Girard’s standards. However, when the prof gave me a B on one of them, without so much as reading it, I took action. I turned in a few papers in a row with real content on the front and final pages and then copied and pasted (we had computers by this time) several pages worth of text from the Bible for the middle portion of my essays. He never noticed. When I brought this to the attention to the Dean, my grades miraculously improved.

When I became a Science Teacher, a job I still miss some twelve years later, my appreciation for Mr. Girard grew. I took up the torch to promote good writing, something my district was pushing, and gave my students meaningful writing assignments in my Biology classes. I didn’t realize the hell I had unleashed on myself. The kids couldn’t write properly, even in the age of computers. They had no sense of sentence structure, proper punctuation, etc. Imagine my shock when I got 150+ assignments every two weeks or so from my students, and I could barely read them. This is no exaggeration. I literally spent my weekends with… you guessed it… red pens. The time required to read all of these papers was ridiculous, and I still can’t imagine how Mr. Girard managed to do it; especially since most of the papers he read were hand written as opposed to typed. It’s no wonder the man wore thick glasses. Eventually, I was asked by the administration to stop the writing assignments because the kids complained to the English department, and parents were complaining that their kids were being taught English in Biology class. It was obvious to me that they needed to be taught to write somewhere, since most of these kids were acing English with such poor writing skills, but I digress.

I respect Mr. Girard for his dedication to his craft, his unfailing demand for perfection from his students, and his unparalleled work ethic. Sadly, he died several years ago so he’ll never get a chance to read this.

I suppose that’s a blessing in a way because if he were still alive, I’m sure he’d print out this page, correct it, and send a copy back to me covered in red ink.

Oh I never did stop “cross pollinating” either.

Profuse Perpetual Pointless Pernicious Permission Problems

I’ve been working with M2M for nearly 12 years, and they’ve made very little progress with permissions. I’ve placed several change requests regarding permissions, which have gone unheeded. Smaller companies with only a few M2M users will probably not relate to some of these issues, but they become major problems when you administer 40+ users and multiple companies, like I do.

What are the Problems?

  1. M2M does not provide a way to tie your Active Directory structure to your M2M account. Yes, if you use the same usernames in M2M as AD (assuming none of your AD names exceed 10 characters), you can automatically log in. However, the admin must manually set permissions for each person. There are no groups in M2M with regards to rights, so you have to assign each person individually. M2M suggests that you create a sample user for every job in your facility and copy permissions from those accounts. For example, you might have user accounts such as “SalesAdmin”, “SalesMngr”, etc. Those accounts would act as your base permissions account for those job positions. However, when the Sales Administrators’ permission requirements change, this process is even more tedious. You must add the permission to the base account “SaleAdmin” and then manually copy the rights to each Sales Administrator afterward. Exactly how does this accomplish anything?
  2. Each new report must be assigned manually per employee as well. Every time you create a Sales report for your Sales Administrators, you must add that permission to each one.
  3. Setting up a practice company is tedious because rights have to be given manually per person. Why isn’t that an option when creating a new company? More on this later as I think a friend of mine has created an application to accomplish that very task, and I’ll share it with my readers in a future post.
  4. The permissions tables are encrypted (username) so you can’t write custom reports nor create a program to automatically manage permissions.
  5. New users have root control of M2M by default and this is a terrible security policy. I can’t tell you how many times I’ve run the Permission Report and seen that the new guy could ruin us because another admin (I would never make such a mistake right?) forgot to limit his rights.
  6. Speaking of the Permission Report, it is awful as well. It takes forever to run, and it’s very inflexible. For example, I want to be able to run the permissions report per screen only for those people who have deletion rights. The standard report doesn’t allow this. Therefore, I export them and import them into an access database and use a Crystal Report to summarize them per screen.
  7. ”Hidden” screens can be a problem as well. For example, let’s assume your Sales Administrator role is to add new sales orders to the system. So, you give them Add and Edit permissions to the Sales Order (SO) screen. The user re-starts M2M for the permissions to take effect and then come to you with the following error:
    SO Add
    Not only do you have to provide permissions to the SO screen, but you have to provide permissions to screens such as SOADD and SOCHNG as well.
  8. Speaking of Sales Orders, they are like many other documents in that you cannot give users permission to delete line items, but not entire master document. This is a hassle because I’d rather inconvenience the user as little as possible. A disgruntled employee can really hurt you with deletion permissions.
  9. Why can’t users change their own password? This is a huge security problem that all passwords are assigned by the M2M Administrator. This problem has actually been addressed in Version 6.0.
  10. Finally, and this is a small issue, but if you try to remove rights to a certain screen and you start with View, you will receive the following:
    permission_error
    This goes back to blog post about M2M Errors. If M2M knows what I need to do, why doesn’t it simply do it?

What do you folks think? Have I been too harsh? What problems do you have with the current permission structure?

Interesting VFP Date Issue

I performed a test migration to M2M Version 6.0 the other day on a test server. After your test server is set up, one of the first steps is to run DBSCAN on your Util database. My scan found a few records with data corruption. One sample record is below:

11/21/09 03:17:39 PM:dbScan: Data Corruption Detected!
11/21/09 03:17:39 PM:>>Table…..: L:\M2MDATA\\UTIL\utrpsess.dbf
11/21/09 03:17:39 PM:>>Record Number…….: 3995
11/21/09 03:17:39 PM:>>Field Name……: DATE_FROM
11/21/09 03:17:39 PM:>>Error……: Date fields must have values > 01/01/1900
11/21/09 03:17:39 PM:>>——————————————————————————–

To clean this up, I opened VFP and entered the following commands:

set exclusive on
open data M:\m2mdata\util\util.dbc
use utrpsess
goto 3995
brow

When I hit browse, I didn’t understand the problem. Look for yourself:

Looks like a good date to me.

Looks like a good date to me.

However, a Consona Support Tech suggested I click inside that field and when I did, I saw the following:

See it?

See it?

Score one for support.

Happy Thanksgiving

Last year about this time I referenced the famous WKRP Thanksgiving Day Episode and listed those things for which I am thankful. Well, I’ve decided to update my list for this year as a lot has changed since then.

  • I’m thankful to have a secure position in this awful economy and that my career is moving in a positive direction.
  • I’m incredibly thankful to the SQL community and their willingness to freely share their knowledge. The following offer excellent blogs and/or recorded videos with amazing free content. In particular I’d like to thank Brent Ozar, Grant Fritchey, Andy Warren, Steve Jones, Tim Mitchel, Brian Knight.
  • I’m thankful to live near two great SQL Server User Groups, especially for the excellent classes given by Mike Hotek (which he does free) at the Fort Worth User Group.
  • Once again I’m thankful that Made2Manage has not outsourced their support, and I hope they never do.

What are you thankful for?

M2M Tech Support Gaffes

As a follow up to my last post in which I said that you need to be careful following the free advice given by another customer; you should also be wary of what M2M Tech Support tells you. They can and do make mistakes. I can’t tell you how many times they’ve given me directions which were for the wrong version of M2M as well as a SQL script which was incorrect and would have caused huge problems with my database.

For example, when I first started working with a Visual FoxPro version of M2M (3.1 I believe), I had problems with one of my invoicing tables. There are as many as 3 files with each VFP table. The first file contains the data, the second contains any indexes, and the third contains memo fields. The Tech told me to delete the file which contains the index structure so that it could be rebuilt, but gave me the extension of the data file. I asked her to verify the file and extension she wanted me to delete and then did so. Of course, this was a mistake. Shortly thereafter I found out that the company we paid to do network maintenance and check our back ups was not doing so, and I had to restore an invoicing table from two weeks back. I then hired a VFP programmer to update the table using information from related tables. This was stupid on my part, but as I said I was a complete beginner and had no idea.

Later, when I first started with Crystal, I was instructed to use the SA account, the same account most M2M installations are configured to use. This is a bad idea for several reasons, but as I said, I was a beginner at the time. However, I did not know the SA password, so Tech Support showed me how to change it…. during the work day… with everyone in M2M. I specifically asked, “Will this cause problems for my users in M2M?” The tech assured me that no, it wouldn’t. Well, the results were predictable, exactly 1 minute after doing it, I had 3 calls in rapid succession from users getting all sorts of SQL Connection Errors. Nice.

Recently, I received a script I was told to run by a Senior Tech Support Rep and it began with:

--Change the database name before executing this query
use mercury
 
--FIRST DO THE INONHD TO INMAST COMPARISONS
--Find inonhd records without matching inmast records

Obviously I am not going to change the name of our production database with users in the system, nor does it make any sense to change the name at all. Most of their scripts will tell you to “use DataXX” and this is more clear.

After I questioned the support tech about that, she verified that I should just run the scripts against M2MData01. I didn’t understand the reason for one of the update statements, so I checked it out as a select statement first and it returned almost 3000 records. If correct, this would indicate a serious problem in my database. I immediately stopped and called the Support Tech and she apologized that the script was in error and should not be run against my database. If I had run the update script, it would not have been an easy fix.

As a general rule, make a copy of your M2MData folders before changing anything. Do not assume your backup will suffice. It’s much faster to “restore” from a duplicate copy right on the drive than messing around with tapes. If I had simply done this I would not have found myself in a terrible spot with my first example.

This post isn’t meant to jab at M2M. These problems are not always their fault. Unless they are looking at your screen they are relying on you for the answers to their questions. Having helped people out this way, I have a new appreciation for just how difficult it is to guide a user through a process that you cannot watch.

Anyway, the point is that M2M does not administer itself, and if you are going to administer it you need to learn it. Don’t blindly follow directions as even the best Support Technicians make mistakes.

Have any of you encountered similar issues?

Want to Drop Support?

Since I began this blog a little over a year ago, I’ve had many people contact me for help and advice. I do my best to help them if I can, but one type of message never ceases to amaze me. It goes something like this:

Sir,

“Can you please help me? I am on M2M Version x.x and had a hard drive/server crash. After attempting to re-build the system I get the following error: (Completely unhelpful obscure error message and code removed)

We have been down since last Friday and have not been on M2M support for several years. Can you help me get my system back up?

Sincerely,

Milton

P.S. If you don’t help me, I’ll set your blog on fire.

The advice I’m about to give may sound a lot like my post on M2M Migration. If you don’t have a Visual FoxPro and SQL Server expert on site, and your company’s productivity means anything to you, then you need to be on support.

People who read this blog know that I am not employed nor sponsored by M2M. I am not a Made2Manage (Consona) apologist and I criticize them when appropriate. While I realize that M2M Support is expensive and times are tough, it costs money to do business. That’s just the way it is.

If you drop support, you ARE support. It’s an awful position to be in when your ERP system is down, you have no idea how to fix it, and you aren’t on support. I was in that situation years ago when I first started M2M. You can’t access their bulletin boards, and the only other one I know of is a Google group for the Los Angeles User Group. They have some good people there, but they have their own jobs to attend to. Your emergency is not their emergency, and you won’t get an instant response. Also, take any advice you get from someone other than M2M Support with suspicion as well. Free advice is often worth just what you paid for it.

Are you ready for the responsibility of being your own tech support? Even if you are able to get help with your system from another customer, was it worth all of the down time?

Even if you have a SQL and VFP expert on site, you still need to be able to upgrade your systems. Software is a never-ending treadmill and even if you are satisfied with your current version of M2M, it will not necessarily work with new versions of SQL Server or Windows Operating Systems and eventually you will be forced to upgrade.

The customers who contact me in this situation have indicated that Consona’s terms are draconian (their words, not mine), and I’m sure that is what drives a customer to spend days or weeks looking for a solution. Perhaps someone from M2M would like to clarify their policy in the comments.

Amazed by the Wrong Things

Ms Pacman

I love this chart, which I borrowed (stole) from Coding Horror. A major project that I completed recently reminded me of it. I created a sales order auditing system that included scheduled SQL jobs, multiple triggers, VBA for M2M, and Crystal Reports. The project took me a long time to complete and was highly rewarding.

However, when I delivered the report to the user, he was less impressed than I expected from such a large project that was very challenging. He asked for a pie chart at the top of the report.

Five minutes later, I returned with a full color, 3-d pie chart that is very easy to create in Crystal Reports. The guy was thrilled and has since sung my praises.

This is all well and good, but it just serves to remind me that most people have very little idea of what we do or how we do it. The project was a success due to thorough planning and development, which insured data accuracy and efficient code. All the user can see is the pretty pie chart.

Do you ever feel this way?

Oh well, at least I like pie.

Would You Use a New Made2Manage Forum?

I started this blog to help people learn more about M2M, SQL, and Crystal Reports. The reason was simple; I had to learn this stuff the hard way, by myself and essentially in a vacuum. I wanted to help anyone who found themselves in the same situation.

Since then, I’ve had a couple of people ask me, “Dave, when are you going to host a forum for M2M users?” Well, I’ve been reluctant to do so for a few reasons.

  1. I don’t intend to do M2M forever and I don’t wish to set myself up to moderate forums regarding it indefinitely.
  2. Regarding moderation, I wouldn’t be able to moderate it during the day.
  3. Bandwidth is not free, but people don’t like to see ads either.
  4. Most importantly, I’m not sure there is enough demand for it.

However, the current options are not very successful either. Let’s examine them a moment:

M2M’s own forum. I look at the Administrator’s board fairly regularly. However, the interface is from the early 90’s with frames and the functionality is counter intuitive as well. Therefore, it is hardly used. I’d estimate that they receive less than one post per day.

In fact, I’d bet money that Consona doesn’t read their own forums either. If you look in the “Company Setup/Maintenance” forum, you’ll see the second recent post at the top entitled “Remove Permissions from ALL of Us…” In that post another forum member suggests that the original poster delete all records from the UTSEC table. UTSEC contains the list of current M2M screens and deleting anything from it would be catastrophic. If someone from M2M was paying attention, they’d remove that statement immediately. Did I mention that the dangerous advice has been there for nearly eight months?

Another disadvantage is you must be on M2M support to use the forum. With the current economic climate, many companies just can’t afford support fees.

I realize that economic times are tough, and that maintaining a decent forum costs money. However, if the M2M forums were free and being used, calls to support would drop dramatically. In the long run, I think it would save money for Consona.

The Los Angeles Area Made2Manage User Group. This is a Google Group for users in the LA Area, and some of them use it since dropping M2M Support. This is a free service and the group members are very helpful, but the group still doesn’t have a lot of traffic anyway. Also, I don’t care for Google Groups (list groups in general) because of the way they process messages. Comments accumulate and get re-sent over and over again. For example, if Milton posts a question about the Purchasing screen the message goes out to the subscribers. If Sally responds, her message includes both hers and Milton’s. After three more people reply to his question, the messages get longer and longer and the signal to noise ratio becomes intolerable. However, I would like to mention again, that the users are good people and I’ve received assistance from several of them.

I’ll end this post with a poll. If someone creates and maintains a modern forum site for M2M and related technologies, how often would you participate?

How often would you participate?

View Results

Loading ... Loading ...

Pop Quiz

Dennis Hopper - Speed

Dennis Hopper - Speed


You get a frantic phone call at 3am on a Sunday. It’s your boss, and there’s been a fire. The server room, and perhaps the whole building, is still smoldering. He asks you the following questions:

  • Is our data safe?
  • Is it off site? Is it secure or on someone’s kitchen table?
  • When was the last time you checked the back up? You are checking them, right?
  • Are you sure you can restore the M2M files? You have been performing test restores, right?

There are many blog articles on the web about the importance of disaster recovery, and you’ve probably read a few of them. I won’t re-hash everything here, but do you have the answers to all of those questions? If not (and you value your job), stop reading this and address them immediately. I’ll wait….

Good! Now that the above are covered lets address some M2M specific issues.

  • Can you build your SQL Server and install everything without help? Servers seem to prefer to die on weekends, and M2M Support is not available late at night or on weekends and holidays.
  • Where is your software? Latest Service Packs? Software keys? At the bare minimum, a M2M server requires Windows Server, Visual FoxPro, SQL, and Made2Manage.
  • Do you have documentation handy with all of your M2M and other settings?
  • Do you have instructions ready to install all of your optional modules? Do you have the latest install files for them? I recommend keeping all of this (including the install files for everything) in electronic format with your back-ups if possible.

I remember watching a movie where special forces soldiers spent hours assembling and disassembling their rifles blindfolded. The point was that they became intimately familiar with their weapon and knew everything about it. Ultimately, this made them more effective soldiers.

Recently I wrote disaster recovery instructions for SQL Server, Made2Manage, and the associated modules for my current employer. One of my fellow employees performed the same process on a Domain Controller and Exchange Server. We then verified them by restoring everything from bare hardware, back-ups, and our instructions in an isolated room without access to the internet. Our manager also put us under stress by telling us our results were going to be public and that we had better not let him down.

Why a closed room and stress? It simulates a disaster. Can you be assured that you will have access to the internet in a disaster? Even if you could, would your boss want to wait while you download service packs? Since we had all of the files and had practiced, we built and tested our servers in less than 4 hours.

What are the benefits of a complete test?

  • To prove we could do it.
  • I learned exactly what makes M2M work.
  • I’m now confident that I can fix anything on that server.

Incidentally, with the exception of our database server, the rest of our servers are replicated in two other sites in the United States. In the near future, our SQL Server will be replicated the same way. So we should never actually be “under the gun” so to speak.

So Hotshot, what do you do?

The Terrorists Win

Professor Chaos - The Ultimate Terrorist

Professor Chaos - The Ultimate Terrorist


Recently the call went out for SQL Bloggers to submit their best work for the PASS Log Reader Awards. A few of the best SQL Bloggers got together and created this contest to inspire and encourage others to create top quality content.

I was encouraged to enter my Encyclopedia Brown Mystery posts I created and I did so. It’s not strictly SQL, so I entered it into the “Unusual Blog Post” category. I’ve always been seen as unusual anyway, so I figured I had a good shot to win.

The entry even got some good buzz around it on Twitter when SQL Chicken BlogTwitter raved about it.

terrorists

So, I waited with baited breath for the results. I worked on an acceptance speech. Well, the winners were announced and ::heavy sigh::

I didn’t win.

When I read the post and didn’t see my name, I started to comment on Brent’s post, “I’m real happy for ya, and I’mma let you finish but the Encyclopedia Brown Post was one of the most unusual of all time!!!”

However, In an effort to be classy and take my defeat well, I refrained from doing that. After brooding about being unappreciated and misunderstood for several days, I started feeling emo, wearing goth clothing, and listening to sad music to make my point to the community that nobody understands me.. However, I realized that wouldn’t get me noticed either as one of the Award Judges already tried that.

After careful consideration, it all comes down to SQL Chicken’s comment: The Terrorists Win. (Scroll Down)

.
.
.
.
.
.
.
.
.
.
.
.

Vote for me next time or the bird gets it!!!

tins_gun

Seriously though, congrats to the winners. 🙂

Page 19 of 33« First...10...1718192021...30...Last »