开发者

Automatically print out orders

开发者 https://www.devze.com 2022-12-22 08:15 出处:网络
I am wanting to create a VB.Net app that checks a database and then prints out the latest orders, the database is mysql and i need it to periodatically c开发者_StackOverflow中文版heck and only print n

I am wanting to create a VB.Net app that checks a database and then prints out the latest orders, the database is mysql and i need it to periodatically c开发者_StackOverflow中文版heck and only print new orders i.e. not print ones it has already printed out.

Any advice would be greatly appriciated.

Kyle


My suggestion is to add a printed flag to your database, i.e. add a printed field in the database which stores 0 by default denoting the entry has not been printed and a 1 that denotes the entry has been printed.

I would then create an application which checks the database table for all entries where flag = 0.

These entries are the ones that need printed.

Print each entry an set its flag to 1 in the database. Setting the flag to 1 ensures that the next time you poll the database the entries will be ignored.


I'd recommend breaking the problem down into pieces:

  1. "checks a database" - you'll need to create a connection to a relational database. You'll have to set up either an ADO.NET or ODBC connection to MySQL.
  2. You don't say if the database is running on the same machine as the app. If it's not, you'll have to be able to connect to it on the network.
  3. Make sure that you GRANT the appropriate permissions in MySQL. Don't just use the admin credentials to log in. Set up a separate ID for your app.
  4. "then prints out" - your app will have to find a way to acquire information about a printer. You don't say if it's connected directly to the server on which the job will run or if it's a networked printer. Be sure your app can see the networked printer if it's the latter.
  5. "the latest orders, the database is mysql" - try writing a separate query to test getting only the latest orders.
  6. Does your schema include a way to mark which orders have been printed and when? Your app should INSERT a record noting the timestamp when each order is printed. You can JOIN on this table to figure out what the latest, unprinted orders are.
  7. "and i need it to periodically" - your app needs to be a cron job that's run on a schedule that you specify. Every weekday, hourly? Once a night? You decide when you set up the cron job.


You could try using LINQ and dbLINQ for connecting with MySQL. If you are using .NET Framework 3.5 you may as well take advantage of something like LINQ to speed up development time.

If using WPF for the client application you could use a FlowDocument to layout the order details and then handle printing of the orders. Once they are printed you can update the database or store details locally to mark that order as printed. It depends on your database schema.

0

精彩评论

暂无评论...
验证码 换一张
取 消