MySQL query example explanation through instantiated object parameters

MySQL query example explanation through instantiated object parameters

This article will introduce how to query data in MySQL by instantiating object parameters. (Source code) has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

public static string QueryByEntity<T>(T t) where T : new()
{ string resultstr = string.Empty;
  MySqlDataReader reader = null; try
  {
    Type type = typeof(T);
    PropertyInfo[] properties = type.GetProperties(); string select = string.Format("Select * from {0} {1}", type.Name, "{0}"); string where = string.Empty; foreach (PropertyInfo property in properties)
    { var value = t.GetPropertyValue<T>(property); if (value != null && !value.Equals(property.GetDefaultValue()))
      { if (string.IsNullOrEmpty(where))
        { where = string.Format(" where {0}='{1}' ", property.Name, value);
        } else
        { where = string.Format("{0} and {1} = '{2}'", where, property.Name, value);
        }
      }
    } select = string.Format(select, where);
 
    MySqlConnection connection = OpenConnection(); if (connection == null) return resultstr;
    MySqlCommand _sqlCom = new MySqlCommand(select, connection);
    reader = _sqlCom.ExecuteReader();
    List<T> tList = new List<T>(); while (reader.Read())
    {
      T t1 = new T(); foreach (PropertyInfo property in properties)
      { if (!string.IsNullOrEmpty(reader[property.Name].ToString()))
        {
          property.SetMethod.Invoke(t1, new object[] { reader[property.Name] });
        }
      }
      tList.Add(t1);
    }
    resultstr = JsonConvert.SerializeObject(tList);
  } catch (Exception ex)
  {
    Logging.Error(string.Format("Query database failed, {0}", ex.Message));
  } finally
  { if (reader != null)
    {
      reader.Close();
      reader.Dispose();
    }
  } return resultstr;
}internal static class ObjectExtend
{ public static object GetPropertyValue<T>(this object obj, PropertyInfo property)
  {
    Type type = typeof(T);
    PropertyInfo propertyInfo = type.GetProperty(property.Name); if (propertyInfo != null)
    { return propertyInfo.GetMethod.Invoke(obj, null);
    } return null;
  } public static object GetDefaultValue(this PropertyInfo property)
  { return property.PropertyType.IsValueType ? Activator.CreateInstance(property.PropertyType) : null;
  }
}

By instantiating parameters, assigning values ​​to properties, passing objects as parameters, and obtaining object names, column names, and column values ​​through reflection. The object name is required to be consistent with the table name, and the attribute is required to be consistent with the column name. Thank you for your support of 123WORDPRESS.COM.

You may also be interested in:
  • A brief discussion on the problem of passing parameters when using in in pymysql query statements
  • How to use the Limit parameter to optimize MySQL queries
  • Summary of MySQL 8.0 memory-related parameters
  • Python MySQL in parameterization description
  • Python MySQLdb parameter passing method when executing sql statements
  • Python MySQL datetime formatting as parameter operations
  • Detailed explanation of MYSQL configuration parameter optimization
  • MySQL performance comprehensive optimization method reference, from CPU, file system selection to mysql.cnf parameter optimization
  • Detailed explanation of table_open_cache parameter optimization and reasonable configuration under MySQL 5.6
  • MySQL parameter related concepts and query change methods

<<:  WeChat applet development practical skills: data transmission and storage

>>:  How to install Graphviz and get started tutorial under Windows

Recommend

Element sample code to implement dynamic table

Table of contents 【Code background】 【Code Impleme...

The actual process of implementing the guessing number game in WeChat applet

Table of contents Function Introduction Rendering...

MySQL storage engine basics

In the previous article, we talked about MySQL tr...

Docker image compression and optimization operations

The reason why Docker is so popular nowadays is m...

The table merges cells and the img image to fill the entire td HTML

Source code (some classes deleted): Copy code The ...

MySQL optimization query_cache_limit parameter description

query_cache_limit query_cache_limit specifies the...

Detailed explanation of views in MySQL

view: Views in MySQL have many similarities with ...

Detailed explanation of MySQL database Event scheduled execution tasks

1. Background As the project's business conti...

3 codes for automatic refresh of web pages

In fact, it is very simple to achieve this effect,...

js, css, html determine the various versions of the browser

Use regular expressions to determine the IE browse...

10 bad habits to avoid in Docker container applications

There is no doubt that containers have become an ...

Related commands to completely uninstall nginx under ubuntu16.04

nginx Overview nginx is a free, open source, high...

Detailed explanation of non-parent-child component value transfer in Vue3

Table of contents App.vue sub1.vue sub2.vue Summa...

Detailed tutorial on installing MySQL 8.0.20 database on CentOS 7

Related reading: MySQL8.0.20 installation tutoria...

CentOS 7 cannot access the Internet after modifying the network card

Ping www.baidu.com unknown domain name Modify the...