Detailed explanation of the usage of executenonquery
Detailed explanation of the usage of executenonquery
#Usage of ExecuteNonQuery for operating database technology in C
#Recently in I just need to catch up on the basic knowledge, and I just caught up on some database operation techniques in C#. Today I learned about ExecuteNonQuery. I looked at the code of my own project maintenance project and online data query. I basically understood the usage of ExecuteNonQuery. Let me make a brief summary. , for future reference.
The ExecuteNonQuery method is mainly used to update data, but of course it can also be used to perform target operations (such as querying the structure of the database or creating database objects such as tables). It is usually used to execute insert, update, and delete statements to change the data in the database without using Dataset. The select statement is not suitable for the ExecuteNonQuery() method.
Recommended "C Video Tutorial"
1. First, let’s take a look at the return value of ExecuteNonQuery:
1. For Update, If insert or Delete statements are executed successfully, the return value is the number of rows affected by the command. If the number of rows affected is 0, the return value is 0;
2. For all other types of statements, the return value is -1;
3. If a rollback occurs, the return value is also -1;
4. We generally judge whether the return value is greater than 0 for update operations. This is no problem. . But for other operations [such as operations on data structures (creating tables, etc.)] if the operation is successful, the return value is -1, but please pay attention. For example, adding a new table to the database, if the creation is successful, -1 will be returned. An exception will occur if it fails. It is best to use Try and Catch statements to catch exceptions when performing such operations.
2. The process of the command object updating the database through the ExecuteNonQuery method is very simple. The steps are as follows:
1. Create a database connection;
2. Create a Command object and specify a SQL Inser, Update, Delete query or stored procedure;
3. Attach the Command object to the database connection;
4. Call the ExecuteNonQuery() method;
5. Close the connection.
3. How to use the code example:
1. First is a very simple class, which provides how to use the command object to communicate with the new database through the ExecuteNonQuery method.
public class ExecuteNonQueryClas { private static string connectionString = ConfigurationManager.ConnectionStrings["connectionString"].ConnectionString; //as this method provided static method, set the constructor to priviate to prevent create instance with 'new ExecuteNonQuery()' private ExecuteNonQueryClas() { } public static int ExecuteNonQuery(string commandText) { return ExecuteNonQuery(commandText, (SqlParameter[])null); } public static int ExecuteNonQuery(string commandText,SqlParameter[] commandParams) { //if connectionString is null, then throw exception if(connectionString == null || connectionString.Length == 0) throw new ArgumentNullException("connectionString"); using(SqlConnection conn = new SqlConnection(connectionString)) { SqlCommand cmd = new SqlCommand(commandText,conn); if (conn.State != ConnectionState.Open) conn.Open(); //check if the commandParams is not null, then attach params to command if(commandParams !=null) AttachParameters(cmd,commandParams); int recordsAffected = cmd.ExecuteNonQuery(); return recordsAffected; } } private static void AttachParameters(SqlCommand cmd,SqlParameter[] commandParams) { if (cmd == null) throw new ArgumentException("command"); if (commandParams != null) { foreach (SqlParameter p in commandParams) { if (p != null) { //// Check for derived output value with no value assigned if ((p.Direction == ParameterDirection.InputOutput || p.Direction == ParameterDirection.Input) && (p.Value == null)) { p.Value = DBNull.Value; } cmd.Parameters.Add(p); } } } } }
2. Call in the main function:
static void Main(string[] args) { string userName = Console.ReadLine(); string loginId = "user"; string sqlString = "update Users set UserName = @name where LoginID= @loginID"; SqlParameter[] parms ={ new SqlParameter("@name",userName), new SqlParameter("@loginID",loginId) }; int rlt = ExecuteNonQueryClas.ExecuteNonQuery(sqlString,parms); Console.WriteLine(rlt); Console.Read(); }
Okay, the above is the simplest introduction and example of using the ExecuteNonQuery method.
The above is the detailed content of Detailed explanation of the usage of executenonquery. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



In C, the char type is used in strings: 1. Store a single character; 2. Use an array to represent a string and end with a null terminator; 3. Operate through a string operation function; 4. Read or output a string from the keyboard.

The usage methods of symbols in C language cover arithmetic, assignment, conditions, logic, bit operators, etc. Arithmetic operators are used for basic mathematical operations, assignment operators are used for assignment and addition, subtraction, multiplication and division assignment, condition operators are used for different operations according to conditions, logical operators are used for logical operations, bit operators are used for bit-level operations, and special constants are used to represent null pointers, end-of-file markers, and non-numeric values.

In C language, special characters are processed through escape sequences, such as: \n represents line breaks. \t means tab character. Use escape sequences or character constants to represent special characters, such as char c = '\n'. Note that the backslash needs to be escaped twice. Different platforms and compilers may have different escape sequences, please consult the documentation.

In C language, the main difference between char and wchar_t is character encoding: char uses ASCII or extends ASCII, wchar_t uses Unicode; char takes up 1-2 bytes, wchar_t takes up 2-4 bytes; char is suitable for English text, wchar_t is suitable for multilingual text; char is widely supported, wchar_t depends on whether the compiler and operating system support Unicode; char is limited in character range, wchar_t has a larger character range, and special functions are used for arithmetic operations.

The difference between multithreading and asynchronous is that multithreading executes multiple threads at the same time, while asynchronously performs operations without blocking the current thread. Multithreading is used for compute-intensive tasks, while asynchronously is used for user interaction. The advantage of multi-threading is to improve computing performance, while the advantage of asynchronous is to not block UI threads. Choosing multithreading or asynchronous depends on the nature of the task: Computation-intensive tasks use multithreading, tasks that interact with external resources and need to keep UI responsiveness use asynchronous.

In C language, char type conversion can be directly converted to another type by: casting: using casting characters. Automatic type conversion: When one type of data can accommodate another type of value, the compiler automatically converts it.

There is no built-in sum function in C language, so it needs to be written by yourself. Sum can be achieved by traversing the array and accumulating elements: Loop version: Sum is calculated using for loop and array length. Pointer version: Use pointers to point to array elements, and efficient summing is achieved through self-increment pointers. Dynamically allocate array version: Dynamically allocate arrays and manage memory yourself, ensuring that allocated memory is freed to prevent memory leaks.

The char array stores character sequences in C language and is declared as char array_name[size]. The access element is passed through the subscript operator, and the element ends with the null terminator '\0', which represents the end point of the string. The C language provides a variety of string manipulation functions, such as strlen(), strcpy(), strcat() and strcmp().
