Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 52571
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 10, 20262026-05-10T16:55:40+00:00 2026-05-10T16:55:40+00:00

I’m writing a server that I expect to be run by many different people,

  • 0

I’m writing a server that I expect to be run by many different people, not all of whom I will have direct contact with. The servers will communicate with each other in a cluster. Part of the server’s functionality involves selecting a small subset of rows from a potentially very large table. The exact choice of what rows are selected will need some tuning, and it’s important that it’s possible for the person running the cluster (eg, myself) to update the selection criteria without getting each and every server administrator to deploy a new version of the server.

Simply writing the function in Python isn’t really an option, since nobody is going to want to install a server that downloads and executes arbitrary Python code at runtime.

What I need are suggestions on the simplest way to implement a Domain Specific Language to achieve this goal. The language needs to be capable of simple expression evaluation, as well as querying table indexes and iterating through the returned rows. Ease of writing and reading the language is secondary to ease of implementing it. I’d also prefer not to have to write an entire query optimiser, so something that explicitly specifies what indexes to query would be ideal.

The interface that this will have to compile against will be similar in capabilities to what the App Engine datastore exports: You can query for sequential ranges on any index on the table (eg, less-than, greater-than, range and equality queries), then filter the returned row by any boolean expression. You can also concatenate multiple independent result sets together.

I realise this question sounds a lot like I’m asking for SQL. However, I don’t want to require that the datastore backing this data be a relational database, and I don’t want the overhead of trying to reimplement SQL myself. I’m also dealing with only a single table with a known schema. Finally, no joins will be required. Something much simpler would be far preferable.

Edit: Expanded description to clear up some misconceptions.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. 2026-05-10T16:55:41+00:00Added an answer on May 10, 2026 at 4:55 pm

    Building a DSL to be interpreted by Python.

    Step 1. Build the run-time classes and objects. These classes will have all the cursor loops and SQL statements and all of that algorithmic processing tucked away in their methods. You’ll make heavy use of the Command and Strategy design patterns to build these classes. Most things are a command, options and choices are plug-in strategies. Look at the design for Apache Ant’s Task API — it’s a good example.

    Step 2. Validate that this system of objects actually works. Be sure that the design is simple and complete. You’re tests will construct the Command and Strategy objects, and then execute the top-level Command object. The Command objects will do the work.

    At this point you’re largely done. Your run-time is just a configuration of objects created from the above domain. [This isn’t as easy as it sounds. It requires some care to define a set of classes that can be instantiated and then ‘talk among themselves’ to do the work of your application.]

    Note that what you’ll have will require nothing more than declarations. What’s wrong with procedural? One you start to write a DSL with procedural elements, you find that you need more and more features until you’ve written Python with different syntax. Not good.

    Further, procedural language interpreters are simply hard to write. State of execution, and scope of references are simply hard to manage.

    You can use native Python — and stop worrying about ‘getting out of the sandbox’. Indeed, that’s how you’ll unit test everything, using a short Python script to create your objects. Python will be the DSL.

    [‘But wait’, you say, ‘If I simply use Python as the DSL people can execute arbitrary things.’ Depends on what’s on the PYTHONPATH, and sys.path. Look at the site module for ways to control what’s available.]

    A declarative DSL is simplest. It’s entirely an exercise in representation. A block of Python that merely sets the values of some variables is nice. That’s what Django uses.

    You can use the ConfigParser as a language for representing your run-time configuration of objects.

    You can use JSON or YAML as a language for representing your run-time configuration of objects. Ready-made parsers are totally available.

    You can use XML, too. It’s harder to design and parse, but it works fine. People love it. That’s how Ant and Maven (and lots of other tools) use declarative syntax to describe procedures. I don’t recommend it, because it’s a wordy pain in the neck. I recommend simply using Python.

    Or, you can go off the deep-end and invent your own syntax and write your own parser.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Ask A Question

Stats

  • Questions 77k
  • Answers 77k
  • Best Answers 0
  • User 1
  • Popular
  • Answers
  • Editorial Team

    How to approach applying for a job at a company ...

    • 7 Answers
  • Editorial Team

    How to handle personal stress caused by utterly incompetent and ...

    • 5 Answers
  • Editorial Team

    What is a programmer’s life like?

    • 5 Answers
  • added an answer Do you have a specific question? You have asked an… May 11, 2026 at 3:16 pm
  • added an answer The answers to this question show possible ways to approach… May 11, 2026 at 3:16 pm
  • added an answer For the time being you cannot render RadEditor without having… May 11, 2026 at 3:16 pm

Related Questions

I ran into a problem. Wrote the following code snippet: teksti = teksti.Trim() teksti
I am currently running into a problem where an element is coming back from
Seemingly simple, but I cannot find anything relevant on the web. What is the
Configuring TinyMCE to allow for tags, based on a customer requirement. My config is
Is it possible to replace javascript w/ HTML if JavaScript is not enabled on

Trending Tags

analytics british company computer developers django employee employer english facebook french google interview javascript language life php programmer programs salary

Top Members

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.