2010-11-22 64 views
12

Conozco algunas de las soluciones en SQL pero no pude encontrar ninguna de ellas desde SQlite.Seleccionar números entre un rango (1 a 100) en sqlite

sólo quiero ejecutar una consulta de selección que devuelve un conjunto de resultados de números que van del 1 al 100.

Numbers 
    1 
    2 
    3 
    4 
    ...... 
    5 

Una corrección: En realidad no tengo una mesa en absoluto. (Sin embargo, una solución se animó con una mesa virtual como dual en MySQL)

Respuesta

6

¿Qué tal

SELECT * FROM myTable WHERE myNumber >= 1 AND myNumber <= 100; 

?

+0

sí bien si tabla ' mytable' existe pero no tengo una tabla en absoluto. –

+2

¿Por qué no simplemente crear un bucle en el lenguaje de programación que está utilizando? – BastiBen

+1

¿Hay algún problema con la sintaxis BETWEEN? – ocodo

-2
SELECT * FROM myTable WHERE myNumber BETWEEN 1 AND 100; 

Esto es más eficiente que usar 2 cláusulas WHERE.

+1

Lo siento, en realidad no tengo una tabla –

0

Si su objetivo es seleccionar registros reales de una tabla con valores entre 1 y 100, utilice BETWEEN como lo muestran los demás encuestados.

Si su objetivo es generar una secuencia de números del 1 al 100 sin tener una tabla para basarlo, no creo que SQLite tenga una característica que lo haga.

+0

sí, está bien si mytable tabla existe, pero no tengo una tabla en absoluto. –

3

No creo que SQLite tenga una forma clara de hacerlo, por lo que deberá usar una interfaz de tabla virtual. SQLite envía uno para 'C', y apsw tiene uno para python, como demostraré a continuación. Aquí hay documentación para el .

#!/usr/bin/python 
import apsw,tempfile 

### Opening/creating database 
filename=tempfile.mktemp() #insecure - do not use in production code 
connection=apsw.Connection(filename) 
cursor=connection.cursor() 

# This gets registered with the Connection 
class Source: 
    def Create(self, db, modulename, dbname, tablename, *args): 
     schema="create table foo(dummy integer)" 
     return schema,Table() 
    Connect=Create 

# Represents a table 
class Table: 
    def __init__(self): 
     pass 

    def BestIndex(self, constraints, orderbys): 
     used = [] 
     self.constraints = [] 
     ucount = 0 
     for c in constraints: 
      if c[1] in (
         apsw.SQLITE_INDEX_CONSTRAINT_GT, 
         apsw.SQLITE_INDEX_CONSTRAINT_GE, 
         apsw.SQLITE_INDEX_CONSTRAINT_LT, 
         apsw.SQLITE_INDEX_CONSTRAINT_LE, 
         apsw.SQLITE_INDEX_CONSTRAINT_EQ, 
         ): 
       used.append(ucount) #tell sqlite we want to use this one 
       self.constraints.append(c[1]) #save some for later 
      else: 
       used.append(None) #skip anything we don't understand 
      ucount += 1 
     return (used, # used constraints list 
        0,  # index number - no biggie we only support one right now 
       ) 

    def Open(self): 
     return Cursor(self) 

    def Disconnect(self): 
     pass 

    Destroy=Disconnect 

# Represents a cursor 
class Cursor: 
    def __init__(self, table): 
     self.table=table 

    def Filter(self, indexnum, indexname, constraintargs): 
     start = 0 
     self.end = 4000000000 
     #map constraint arguments to start and end of generation 
     for tc, ca in zip(self.table.constraints, constraintargs): 
      if tc == apsw.SQLITE_INDEX_CONSTRAINT_EQ: 
       start = ca 
       self.end = ca 
      elif tc == apsw.SQLITE_INDEX_CONSTRAINT_LE: 
       if self.end > ca: 
        self.end = ca 
      elif tc == apsw.SQLITE_INDEX_CONSTRAINT_LT: 
       if self.end >= ca: 
        self.end = ca 
      elif tc == apsw.SQLITE_INDEX_CONSTRAINT_GE: 
       if start < ca: 
        start = ca 
      elif tc == apsw.SQLITE_INDEX_CONSTRAINT_GT: 
       if start >= ca: 
        start = ca 
     self.pos = start 

    def Eof(self): 
     return self.pos > self.end 

    def Rowid(self): 
     return self.pos 

    def Next(self): 
     self.pos+=1 

    def Close(self): 
     pass 

# Register the module as intsource, you can make a bunch if needed 
connection.createmodule("intsource", Source()) 

# Create virtual table to use intsource 
cursor.execute("create virtual table uints using intsource()") 

# Do some counting 
for i in cursor.execute("SELECT rowid FROM uints WHERE rowid BETWEEN 1 AND 100"): 
    print i 

Esto implementa un tipo virtual tabla llamada "intsource", que mediante el recuento por defecto de 0 a 4 x 10^9. Es compatible con el filtrado directo por igualdad y comparación, pero cualquier otra restricción seguirá siendo filtrada por sqlite. Las tablas virtuales son un concepto muy poderoso con el que puedes hacer mucho, este es probablemente uno de los usos más simples para ellos. Además, gracias por una buena excusa para probar una nueva tabla virtual API.

6

Ejemplo de subconsulta para generar la serie 1 < = n < = 100000 en SQLite. No se crea ni usa ninguna tabla.

select 1+e+d*10+c*100+b*1000+a*10000 as n from 
(select 0 as a union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9), 
(select 0 as b union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9), 
(select 0 as c union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9), 
(select 0 as d union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9), 
(select 0 as e union select 1 union select 2 union select 3 union select 4 union select 5 union select 6 union select 7 union select 8 union select 9); 
+0

respuesta impresionante, hecho el esperado –

+0

Y sin utilizar la palabra clave 'WITH' (que aún no es compatible con la versión de SQLite de Adobe Air) – Patrick

21

Gracias sgmentzer! Inspirado por su respuesta me fui por delante y también encontré this:

WITH RECURSIVE 
    cnt(x) AS (
    SELECT 1 
    UNION ALL 
    SELECT x+1 FROM cnt 
     LIMIT 100000 
) 
SELECT x FROM cnt; 
+0

respuesta impresionante, hecho el esperado –

+0

Need Sqlite versión al menos 3.8 usar WITH. Por cierto, 'RECURSIVE' y' (x) 'son opcionales:' con cnt as (seleccione 1 x union select x + 1 from cnt where x <100000) seleccione x from cnt' –

-1

uso de esta consulta:

SELECT column1, column2, columnN 
FROM table_name 
LIMIT [no of rows] OFFSET [row num] 

Leer este enlace:

SQLite - LIMIT Clause

Cuestiones relacionadas