Займите слишком много времени для записи в Access Data Base с помощью приложения C # WPF, Visual Studio,

Вот пример сообщения с вложением PDF, текст «тело» и отправка через Gmail.

# Import smtplib for the actual sending function
import smtplib

# For guessing MIME type
import mimetypes

# Import the email modules we'll need
import email
import email.mime.application

# Create a text/plain message
msg = email.mime.Multipart.MIMEMultipart()
msg['Subject'] = 'Greetings'
msg['From'] = 'xyz@gmail.com'
msg['To'] = 'abc@gmail.com'

# The main body is just another attachment
body = email.mime.Text.MIMEText("""Hello, how are you? I am fine.
This is a rather nice letter, don't you think?""")
msg.attach(body)

# PDF attachment
filename='simple-table.pdf'
fp=open(filename,'rb')
att = email.mime.application.MIMEApplication(fp.read(),_subtype="pdf")
fp.close()
att.add_header('Content-Disposition','attachment',filename=filename)
msg.attach(att)

# send via Gmail server
# NOTE: my ISP, Centurylink, seems to be automatically rewriting
# port 25 packets to be port 587 and it is trashing port 587 packets.
# So, I use the default port 25, but I authenticate. 
s = smtplib.SMTP('smtp.gmail.com')
s.starttls()
s.login('xyz@gmail.com','xyzpassword')
s.sendmail('xyz@gmail.com',['xyz@gmail.com'], msg.as_string())
s.quit()
0
задан jon 19 March 2019 в 12:50
поделиться

1 ответ

Используя метод, который вы показываете здесь, вы добавляете по одной строке за раз. Таким образом, сервер открывает соединение с БД, данные записываются в память, затем в физический файл (mdb), затем индексы обновляются. Это целых четыре шага в строке, которые вы пытаетесь выполнить. Хуже того, запись данных в физический файл занимает много времени.

Я думаю, что если вы используете другой подход, выполните эти четыре шага (подключение, память, запись данных, переиндексация) для всего набора данных, которые вы пытаетесь вставить. Итак, предположим, что вы добавляете 1000 записей, а не 4000 шагов (4x1000), вы можете сократить эту обработку до 1400 шагов обработки (1 соединение, сверхбыстрая запись в память 1000, 1 запись в файл данных, 1 пересмотр индекса). [ 112]

Следующий код дает приблизительное представление о том, о чем я говорю:

class Program
{
    static void Main(string[] args)
    {
        //memory-only list for data loading
        List<HeaderResult> mylist = new List<HeaderResult>(){ new HeaderResult("report1","desc of report","ete"), new HeaderResult("report2", "desc of report2", "ete2")};
        var tableForInsert = new DataTable();
        using (SqlDataAdapter dataAdapter = new SqlDataAdapter("SELECT * from  HeaderResult", "my conneciton string")) {
            dataAdapter.Fill(tableForInsert);

            //now I have a live copy of the table into which I want to insert data
            //blast in the data
            foreach (HeaderResult hr in mylist) {
                tableForInsert.Rows.Add(hr);
            }

            //now all the data is written at once and sql will take care of the indexes after the datat's written
            dataAdapter.Update(tableForInsert);
        }
}

//class should have same fields as your table
class HeaderResult
{
    string report;
    string reportDescription;
    string etc;
    public HeaderResult(string rpt, string desc, string e)
    {
        report = rpt;
        reportDescription = desc;
        etc = e;
    }
}
0
ответ дан Brian 19 March 2019 в 12:50
поделиться
Другие вопросы по тегам:

Похожие вопросы: