I have been working with SQL queries for a while. Usually through SQLite connection to the database and creating a database can be done by the following code: #include <stdio.h> #include <stdlib.h> #include <sqlite3.h>
/* Create SQL statement */
sql = "CREATE TABLE COMPANY("
"ID INT PRIMARY KEY NOT NULL,"
"NAME TEXT NOT NULL,"
"AGE INT NOT NULL,"
"ADDRESS CHAR(50),"
"SALARY REAL );";
Thank you sir for suggesting. I am doing my final year project to develop a tool for writing SQL queries in a language other than English. Can you please suggest, how to get with the CODING in C/C++ for generating queries in that particular language?
Thank you.
Sir, I have been searching many websites for reference for my project, but unable to know how SQL queries have been created initially. From wikipedia, I got to know that the query language was developed using ANSI-C but unable to know the coding used for development. I think it will help me create a tool for writing queries in a language other than English. Please suggest if any, it will be great help.
On the one hand, it sounds like you are looking to build a program that emits SQL that is ANSI SQL translated to another language. As I pointed out, I'm not sure where you would run that.
On the other hand, it sounds like you want to build a program that reads SQL written in another language (like my previous example in Dutch) and translates it.
I'm not sure if you want to do 1 or 2. Perhaps if you post a few of the links you referred to, we can help you out a bit more.
Note that this is a SQL Server forum, not a C forum. However, the Postgres project is completely open source, as is MySql, MariaDB and others. If you are looking for examples of C programs that parse SQL, you can start there.
As you said in above reply, as we write the 'Dutch' language query in the database editor tool will it be translated to 'English' SQL query and then get parsed? Will the result data be shown in same 'dutch' language?
The results depend on the query. If your query is returning rows from some table, and the table contains text, there is no built-in translator so it will be displayed as-is. However, SQL is locale-aware so will display dates, times and numbers in the locale-appropriate manner, if you SET LANGUAGE before running the query.
Assume that I have developed a tool and wrote a query to create a table in Dutch language, which then gets to the translator and converted into usual SQL query.
For example.,
CREATE TABLE emp
(
int emp_id
varchar emp_name (15)
varchar dept (15)
)
What is the background (pre-compiler) coding (in ANSI C or C or C++ only) for generating the table as output?
.
.
.
.
Note: consider the following Embedded SQL C code's snippet:
.
EXEC SQL begin declare section;
int cno;
varchar cname (20);
varchar address (20);
EXEC SQL end declare section;
.
. The pre compiler converts the above code line /varchar cname (20)/ as:
struct
{ unsigned short len;
unsigned char arr [20]
}cname;
.
and similar coding for other lines.
.
.
.
How will the pre-compiled code will be generated in SQL query's pre-compilation?
I meant that SQL was written in ANSI C (as described in Postgres95 document, as well as for IBM's DB2), how was the coding written behind queries? I am unable to find any examples for these codes.
When I write a query, the "coding behind the queries" is what happens in my brain before I type it into the query editor. Not surprised you can't find any examples for that! Neurologists would love to have that code, too!
Sir, I meant as 'SQL was developed using ANSI C initially in 1970's', i was talking about that code in ANSI standard (if available).
If we write an SQL statement in the front-end tool, how will it be recognized by database in the back-end?
How will the interaction will go on in the back-end to generate output?
.
.
See this link Processing of SQL statement
The parsing and accessing (as in the above link) all goes on in the back-end.
.
.
Just as the above case, how could it connect to my project, as I need to develop a tool in which we can write queries in a language other than English?
(Hope you would understand this)
When you send a query to the database, it compiles the query into an internal format (depends on the database) then computes an execution plan for running the query. Then, it executes the plan and returns any results to the requester.
So, in your tool, you need to take the input in whatever (human) language you like, translate it to ANSI SQL, then pass it to the database for actual execution, then take the results, possibly translate them back into the (human) language of the tool and present the results.
FWIW I found the parser for Postgresql here: Parser