如何将文本框中输入的数据存入数据库?——c 读取文本框值到数据库 (c 读取文本框值到数据库)

在很多程序设计的场景中,我们需要从用户手中获取数据。而这些数据可能是用户输入的文本、图片、视频等等。在这些数据被获取到之后,我们通常需要将其存储在数据库中。本文将介绍如何使用c语言读取文本框值并将其存储到数据库中。

1. 连接数据库

在进行数据存储之前,我们需要先建立一个数据库连接。在c语言中,我们可以使用ODBC API来连接数据库。ODBC API是一套标准的API,这意味着我们可以使用ODBC API来连接各种类型的数据库,如Microsoft SQL Server、MySQL、Oracle等等。

以下是一个建立ODBC连接的示例代码:

“`

#include

#include

#include

#include

SQLHENV henv; // Environment Handle

SQLHDBC hdbc; // Connection Handle

int mn()

{

SQLRETURN retcode;

// Allocate Environment Handle

retcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Set the ODBC version

retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER*)SQL_OV_ODBC3, 0);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Allocate Connection Handle

retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Connect to database

retcode = SQLConnect(hdbc, (SQLCHAR*)L”DatasourceName”, SQL_NTS, (SQLCHAR*)L”UserName”, SQL_NTS, (SQLCHAR*)L”Password”, SQL_NTS);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Do something with the database

}

}

}

}

return 0;

}

“`

在这个示例代码中,我们使用SQLAllocHandle函数分别创建了Environment Handle和Connection Handle。然后,在 SQLSetEnvAttr函数中,我们设置了ODBC的版本。接着,我们又使用SQLConnect函数连接了数据库。注意,这里的 DatasourceName、UserName、Password都是需要替换为实际的数据库信息的。

2. 获取文本框输入的值

建立好了数据库连接之后,我们就需要从文本框中获取用户输入的值了。在常规的Windows程序中,我们可以使用GetDlgItemText函数获取文本框输入的值。示例代码如下:

“`

#include

#define IDC_EDIT1 100

LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)

{

switch (message)

{

case WM_CREATE:

{

CreateWindow(L”EDIT”, L””, WS_VISIBLE | WS_CHILD | WS_BORDER, 10, 10, 200, 20, hWnd, (HMENU)IDC_EDIT1, NULL, NULL);

CreateWindow(L”BUTTON”, L”存储”, WS_VISIBLE | WS_CHILD, 10, 40, 100, 30, hWnd, (HMENU)IDC_BUTTON1, NULL, NULL);

}

return 0;

case WM_COMMAND:

switch (LOWORD(wParam))

{

case IDC_BUTTON1:

TCHAR text[256];

GetDlgItemText(hWnd, IDC_EDIT1, text, 256);

// Do something with the text

return 0;

}

break;

case WM_DESTROY:

PostQuitMessage(0);

return 0;

}

return DefWindowProc(hWnd, message, wParam, lParam);

}

int WINAPI WinMn(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)

{

WNDCLASS wc = {0};

wc.hbrBackground = (HBRUSH)(COLOR_BACKGROUND);

wc.hCursor = LoadCursor(NULL, IDC_ARROW);

wc.hInstance = hInstance;

wc.lpfnWndProc = WndProc;

wc.lpszClassName = L”MnWndClass”;

RegisterClass(&wc);

HWND hWnd = CreateWindow(L”MnWndClass”, L”窗口标题”, WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, 300, 200, NULL, NULL, hInstance, NULL);

ShowWindow(hWnd, nCmdShow);

MSG msg = {0};

while(GetMessage(&msg, NULL, 0, 0))

{

TranslateMessage(&msg);

DispatchMessage(&msg);

}

return msg.wParam;

}

“`

在这段代码中,我们创建了一个文本框和一个按钮。当用户点击按钮时,我们就可以通过GetDlgItemText函数获取文本框输入的值了。注意,这里的 IDC_EDIT1、IDC_BUTTON1 都是需要替换为实际的控件ID的。

3. 将数据存储在数据库中

我们需要将从文本框中获取到的值存储在数据库中。在c语言中,我们可以使用ODBC API来执行SQL语句。以下是一个将数据插入数据库的示例代码:

“`

#include

#include

#include

#include

SQLHENV henv; // Environment Handle

SQLHDBC hdbc; // Connection Handle

int mn()

{

SQLRETURN retcode;

// Allocate Environment Handle

retcode = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Set the ODBC version

retcode = SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER*)SQL_OV_ODBC3, 0);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Allocate Connection Handle

retcode = SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Connect to database

retcode = SQLConnect(hdbc, (SQLCHAR*)L”DatasourceName”, SQL_NTS, (SQLCHAR*)L”UserName”, SQL_NTS, (SQLCHAR*)L”Password”, SQL_NTS);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

// Insert data into database

SQLHSTMT hstmt;

retcode = SQLAllocHandle(SQL_HANDLE_STMT, hdbc, &hstmt);

if (retcode == SQL_SUCCESS || retcode == SQL_SUCCESS_WITH_INFO) {

TCHAR text[256];

GetWindowText(hwnd, text, 256);

SQLTCHAR* sql = (SQLTCHAR*)L”INSERT INTO [Table] ([Column]) VALUES (?)”;

SQLPrepare(hstmt, sql, SQL_NTS);

SQLBindParameter(hstmt, 1, SQL_PARAM_INPUT, SQL_C_TCHAR, SQL_VARCHAR, 256, 0, text, 0, NULL);

SQLExecute(hstmt);

SQLFreeHandle(SQL_HANDLE_STMT, hstmt);

}

}

}

}

}

return 0;

}

“`

在这个示例代码中,我们先通过SQLAllocHandle函数创建了一个Statement Handle,然后使用GetWindowText函数获取了文本框输入的值。接着,我们使用SQLTCHAR类型定义了SQL语句,然后使用SQLPrepare函数将SQL语句与Statement Handle绑定。在SQLBindParameter函数中,我们将获取到的文本框值绑定到SQL语句中。我们使用SQLExecute函数执行SQL语句并关闭Statement Handle。

相关问题拓展阅读:

c#在前台文本框的值怎么发送到后台去?

可以用json方法提交

这个不应该叫什么发到后简纯喊台,而应该是在写一个方法将前台的文本框等的值进行处理保存到数据库,然后后台可以读取这些已经保存的数据。常规来讲是这裤册样的思拦野路。

C#中获取js里的值个人建议还是使用HiddenField控件,放一个HiddenField控件,这个是隐藏控件,这么传值不会丢,用给HiddenField的value赋值,然后在后台得到HiddenField的value即可。

看了你的问题补充,唉,你确认你是C#?文本框获取值,你直接拖放一个TextBox控件,然后在后台用TextBox1.text就获取脊雀到了文本框的值。 如果不是拖放控件,用html原生态的input的话,那就是

前台

后台

string xx = Request.Form;

前台

后樱团早台

string xx = txt.Value;

关于c 读取文本框值到数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » 如何将文本框中输入的数据存入数据库?——c 读取文本框值到数据库 (c 读取文本框值到数据库)