Thursday, 1 August 2013

Clarion IP Driver and MS SQL Server



.
Clarion IP Driver and MS SQL Server


Normally when you create a Clarion programme that accesses  an SQL Server you would define the details of the connection string in the owner field of the dictionary properties for the table.  This can be hard coded or a variable.

One of the issues that’s been a problem with the Clarion IP Driver/ Server has been the inability to change the sql connection string at runtime.

By exhaustively checking various options I have found a solution that appears to work and allows the programmer to change the SQL Connection string at runtime.

Tip - Don’t define the variable as part of the dictionary’s global variables.
In my example I’m using a variable called servervariable (this is defined in the data dll global as a string)

IP Driver Variables
To change variables on the Clarion IP Server you will need to define the variables (global) in your IP Data DLL. In addition you will need to allow them to be accessed/changed by the IP Client Application (to do this you will need to use the extended features of the IP Driver)

You will need five variables in all (of course you can use names that are meaningful to you)

ServerVariable String - use this as the owner attribute for the sql table/s
DBServer - String/Cstring - the details/name of the SQL Server
DBDataBase - String/Cstring - the name of the SQL Database
DBUsername - String/Cstring - the user name to be used to connect - in my case I created a separate user clarionipserver in the SQL Server for the Clarion IP Server to use for connection
DBPassword - String/Cstring - the password used to access the SQL Server
* Optional - you’ll need a variable for the DBport if you’re not using the default SQL TCP/IP port of 1433

IP Data DLL
In the IP Data DLL after creating the variables, using the IPDRV Extended options make the variables available for the IP Client Application

IP Data DLL - Embed Point for concatenating the variables and assigning to the ServerVariable
Global Embeds > Program Setup > after Extended Options Init
Pass the values to the ServerVariable here.


That’s all that’s required for the Data DLL, next the IP client will need some settings defined.

IP Client Application
In the IP client application you’ll need to check that the IP Data DLL variables are available. This is available as a global extension - IP Client - IPDRV Extended  


Assigning the variables
There are many ways you can store and retrieve the data to assign to the variables;
INI File, Local Data File, TPS File on the IP Server and many other options.

In my testing I decided to use an IP Driver enabled TPS file to store the details for the SQL Server. TIP - makes sure you open and retrieve the data from this file and set the variables on the IP Server prior to opening the SQL Table

Setting the Variables on the IP Server from the Client
To set the variables you can choose to use the IP template extension “set remote” Clarion IP Driver and MS SQL Server

In the example I call the Data settings table to retrieve the variable data after the open files embed in the Main procedure. (I’m not opening the SQL Table until I select a browse containing the data).


Things to know
Trying to set the ServerVariable on the IP Client doesn’t work. The IP Server appears to treat the comma separated values of an SQL connection string as different parameters and only takes the first value (the SQL Server Name)

Make sure that the SQL Server security settings allow the SQL user you’ve defined for the IP Server are valid and have the correct access attributes

Changing SQL Servers and  SQL Databases has been tested and works.

Why Use SQL and IP Driver?
There have been a number of discussions around this. We have a number of IP Driver apps that sit well in the small business/commercial space. In this instance a client needed to have client details imported in real time from their MS SQL based CRM.


Friday, 26 July 2013

Winning combination

Winning combination


Brother MFC-J6910DW and HL-2250DN
I recently purchased a Brother MFC-J6910. An excellent multi function centre that allows for scanning of up to A3 size paper. You are able to set up a number of scan locations if you're scanning to PDF (or images) or you can use it as a pseudo-photocopier (I'd argue more useful in most small office situations). The ADF (sheet feeder) will accommodate up to 35 sheets of paper.

The J6910 has two trays so you are able to load A3 and A4 paper.


MFC-J6910
  • Brilliant
  • Wired - Network
  • Wireless Network
  • USB
  • Fax
  • A4
  • A3
  • Colour
  • Duplex (double sided printing)
All in all a fantastic, reliable, easy to use (and set up) MFC. If you get stuck - excellent support from Brother's help line.

Brother MFC-J6910DW and HL-2250DN

Bought and installed a Brother HL-2250DN today. Why? Because most of our volume printing is monochrome. Fast (26ppm) and another reliable "little" Brother. 

It's very easy to install. It took me longer to find the scissors to open the carton than it it did to set it up. The printer comes with the usual Brother installer CD - just follow the prompts and away you go.

  • Brilliant
  • Wired - Network
  • USB
  • A4
  • Duplex (double sided printing)
The Combination

I've got the best of both worlds. A4/A3 Colour and higher speed monochrome laser. All for under AUD$600. (Look around plenty of suppliers) and networked.

Wish-list
Next item on my wish-list - The Brother HL-S7000 100 ppm monochrome. Why? I've seen it in action and it's a ball-tearer!

Tips
D = Duplex , W = Wireless , N = Network, PPM = Pages Per Minute
Always use good quality paper for the best results

Using Ubuntu?
The Über Geeks at Brother have done it again. Visit this page for a very quick and simple method for installing your Brother printer in Linux.




Saturday, 18 May 2013

Brother TD-4100N

I've written about the Brother TD-4000 in the past. It's a great printer and it does a sterling job as both a receipt and label printer.

Brother also offer a network version of the same printer, the TD-4100N.

From our beta testing with our etouchOS Retail Point of Sale, we've discovered that both printers just keep on. In a network environment where you want to share printers, I'd strongly recommend spending that bit extra and go with the network printer. In fact, I'd suggest that where possible, always chose the network option over the standard printer irrespective as to whether it's a receipt/label printer or just for printing documents. The same approach applies to Multi-Function Centres as well, make it easy to print from PCs, laptops and phones.

Why? 

Because it's easier when you have different devices with different operating systems wanting to print to the same device. Use a printer designed to be networked.

Just sayin'.

Brother have a comprehensive range of printers from entry level to 100 pages per minute - check them out here :- www.brother.com.au