Hacer consultas SQL dinámicas a una base de datos MySQL

Nunca he usado golang con mysql antes, así que estoy leyendo sobre estos por primera vez. Me gustaría hacer algo como esto:

if userId && gender && age
db.QueryRow("SELECT name FROM users WHERE userId=? AND gender=? AND age=?", userId,gender,age)
else if gender && age
db.QueryRow("SELECT name FROM users WHERE gender=? AND age=?", gender, age)
else if userId && gender
db.QueryRow("SELECT name FROM users WHERE userId=? AND gender=?", userId,gender)
else if userId && age
db.QueryRow("SELECT name FROM users WHERE userId=? AND age=?", userId, age)
else if gender
db.QueryRow("SELECT name FROM users WHERE gender=?", gender)
else if userId
db.QueryRow("SELECT name FROM users WHERE userId=?", userId)
else if age
db.QueryRow("SELECT name FROM users WHERE age=?", age)

Esto es escribir demasiado, especialmente si tengo una docena más de variables que me gustaría agregar a la condición WHERE.

Si esto fuera PHP, haría algo como esto:

$sql = "SELECT name FROM users ";
$where = array();
foreach(explode(",","userId,gender,age,name,height,weight,ethnicity" as $field)
{
    if(isset($arrayOfValues[$field]))
    {
        $where[count($where)] = $field." = ?".$field
        $db->bind("?".$field,$arrayOfValues[$field]);
    }
}

if(count($where)>0)
$sql = $sql . " WHERE ".implode(" AND ",$where);
$db->query($sql);

Al usar un bucle foreach, puedo generar consultas dinámicamente y vincular dinámicamente tantas variables como sea necesario.

¿Es algo como esto una opción con golang y mysql? ¿O hay alternativas a no escribir todas las combinaciones de variables para una consulta?

Respuestas a la pregunta(1)

Su respuesta a la pregunta